Lukas00990 2022-09-30 05:48 采纳率: 40.8%
浏览 112
已结题

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 转换成矩阵,如何操作?

  • 写回答

4条回答 默认 最新

  • 脚踏南山 2022-09-30 14:11
    关注

    赋值的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)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 10月10日
  • 已采纳回答 10月2日
  • 修改了问题 9月30日
  • 修改了问题 9月30日
  • 展开全部

悬赏问题

  • ¥15 求C# .net4.8小报表工具
  • ¥15 安装虚拟机时出现问题
  • ¥15 Selenium+docker Chrome不能运行
  • ¥15 mac电脑,安装charles后无法正常抓包
  • ¥18 visio打开文件一直显示文件未找到
  • ¥15 请教一下,openwrt如何让同一usb储存设备拔插后设备符号不变?
  • ¥50 使用quartz框架进行分布式任务定时调度,启动了两个实例,但是只有一个实例参与调度,另外一个实例没有参与调度,不知道是为什么?请各位帮助看一下原因!!
  • ¥50 怎么获取Ace Editor中的python代码后怎么调用Skulpt执行代码
  • ¥30 fpga基于dds生成幅值相位频率和波形可调的容易信号发生器。
  • ¥15 R语言shiny包和ncdf4包报错