Filter löschen
Filter löschen

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 Ansichten (letzte 30 Tage)
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

Akzeptierte Antwort

Guillaume
Guillaume am 14 Dez. 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 Kommentare
Guillaume
Guillaume am 14 Dez. 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.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

KSSV
KSSV am 14 Dez. 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 Kommentare
Pratik Anandpara
Pratik Anandpara am 14 Dez. 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 am 14 Dez. 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)

Melden Sie sich an, um zu kommentieren.

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by