Borrar filtros
Borrar filtros

"Vector must be strictly increasing or strictly decreasing with no repeated values" error

21 visualizaciones (últimos 30 días)
Hello,
I'm trying to use contour to represent some data, but I get this error.
Thank you in advance.
R_a=3;
N=100;
phi=linspace(0,2*pi,N);
rho= linspace(0,R_a,N);
r = randi([50 70],1,length(rho));
A=ones(length(rho)).*r;
[x_c,y_c] = pol2cart(phi,rho);
[Ro_tag, Phi_tag]=meshgrid(rho,phi);
contour(x_c,y_c,A);
  4 comentarios
Adam Danz
Adam Danz el 31 de Ag. de 2020
Editada: Adam Danz el 31 de Ag. de 2020
Shot in the dark,
R_a=3;
N=100;
phi=linspace(0,2*pi,N);
rho= linspace(0,R_a,N);
r = randi([50 70],1,length(rho));
A=ones(length(rho)).*r;
[Ro_tag, Phi_tag]=meshgrid(rho,phi);
[x_c,y_c] = pol2cart(Ro_tag,Phi_tag);
contour(x_c,y_c,A);
axis equal
Michael Elman
Michael Elman el 31 de Ag. de 2020
Looks a little bit weird to me, I will try the link you posted before.

Iniciar sesión para comentar.

Respuesta aceptada

Matt J
Matt J el 31 de Ag. de 2020
Editada: Matt J el 31 de Ag. de 2020
Your meshgrid must be Cartesian:
R_a=3;
N=100;
[X,Y]=meshgrid( linspace(-R_a,+R_a, N) );
[Phi,Rho]=cart2pol(X,Y);
A= ... computaton based on Phi and Rho ...
contour(X,Y,A);
  3 comentarios
Matt J
Matt J el 31 de Ag. de 2020
Editada: Matt J el 31 de Ag. de 2020
Very well, then I modify my answer to,
R_a=3;
N=100;
[X,Y]=meshgrid( linspace(-R_a,+R_a, N) );
A= ... computaton based on X and Y ...
contour(X,Y,A);
The point is, A needs to be sampled on a normal Cartesian meshgrid for the purposes of doing the contour plot. You cannot, as a starting point, set up your sample locations in polar coordinates because they will not remain monotonic when transformed by pol2cart().
Michael Elman
Michael Elman el 1 de Sept. de 2020
Editada: Michael Elman el 1 de Sept. de 2020
contour(X,Y,A);
I think, this will do the trick, thank you.

Iniciar sesión para comentar.

Más respuestas (0)

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by