python 矩阵运算出问题

NumberOfCandidateDevices = 3
python矩阵运算出问题。 按照代码逻辑, 应该会得到这样的矩阵

img

#Evaluator1 - Repeatability
#Deviation
Device1_deviation = 0.06 - 0.05
Device2_deviation = 0.06 - 0.05
Device3_deviation = 0.3 - 0.05

DeviceEvaluatorList = []
DeviceEvaluatorList.append(Device1_deviation)
DeviceEvaluatorList.append(Device2_deviation)
DeviceEvaluatorList.append(Device3_deviation)
B =np.empty((NumberOfCandidateDevices,NumberOfCandidateDevices))
for i in range(1, NumberOfCandidateDevices+1):
    for j in range(1, NumberOfCandidateDevices+1):
        a = DeviceEvaluatorList[i-1]
        b = DeviceEvaluatorList[j-1]
        if a < b:
            B[i-1,j-1] = 0.6
        if a == b:
            B[i-1,j-1] = 0.5
        else:
            B[i-1,j-1] = 0
B

但是实际运算出的矩阵如下。即最右边前两行应该为1,但是算出来却为0. 可否解释下原因,并修正下代码

img

除此之外想把生成 的B 转换成矩阵,如何操作?

赋值的0.6改为1,把最后一个else改为 if a > b:,条件清晰明了,有用记得采纳

import numpy as np

# Evaluator1 - Repeatability
# Deviation
Device1_deviation = 0.06 - 0.05
Device2_deviation = 0.06 - 0.05
Device3_deviation = 0.3 - 0.05
NumberOfCandidateDevices = 3
DeviceEvaluatorList = []

DeviceEvaluatorList.append(Device1_deviation)
DeviceEvaluatorList.append(Device2_deviation)
DeviceEvaluatorList.append(Device3_deviation)
B = np.empty((NumberOfCandidateDevices, NumberOfCandidateDevices))
for i in range(1, NumberOfCandidateDevices + 1):
    for j in range(1, NumberOfCandidateDevices + 1):
        a = DeviceEvaluatorList[i - 1]
        b = DeviceEvaluatorList[j - 1]
        if a < b:
            B[i - 1, j - 1] = 1
        if a == b:
            B[i - 1, j - 1] = 0.5
        if a > b:
            B[i - 1, j - 1] = 0
print(B)

import numpy as np

NumberOfCandidateDevices = 3
# Evaluator1 - Repeatability
# Deviation
Device1_deviation = 0.06 - 0.05
Device2_deviation = 0.06 - 0.05
Device3_deviation = 0.3 - 0.05

DeviceEvaluatorList = []
DeviceEvaluatorList.append(Device1_deviation)
DeviceEvaluatorList.append(Device2_deviation)
DeviceEvaluatorList.append(Device3_deviation)
print(DeviceEvaluatorList)
B = np.empty((NumberOfCandidateDevices, NumberOfCandidateDevices))
print(B)
for i in range(1, NumberOfCandidateDevices + 1):
    for j in range(1, NumberOfCandidateDevices+1):
        a = DeviceEvaluatorList[i - 1]
        b = DeviceEvaluatorList[j - 1]
        if a < b:
            B[i - 1, j - 1] = 1
        elif a == b:
            B[i - 1, j - 1] = 0.5
        else:
            B[i - 1, j - 1] = 0

ArrayToMat = np.mat(B) # 数组转矩阵
print(type(ArrayToMat))
print(ArrayToMat, end='\n\n')

车机安装第三方app教程,如何解除安卓车机禁止安装软件-有驾 看看这篇回答

您好,问题已解决,如有帮助还请采纳。
问题在于,连续判断的时候,第二次判断不能用if,应该使用elif,不然会出现重复判断,会覆盖上边第一次判断的结果。此外将第一次判断的结果赋值由0.6改为1。
'

import numpy as np


NumberOfCandidateDevices = 3
# Evaluator1 - Repeatability
# Deviation
Device1_deviation = 0.06 - 0.05
Device2_deviation = 0.06 - 0.05
Device3_deviation = 0.3 - 0.05

DeviceEvaluatorList = []
DeviceEvaluatorList.append(Device1_deviation)
DeviceEvaluatorList.append(Device2_deviation)
DeviceEvaluatorList.append(Device3_deviation)

B = np.empty((NumberOfCandidateDevices, NumberOfCandidateDevices))

for i in range(1, NumberOfCandidateDevices + 1):
    for j in range(1, NumberOfCandidateDevices + 1):
        a = DeviceEvaluatorList[i - 1]
        b = DeviceEvaluatorList[j - 1]
        if a < b:
            B[i - 1, j - 1] = 1
        elif a == b:
            B[i - 1, j - 1] = 0.5
        else:
            B[i - 1, j - 1] = 0
print(B)