How to plot matlab stream plot?

77 views (last 30 days)
I have a 2D domain which has diffrent width(X) and length(Y) as attached photo. Say the height Y=0.05 and width X=0.02;
I have each particle position array in X,Y and I know the corresponding velocity of the particle in U and V.
If I create meashgrid say
[X1,Y1] = meshgrid(0:0.005:0.02,0:0.005:0.05);
Then how I create the dimension of U and V equal to the dimension of X1 and Y1? So that I can plot
streamline(X1,Y1,U,V)
Please help,Thanks.

Accepted Answer

Walter Roberson
Walter Roberson on 12 Jul 2021
U1 = interp2(X, Y, U, X1, Y1);
V1 = interp2(X, Y, V, X1, Y1);
streamline(X1, Y1, U1, V1);
  13 Comments
Walter Roberson
Walter Roberson on 5 Aug 2021
Edited: Walter Roberson on 5 Aug 2021
You can do a bit better by calling stream2() yourself, see the first example at
The idea is that you would filter down your coordinates. For example break up into two blocks, one the left area and the other the bottom area, so that you avoid doing all that interpolation for the large part of your plot that is empty.
It might take a bit of work to figure out where the useful boundaries are given only the scattered data. One approach would be a crude 2d histogram to find out which parts are occupied.
By the way, I just opened a case recommending specific performance improvements to streamline(). I doubt we will see them before 2022 however.
Rubel Ahmed
Rubel Ahmed on 6 Aug 2021
I can plot the quiver plot on the lower bath region where the geometry filled with fluids by using the griddata function as attached figures. When I am again trying to plot the streamline by using the same interpolated data(data that used to plot the quiver plot), still no improvment. Do you khowwhats wrong now? Since my program can avoided the empty space of the L shape. Also, is it possible to add lines on the quiver plot?
My code is
AXX= ARPP(:,1); % Prticles x position with array size n by 1
AYY= ARPP(:,2); % Prticles y position with array size n by 1
UXX= gather(TRPV(:,1)); % Prticles x velocity component with array size n by 1
UYY= gather(TRPV(:,2)); % Prticles y velocity component with array size n by 1
for i = 1:40000
for j = 1
if AYY(i,j)< 0.01
X(i,j)=AXX(i,j);
Y(i,j)=AYY(i,j);
XU(i,j)=UXX(i,j);
YU(i,j)=UYY(i,j);
else
X(i,j)=0;
Y(i,j)=0;
XU(i,j)=0;
YU(i,j)=0;
end
end
end
X = X(X~=0);
Y = Y(Y~=0);
XU = XU(XU~=0);
YU = YU(YU~=0);
[X1,Y1] = meshgrid(-6*PDis:0.0006:0.01,-6*PDis:0.0006:0.01); % Total geometry is divided into gridpoints
U1 = griddata(X,Y,XU, X1, Y1);
V1 = griddata(X,Y,YU, X1, Y1);
figure(10)
% streamline(X1, Y1, U1, V1)
quiver(X1, Y1, U1, V1)
pbaspect([1 1.2 1])

Sign in to comment.

More Answers (0)

Categories

Find more on Vector Fields in Help Center and File Exchange

Products


Release

R2019b

Community Treasure Hunt

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

Start Hunting!