I have the 2-D PIV data like below and I am not able to get streamlines in matlab:
ix,iy,iz = image coordinate X,Y,Z [pixel]
dx = displacement component X [pixel] * (image resoltion) = mm
dy = displacement component Y [pixel] * (image resoltion) = mm
--------------------------------------------------
So I have dx and dy in mm. Also I can calculate: du = dx/dt , dv = dy/dt as the velocities in x and y directions.
I want to get the streamline usnig streamline/streamslice functions in matlab but I do not know how to define startx and starty?? Should I use meshgrid function for that? and shoul I use ix,iy(image coordinates) OR dx,dy to define startx and starty points?
Moreover do I need to define meshgrid for du,dv to fill velocities for every point??
Any help would be appreciated.
A = xlsread(......myfile.xls); % myfile.xls contains all data.
dx = A(1:end,4); % size(dx) = 8400*1
dy = A(1:end,5); % size(dy) = 8400*1
du = A(1:end,6); % size(du) = 8400*1
dv = A(1:end,7); % size(dv) = 8400*1
[startx,starty] = ?????
[X,Y] = meshgrid(dx,dy);
streamline(X,Y,du,dy,startx,starty);

1 comentario

Ham Man
Ham Man el 16 de Jul. de 2021
The streamline/streamslice gave me an error stating that U,V should be 3D data. How can I make those in 3D?

Iniciar sesión para comentar.

 Respuesta aceptada

KSSV
KSSV el 14 de Jul. de 2021
Editada: KSSV el 14 de Jul. de 2021

2 votos

Try:
skip = 2 ; % can be changed
startx = X(1:skip:end,1:skip:end) ;
starty = Y(1:skip:end,1:skip:end) ;
streamline(X,Y,du,dy,startx,starty);
Also have a look on streamslice. This would be a better function to use.

11 comentarios

Ham Man
Ham Man el 14 de Jul. de 2021
Editada: Ham Man el 14 de Jul. de 2021
Thanks for replying KSSV.
It gave me an error for the size of du and dv. Shouldn't be du and dv in the same size of X,Y? X and Y are now a grid but du,dv are both have one column.
size(X) = size(Y) = 8400*8400
size(du) = size(dv) = 8400*1
Ham Man
Ham Man el 14 de Jul. de 2021
Is this true for input argument for "streamline" function:
streamline(x displacement,y displacement,velocity in x direction,velocity in y direction)??
KSSV
KSSV el 15 de Jul. de 2021
(x,y) are locations at which you have velocitties (u,v). If you don't have locations you can plot w.r.t indices.
Ham Man
Ham Man el 16 de Jul. de 2021
The streamline/streamslice gave me an error stating that U,V should be 3D data. How can I make those in 3D?
KSSV
KSSV el 17 de Jul. de 2021
Share your data.
Ham Man
Ham Man el 17 de Jul. de 2021
Editada: Ham Man el 17 de Jul. de 2021
Here is my data. Thanks for your attempt.
ERROR:
Error using streamslice (line 142)
Volume data arguments must be 3-D arrays.
Ham Man
Ham Man el 18 de Jul. de 2021
Editada: Ham Man el 18 de Jul. de 2021
I wonder how to make du,dv in the same size of X,Y? should I use reshape or repmat to make du and dv in the same size of X,Y( made by meshgrid(dx,dy) )?
otherwise the streamline are not achievable.
T = readtable('https://in.mathworks.com/matlabcentral/answers/uploaded_files/687023/ane1_data.xlsx.xlsx') ;
T(8447,:) =[] ; % remove NaNs
x = T.(1) ; y = T.(2) ;
dx = T.(4) ; dy = T.(5) ;
[X,Y] = meshgrid(linspace(min(x),max(x)),linspace(min(y),max(y))) ;
dX = griddata(x,y,dx,X,Y) ;
dY = griddata(x,y,dy,X,Y) ;
streamslice(X,Y,dX,dY)
Ham Man
Ham Man el 19 de Jul. de 2021
Awesome, Many thank to you. This is what I was looking for. Much appreciate.
I tried "streamline" function but no luck. How does it work with these data?
T = readtable('https://in.mathworks.com/matlabcentral/answers/uploaded_files/687023/ane1_data.xlsx.xlsx') ;
T(8447,:) =[] ; % remove NaNs
x = T.(1) ; y = T.(2) ;
dx = T.(4) ; dy = T.(5) ;
[X,Y] = meshgrid(linspace(min(x),max(x)),linspace(min(y),max(y))) ;
dX = griddata(x,y,dx,X,Y) ;
dY = griddata(x,y,dy,X,Y) ;
streamline(X,Y,dX,dY,X,Y)
And thanks is accepting/ voting the answer.
Ham Man
Ham Man el 19 de Jul. de 2021
Editada: Ham Man el 19 de Jul. de 2021
Perfect. Thanks again KSSV.

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Vector Fields en Centro de ayuda y File Exchange.

Preguntada:

el 14 de Jul. de 2021

Editada:

el 19 de Jul. de 2021

Community Treasure Hunt

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

Start Hunting!

Translated by