作者pk790127 (<>)
看板MATLAB
標題[討論] 基因演算法 交換問題
時間Fri Oct 28 22:49:56 2016
初學matlab , 想要簡單實踐基因演算法的邏輯,而不是用套件
我的交配(crossover)邏輯是有參考一篇paper所提供的 以下舉例:
1~6個數值
V V V
P1 = [1,2,3,4,5,6]
V V V
P2 = [2,4,1,3,6,5]
我生成C1的方法是固定P2的位置(第2,4,6的位置),然後當作C1的值
V V V
C1 = [X,4,X,3,X,5] ,而剩下的X的值則由P1扣除掉4,3,5的值照順序填入
P1 = [1,2,3(X),4(X),5(X),6] --> [1,2,6]
C1 = [1,4,2,3,6,5] 就是我求得的C1 子代的值 ,C2也同理
我在matlab上面我可以在固定位置的情況下達成,例如固定2,4,6的位置
P2([2,4,6]) %固定P2位置
P2_X = (P2([2,4,6])) % 令一個值存取叫P2_X
Y1=P1 % 令一個新矩陣叫Y1
for i = 1:3
Y1(Y1==P2_X(i)) = [] % 把Y1裡面有P2_X重複的值挑出來
由於我都知道位置 所以
C1 = [Y1(1),P2(2),Y1(2),P2(4),Y1(3),P2(6)] % 我就可以土法煉鋼的把C1填出來
但是我想知道的是,當我位置隨機給定,不再是2,4,6而是其他隨機產生的值
我有什麼方法可以做到我的交換邏輯,因為初學還不是很熟很多語法
我只能用比較笨的方法做...希望各位大大能指點
謝謝
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.116.86.113
※ 文章網址: https://www.ptt.cc/bbs/MATLAB/M.1477666199.A.2E5.html
※ 編輯: pk790127 (36.238.93.87), 10/29/2016 01:43:32
推 sunev: ind=[2 4 6];[x,ind2]=setdiff(P1,P2(ind),'stable'); 10/31 21:18
→ sunev: C1=P2;C1(ind2)=x; 10/31 21:18
→ pk790127: 感謝~ 有大概懂matlab矩陣的邏輯,雖然照這方法還是不行 11/02 20:38
→ pk790127: 不過我用for迴圈硬灌解決了 但是還是想知道上述的方法 11/02 20:39
推 sunev: 因為沒有實機測試過,所以不行也是理所當然的 (咦?) 11/02 20:55
→ linfox: C1=P2;C1(ind2)=x;改成C1=zeros(1,6);C1(ind)=P2(ind); 11/02 21:31
→ linfox: C1(C1==0)=P1(sort(ind2)); 11/02 21:32
→ pk790127: 感謝兩位提供的方法 已經成功解決了~ 11/03 02:37