Plotting 3D graph in polar coordinates

16 次查看(过去 30 天)
I'm trying to plot a 3D graph of a function in polar coordinates. The function takes a different form at different values of r. a, b and multiplier are constants I've defined earlier in the code (a=11, b=60, multiplier =-14)
r=0:1:60;
theta=0:pi/30:2*pi;
for i=1:61
r(i)=i-1;
if (r(i)<a)
sigmar(i)=-p_i;
else
sigmar(i)=((1-((b^2)/(r(i)^2)))*multiplier);
end
end
I've been trying to plot the 3D curve using
[x,y]=pol2cart(theta, r);
surf(x,y,sigmar)
but when I run the code, it keeps saying 'Data dimensions must agree.'
  2 个评论
madhan ravi
madhan ravi 2018-11-11
编辑:madhan ravi 2018-11-11
a,p_i,multiplier? provide the datas
Rachel Attwood
Rachel Attwood 2018-11-11
constants that i've defined earlier in the code. have edited the question body

请先登录,再进行评论。

采纳的回答

madhan ravi
madhan ravi 2018-11-11
编辑:madhan ravi 2018-11-11
clear all
r=0:1:60;
theta=0:pi/30:2*pi;
for i=1:61
r(i)=i-1;
if (r(i)<3)
sigmar(i)=-6;
else
sigmar(i)=((1-((7^2)/(r(i)^2)))*-14); %multiplier is a predefined constant
end
end
[x,y]=pol2cart(theta, r);
[X,Y]=meshgrid(x,y);
sigmar=repmat(sigmar,61,1);
surf(X,Y,sigmar)
  5 个评论
Rachel Attwood
Rachel Attwood 2018-11-11
Ah great, thanks. I've got a plot now. It's not quite how I expected it to look, so I'll keep playing around with it.

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Surface and Mesh Plots 的更多信息

产品


版本

R2016b

Community Treasure Hunt

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

Start Hunting!

Translated by