How to plot the opposite direction field
5 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
EA
am 7 Dez. 2020
Bearbeitet: Ameer Hamza
am 7 Dez. 2020
I have this code written for the flow field. But I want the opposite to happen, the image below should be inside out. The longest direction lines should be on the inside and the outside should have the smallest direction lines. It should be inside out, if that makes sense
%Define parameters for the velocity profile
w=2*pi; %rad/s
R=15; %cm
%Create a meshgrid of cylindrical coordinates
[r,theta]=meshgrid(R:R/10:0,2*pi:pi/12:0);
%Define the Cartesian coordinates
x=r.*cos(theta);
y=r.*sin(theta);
%Calculate the linear velocity components in cartesian coordinates
u=-w.*r.*sin(theta);
v=w.*r.*cos(theta);
%Create a 2d vector plot of the velocity
quiver(x,y,u,v);
daspect([1 1 1]);
xlabel('x, cm');
ylabel('y, cm');
title('Title')
%Define the axis ranges
axis([-R R -R R]);

0 Kommentare
Akzeptierte Antwort
Ameer Hamza
am 7 Dez. 2020
Try this
quiver(x, y, 1./u, 1./v);
2 Kommentare
Ameer Hamza
am 7 Dez. 2020
Bearbeitet: Ameer Hamza
am 7 Dez. 2020
The suggestion about meshgrid was given by VBBV. I only suggested to modify quiver() line. Anyway, try the following code
%Define parameters for the velocity profile
w=2*pi; %rad/s
R=15; %cm
%Create a meshgrid of cylindrical coordinates
[r,theta]=meshgrid(R/10:R/10:R,0:pi/10:2*pi);
%Define the Cartesian coordinates
x=r.*cos(theta);
y=r.*sin(theta);
%Calculate the linear velocity components in cartesian coordinates
u=-w.*1./r.^(1/2).*sin(theta);
v=w.*1./r.^(1/2).*cos(theta);
%Create a 2d vector plot of the velocity
quiver(x,y,u,v);
daspect([1 1 1]);
xlabel('x, cm');
ylabel('y, cm');
title('Title')
%Define the axis ranges
axis([-R R -R R]);

Weitere Antworten (0)
Siehe auch
Kategorien
Mehr zu Vector Fields finden Sie in Help Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!