您好,登錄后才能下訂單哦!
本文實例講述了python關于矩陣重復賦值覆蓋問題的解決方法。分享給大家供大家參考,具體如下:
import itertools import numpy as np comb = list(itertools.combinations(list(range(regions)), 2)) bands_info = [] coeff = np.zeros([bands, len(comb)]) for cla in range(classes): class_info = data[:,cla*bands*regions:(cla+1)*bands*regions] for bs in range(bands): n = bs*regions for i in range(len(comb)): index1 = comb[i][0]+n index2 = comb[i][1]+n part1 = class_info[:, index1] part2 = class_info[:, index2] coeff[bs, i] = (np.corrcoef(part1, part2))[0, 1] bands_info.append(coeff.reshape([1,-1])) coeff_info = np.vstack((bands_info[0], bands_info[1], bands_info[2],bands_info[3]))
例如這個循環賦值過程,最終得出來的結果是bands_info這個List里面每一個矩陣都是一樣的,這是為什么呢?我一開始也在這里糾結了很長時間,思來想去感覺沒錯的呀。后來想想以前學的C語言知識,才有點明白。原來python里面有淺層copy和深層copy這一說,同是一個矩陣的話占用的是同一個地址,在里面進行重復賦值的話前面的值都會被覆蓋掉。不只是當前變量被覆蓋掉,就是你之后用到這個變量的也會被覆蓋。比如說你a的變量被b覆蓋了,那你后面用到a的變量的地方,a的值也會變成b的值。是不是很可怕。
那么應該怎么進行修改呢?
import itertools import numpy as np comb = list(itertools.combinations(list(range(regions)), 2)) bands_info = [] for cla in range(classes): coeff = np.zeros([bands, len(comb)]) class_info = data[:,cla*bands*regions:(cla+1)*bands*regions] for bs in range(bands): n = bs*regions for i in range(len(comb)): index1 = comb[i][0]+n index2 = comb[i][1]+n part1 = class_info[:, index1] part2 = class_info[:, index2] coeff[bs, i] = (np.corrcoef(part1, part2))[0, 1] bands_info.append(coeff.reshape([1,-1])) coeff_info = np.vstack((bands_info[0], bands_info[1], bands_info[2],bands_info[3]))
改成這樣就可以了。就是將初始矩陣在循環里在重新設定一遍,意思相當就是給了一次新的地址,再進行復制的話就不會覆蓋前面的結果了。
更多關于Python相關內容感興趣的讀者可查看本站專題:《Python數學運算技巧總結》、《Python數據結構與算法教程》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經典教程》
希望本文所述對大家Python程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。