convert negatives matrix values to positive to then be used in mirroring for a plot on a graph
    2 visualizzazioni (ultimi 30 giorni)
  
       Mostra commenti meno recenti
    
I will start at I am modelling a flea response by an animal moving away from the source (in this case the origin at (0,0)). I have had some difficulty when the x value coordinate of the animal position is negative, and I think this is due to the gradient between the source and the position of the animal, it works perfectly fine when the coordinates are positive or when we have a positive x value and negative y value as the graph produced is a line graph moving directly away from the origin, whereas when the x value is negative it goes towards the origin then moves away. How ive done this model is to randomly generate 5 different positions/ coordinates as a matrix and separate the x and y values. My thought process next was to convert any negative x value coordinate to positive, produce the graph and then mirror the lines that had a negative x value earlier through the y axis and this should hopefully produce the graph i want showcasing a flea response from the animal moving away from the source. 
The questions sets in, how do I convert the selected negative x values from the matrix named x1, produce the graph, and then mirror those lines only that had been converted. I have attached my code so far below including how i have calculated the new positions (as this is something i need) and hope someone can help with this.
x0 = 0;
y0 = 0;
Sr = [x0 y0];            %Source coordinates
SL = 220;                %Source Level dB re 1uPa @ 1m (made up  need to find example)
a = 0.25;                %Attenuation (made up need to find example)
IL = 180;                %Impact Level (made up need to find example)
v = 2;                   %harbor porpoises swim between 0.5 - 4.2 m/s
t = 5;                   %seconds
s = v*t;                 %metres
z1 = [randi([-10 10],1,5); randi([-10 10],1,5)];
z1 = z1';
x1 = z1(1:5,1);     %this shows the first 5 numbers in column 1
y1 = z1(1:5,2);     %this shows the first 5 numbers in column 2
d = sqrt((x1-x0).^2+(y1-y0).^2);          %Pythagoras Theorem for distance between the 2 (Source and Reciever) points
m = (y1-y0)./(x1-x0);                     %Gradient between the points
r1 = d;
z2 = [x1,y1] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];    %New coordinates for new positions 5s later at a speed of 1.5m/s
x2 = z2(1:5,1);
y2 = z2(1:5,2);
r2 = d + s;   
z3 = [x2,y2] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];
x3 = z3(1:5,1);
y3 = z3(1:5,2);
r3 = d + 2*s; 
z4 = [x3,y3] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];  
x4 = z4(1:5,1);
y4 = z4(1:5,2);
r4 = d + 3*s;   
z5 = [x4,y4] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m]; 
x5 = z5(1:5,1);
y5 = z5(1:5,2);
r5 = d + 4*s;   
X1 = [x1 x2 x3 x4 x5];
Y1 = [y1 y2 y3 y4 y5];
X1 = X1';
Y1 = Y1';
figure
hold on;
plot(X1,Y1, '-*')
title('Flea Response')
xlabel('distance (m)')
ylabel('distance (m)')
2 Commenti
  Jon
      
 il 7 Lug 2022
				It is difficult from your description to understand what you are exactly trying to achieve. From what I can understand, I think that it is likely that your general approach needs to be improved, rather than finding a workaround by "mirroring" negative values. 
Please provide a simple explanation of what it is you are trying to model, and a mathematical description of the flee response that you are trying to model. 
One other clarification, I think you mean flee response, not flea response. A flea is a tiny jumping insect that bites cats and dogs, probably not what you are trying to model. 
Risposta accettata
  Kevin Holly
    
 il 7 Lug 2022
        x0 = 0;
y0 = 0;
Sr = [x0 y0];            %Source coordinates
SL = 220;                %Source Level dB re 1uPa @ 1m (made up  need to find example)
a = 0.25;                %Attenuation (made up need to find example)
IL = 180;                %Impact Level (made up need to find example)
v = 2;                   %harbor porpoises swim between 0.5 - 4.2 m/s
t = 5;                   %seconds
s = v*t;                 %metres
z1 = [randi([-10 10],1,5); randi([-10 10],1,5)];
z1 = z1';
x1 = z1(1:5,1);     %this shows the first 5 numbers in column 1
y1 = z1(1:5,2);     %this shows the first 5 numbers in column 2
negative_values = x1<0;
x1(negative_values) = -1*x1(negative_values)
d = sqrt((x1-x0).^2+(y1-y0).^2);          %Pythagoras Theorem for distance between the 2 (Source and Reciever) points
m = (y1-y0)./(x1-x0);                     %Gradient between the points
r1 = d;
z2 = [x1,y1] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];    %New coordinates for new positions 5s later at a speed of 1.5m/s
x2 = z2(1:5,1);
y2 = z2(1:5,2);
r2 = d + s;   
z3 = [x2,y2] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];
x3 = z3(1:5,1);
y3 = z3(1:5,2);
r3 = d + 2*s; 
z4 = [x3,y3] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];  
x4 = z4(1:5,1);
y4 = z4(1:5,2);
r4 = d + 3*s;   
z5 = [x4,y4] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m]; 
x5 = z5(1:5,1);
y5 = z5(1:5,2);
r5 = d + 4*s;   
X1 = [x1 x2 x3 x4 x5];
Y1 = [y1 y2 y3 y4 y5];
X1 = X1';
Y1 = Y1';
figure
hold on;
plot(X1,Y1, '-*')
title('Flea Response')
xlabel('distance (m)')
ylabel('distance (m)')
Mirroring entire line if x1 is negative:
X1(:,negative_values) = -1*X1(:,negative_values);
figure
hold on;
plot(X1,Y1, '-*')
title('Flea Response')
xlabel('distance (m)')
ylabel('distance (m)')
4 Commenti
  Kevin Holly
    
 il 7 Lug 2022
				x0 = 0;
y0 = 0;
Sr = [x0 y0];            %Source coordinates
SL = 220;                %Source Level dB re 1uPa @ 1m (made up  need to find example)
a = 0.25;                %Attenuation (made up need to find example)
IL = 180;                %Impact Level (made up need to find example)
v = 2;                   %harbor porpoises swim between 0.5 - 4.2 m/s
t = 5;                   %seconds
s = v*t;                 %metres
z1 = [randi([-10 10],1,5); randi([-10 10],1,5)];
z1 = z1';
x1 = z1(1:5,1);     %this shows the first 5 numbers in column 1
y1 = z1(1:5,2);     %this shows the first 5 numbers in column 2
negative_values = x1<0;
x1(negative_values) = -1*x1(negative_values);
d = sqrt((x1-x0).^2+(y1-y0).^2);          %Pythagoras Theorem for distance between the 2 (Source and Reciever) points
m = (y1-y0)./(x1-x0);                     %Gradient between the points
r1 = d;
z2 = [x1,y1] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];    %New coordinates for new positions 5s later at a speed of 1.5m/s
x2 = z2(1:5,1);
y2 = z2(1:5,2);
r2 = d + s;   
z3 = [x2,y2] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];
x3 = z3(1:5,1);
y3 = z3(1:5,2);
r3 = d + 2*s; 
z4 = [x3,y3] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m];  
x4 = z4(1:5,1);
y4 = z4(1:5,2);
r4 = d + 3*s;   
z5 = [x4,y4] + diag(s./sqrt(1+m.^2))*[ones(size(x1)),m]; 
x5 = z5(1:5,1);
y5 = z5(1:5,2);
r5 = d + 4*s;  
X1 = [x1 x2 x3 x4 x5];
Y1 = [y1 y2 y3 y4 y5];
X1 = X1';
Y1 = Y1';
figure
hold on;
plot(X1,Y1, '-*')
title('Flea Response')
xlabel('distance (m)')
ylabel('distance (m)')
Mirroring entire line if x1 is negative:
X1(:,negative_values) = -1*X1(:,negative_values);
figure
hold on;
plot(X1,Y1, '-*')
title('Flea Response')
xlabel('distance (m)')
ylabel('distance (m)')
Change Axes location to origin:
ax = gca;
ax.XAxisLocation = 'origin';
ax.YAxisLocation = 'origin';
Più risposte (0)
Vedere anche
Categorie
				Scopri di più su Get Started with Signal Processing Toolbox in Help Center e File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!










