Effacer les filtres
Effacer les filtres

parent1= 0 0 0 0 1 0 0 1 and parent2=0 0 0 0 1 1 0 0 and i have another parent 1 to 50 element and i want swap 7 and 8th raw

2 vues (au cours des 30 derniers jours)
parent 1 :0 0 0 0 1 0 0 1
parent 2: 0 0 0 0 1 1 0 0
swap 7 & 8 element of both1 and create new one
child 1: 0 0 0 0 1 0 0 0
child 2: 0 0 0 0 1 1 0 1
parent 1 & 2 create child 1& 2 same like 3 and 4....5 & 6...done further process in for loop for 1 to 50 all parent and child are in 8 bit digit but here consider as 1*8 matrix or array of 8 entry
child2=parent(1,:);
child2(swapping)=parent(4,:)(swapping);
i tried this but here 'parent(4,:)(swapping)' part create error

Réponse acceptée

Guillaume
Guillaume le 14 Déc 2016
Don't number variables. It's going to give you problems later on.
You can't chain indexing. What you mean by
p(2, :)(end)
is actually
p(2, end)
So, for your example:
parent = [0 0 0 0 1 0 0 1;
0 0 0 0 1 1 0 0]
child = parent;
swappedcolumns = [7 8];
child([1 2], swappedcolumns) = child([2 1], swappedcolumns)
Notice that the order of the rows has been reversed in the assignment in order to swap the swappedcolumns of row 1 and 2.
One way to swap all even and odd rows:
parent = randi([0 1], 50, 8) %demo data
swappedcolumns = [7 8];
child = parent;
swapoddeven = reshape([2:2:size(parent, 1); 1:2:size(parent, 1)], 1, []); %create vector of [2 1 4 3 6 5 ...]
child(swapoddeven, swappedcolumns) = child(1:size(parent, 1), swappedcolumns)
No loop needed
  5 commentaires
Guillaume
Guillaume le 14 Déc 2016
Your comment is completely unreadable. Please, get rid of all these blank lines between each line of code and use the {}Code button to format your code instead.
It does not make people to want to help you when you accept their answer and then unaccept it when it does not answer a completely different question that you ask in the comments.
I recommend that you reaccept the answer and ask your new question in a completely new post, linking this question and the one where you must have had the first part of your code.

Connectez-vous pour commenter.

Plus de réponses (1)

KSSV
KSSV le 14 Déc 2016
p1 = [0 0 0 0 1 0 0 1] ;
p2= [0 0 0 0 1 1 0 0] ;
c1 = p1 ;
c2 = p2 ;
c1(end) = p2(end) ;
c2(end) = p1(end) ;
  2 commentaires
Pratik Anandpara
Pratik Anandpara le 14 Déc 2016
i take this p1 p2 from parent matrix if i use
c1 = p(1,:) ;
c2 = p(2,:) ;
c1(end) = p(2,:)(end) ;
c2(end) = p(1,:)(end) ;
than not working each time not possible to define
pa1=p(1,:)..pa2=p(2,:)
Pratik Anandpara
Pratik Anandpara le 14 Déc 2016
my code uptill now...@Guillaume i want to find minumum value of [(X(-0.33).^2+(Y-0.33).^2+(Z-0.33).^2] this function where X+Y+Z=9 with genetic algorithm
x = 0:9 ;
y=x ;
z = x ;
[X,Y,Z] = ndgrid(x,y,z) ;
thesum = X+Y+Z ;
idx = thesum==9 ;
iwant = [X(idx) Y(idx) Z(idx)];
eq1=[(X(idx)-0.33).^2+(Y(idx)-0.33).^2+(Z(idx)-0.33).^2] ;
[p,q]=min(eq1);
iwant(q,:);
dec2bin(iwant)';
de2bi(iwant(1,:));
for i=1:6
c(i)=1+round(rand*54);
el=iwant(c(i),:);
entry(i,:)=[el];
de2bi(el,8);
totalfx0(i,:)=eq1(c(i),:) ;
lowest(i,:)=min(totalfx0(i,:)) ;
finaltotalfx=sum(totalfx0) ;
end
bins=fliplr(de2bi(entry(:,:),8));
swappedcolumns = [7 8];
child = bins;
swapoddeven = reshape([2:2:size(bins, 1); 1:2:size(bins, 1)], 1, []);
child(swapoddeven, swappedcolumns) = child(1:size(bins,
1),swappedcolumns);
bincon=bi2de(fliplr(child(:,:)));
cross1=reshape(bincon,6,3)

Connectez-vous pour commenter.

Produits

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by