请教matlab变化圆心画圆具体函数如下:R0=100;r=27.5;L1=180;L2=105;du=180/pi;wt3=0:1:75;Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;Y=Y0+Y1;R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));%以上为公

来源:学生作业帮助网 编辑:作业帮 时间:2024/05/04 06:30:28
请教matlab变化圆心画圆具体函数如下:R0=100;r=27.5;L1=180;L2=105;du=180/pi;wt3=0:1:75;Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;Y=Y0+Y1;R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));%以上为公

请教matlab变化圆心画圆具体函数如下:R0=100;r=27.5;L1=180;L2=105;du=180/pi;wt3=0:1:75;Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;Y=Y0+Y1;R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));%以上为公
请教matlab变化圆心画圆
具体函数如下:
R0=100;
r=27.5;
L1=180;
L2=105;
du=180/pi;
wt3=0:1:75;
Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;
Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;
Y=Y0+Y1;
R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));
%以上为公式
x=zeros(1,360);
y=zeros(1,360);
m=zeros(1,360);
n=zeros(1,360);
%以上为缩小范围
for i=0:1:75 %画曲线
x(i+1)=R(i+1)*cos(i*pi/180.0);
y(i+1)=R(i+1)*sin(i*pi/180.0);
for t=0:1:2*pi %画圆
m=x(i+1)+r*cos(t);
n=y(i+1)+r*sin(t);
plot(m,n,'r')
end
end
plot(x,y,'r')
axis equal
hold on
程序运行后是个曲线,我想显示出曲线上每隔i=1,以(x,y)为圆心,r为半径画圆,这样会有76个圆,为什么显示不出来呢,我哪里出错了?

请教matlab变化圆心画圆具体函数如下:R0=100;r=27.5;L1=180;L2=105;du=180/pi;wt3=0:1:75;Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;Y=Y0+Y1;R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));%以上为公
第一种和第二种是动态的,第三种是静态的
1、3D版
clear all;
clc;
R0=100;
r=27.5;
L1=180;
L2=105;
du=180/pi;
wt3=0:1:75;
Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;
Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;
Y=Y0+Y1;
R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));
%以上为公式
%hold on;% 加上hold on使得所有图形都在一张图上,按照matlab顺序执行的特点,hold on不能放在多重绘图语句的最后面,一般放在第一个绘图语句的前面或者第一第二个语句的中间都行,如:a注释所示
%axis equal% 是一种对当前图形句柄的修正命令,放在任意位置都行,注意只对当前图形句柄有效,对于动态图,其用法跟hold on类似
x=zeros(1,76);% 删除m,n的预开辟内存空间的语句,因为他们的长度是由0:0.1:2*pi的长度决定
y=zeros(1,76);% x,y的长度由0:75决定,所以为76
%以上为缩小范围
for i=0:1:75 %画曲线
x(i+1)=R(i+1)*cos(i*pi/180.0);
y(i+1)=R(i+1)*sin(i*pi/180.0);
k=1;
for t=0:0.1:2*pi %画圆
m(k)=x(i+1)+r*cos(t);
n(k)=y(i+1)+r*sin(t);
k=k+1;
end
z=repmat(i,1,k-1);
plot3(m,n,z,'r');
axis([-20 220 -40 200 0 78]);
hold on
plot3(x(1:i+1),y(1:i+1),0:i,'b');
pause(0.1);
% 将绘图语句放在循环外
% hold on % a 如:把hold on语句放在此处也行
end
2、2D版
clear all;
clc;
R0=100;
r=27.5;
L1=180;
L2=105;
du=180/pi;
wt3=0:1:75;
Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;
Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;
Y=Y0+Y1;
R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));
%以上为公式
hold on;% 加上hold on使得所有图形都在一张图上,按照matlab顺序执行的特点,hold on不能放在多重绘图语句的最后面,一般放在第一个绘图语句的前面或者第一第二个语句的中间都行,如:a注释所示
axis equal% 是一种对当前图形句柄的修正命令,放在任意位置都行,注意只对当前图形句柄有效,对于动态图,其用法跟hold on类似
x=zeros(1,76);% 删除m,n的预开辟内存空间的语句,因为他们的长度是由0:0.1:2*pi的长度决定
y=zeros(1,76);% x,y的长度由0:75决定,所以为76
%以上为缩小范围
for i=0:1:75 %画曲线
x(i+1)=R(i+1)*cos(i*pi/180.0);
y(i+1)=R(i+1)*sin(i*pi/180.0);
k=1;
for t=0:0.1:2*pi %画圆
m(k)=x(i+1)+r*cos(t);
n(k)=y(i+1)+r*sin(t);
k=k+1;
end
plot(m,n,'r');
axis([-20 220 -40 200]);
hold on
plot(x(1:i+1),y(1:i+1),'b');
pause(0.1);
% 将绘图语句放在循环外
% hold on % a 如:把hold on语句放在此处也行
end
3、静态2D版
clear all;
clc;
R0=100;
r=27.5;
L1=180;
L2=105;
du=180/pi;
wt3=0:1:75;
Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;
Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;
Y=Y0+Y1;
R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));
%以上为公式
hold on;% 加上hold on使得所有图形都在一张图上,按照matlab顺序执行的特点,hold on不能放在多重绘图语句的最后面,一般放在第一个绘图语句的前面或者第一第二个语句的中间都行,如:a注释所示
axis equal% 是一种对当前图形句柄的修正命令,放在任意位置都行,注意只对当前图形句柄有效,对于动态图,其用法跟hold on类似
x=zeros(1,76);% 删除m,n的预开辟内存空间的语句,因为他们的长度是由0:0.1:2*pi的长度决定
y=zeros(1,76);% x,y的长度由0:75决定,所以为76
%以上为缩小范围
for i=0:1:75 %画曲线
x(i+1)=R(i+1)*cos(i*pi/180.0);
y(i+1)=R(i+1)*sin(i*pi/180.0);
k=1;
for t=0:0.1:2*pi %画圆
m(k)=x(i+1)+r*cos(t);
n(k)=y(i+1)+r*sin(t);
k=k+1;
end
plot(m,n,'r');
axis([-20 220 -40 200]);
hold on
plot(x(1:i+1),y(1:i+1),'b');
% 将绘图语句放在循环外
% hold on % a 如:把hold on语句放在此处也行
end

%试一下
R0=100;
r=27.5;
L1=180;
L2=105;
du=180/pi;
wt3=0:1:75;
Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;
Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;
Y=Y0+Y1;

全部展开

%试一下
R0=100;
r=27.5;
L1=180;
L2=105;
du=180/pi;
wt3=0:1:75;
Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;
Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;
Y=Y0+Y1;
R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));
%以上为公式
x=zeros(1,360);
y=zeros(1,360);
m=zeros(1,360);
n=zeros(1,360);
%以上为缩小范围
for i=0:1:75 %画曲线
x(i+1)=R(i+1)*cos(i*pi/180.0);
y(i+1)=R(i+1)*sin(i*pi/180.0);
%%%%%%%%%%%
%改变t间隔
for t=0:0.1:2*pi %画圆
m=x(i+1)+r*cos(t);
n=y(i+1)+r*sin(t);
%%%%%%%%%%%
%改变画图指令及hold on
plot(m,n,'-r')
hold on
end
end
%%%%%%%%%%%
%最后的零点不出现
plot(x(1:76),y(1:76),'r')
axis equal

收起

for i=0:1:75 %画曲线
x(i+1)=R(i+1)*cos(i*pi/180.0);
y(i+1)=R(i+1)*sin(i*pi/180.0);
for t=0:1:2*pi %画圆
m=x(i+1)+r*cos(t);
n=y(i+1)+r*sin(t);
plot(m,n,'r'...

全部展开

for i=0:1:75 %画曲线
x(i+1)=R(i+1)*cos(i*pi/180.0);
y(i+1)=R(i+1)*sin(i*pi/180.0);
for t=0:1:2*pi %画圆
m=x(i+1)+r*cos(t);
n=y(i+1)+r*sin(t);
plot(m,n,'r')
hold on
end
end
plot(x,y,'r')
axis equal
hold on
不知道是不是你hold on的问题

收起

请教matlab变化圆心画圆具体函数如下:R0=100;r=27.5;L1=180;L2=105;du=180/pi;wt3=0:1:75;Y0=(acos((L1^2+L2^2-(R0+r)^2)/(2*L1*L2)))*du;Y1=23.9123*(pi*wt3/75-0.5*sin(2*pi*wt3/75))/pi;Y=Y0+Y1;R=sqrt(L1^2+L2^2-2*L1*L2*cos(Y/du));%以上为公 请教MATLAB画函数图形希望附上程序+结果图, 请教matlab函数plot画点的问题 请教:怎么用matlab画函数项级数的图像? 请教matlab函数plot画点的问题 matlab 曲面拟合,已有三维数据已有三维数据,然后想先用插值函数插值,然后再拟合出来,我不知道具体怎么做,请教大家一下.呵呵,谢谢大家.数据如下:416.73237 -454.57213 -370.67631417.13137 -453.78312 -37 如何在MATLAB中画出类似如下的分段函数的图像,我想画出y随着时间t 的变化曲线,具体函数形如x=sin(t),y=0.5 ,x>=0.5; y=x,-0.5 matlab中如何以一个点为圆心画圆 matlab中如何以一个点为圆心画圆 求教如何使用MatLab来绘制如下的函数曲线方程图像不懂什么拟合. 求具体教导~ matlab:已知一幅图像某点的坐标,以此点为圆心,指定r为半径画圆,提取该区域图像,求具体方法. matlab 画函数问题,函数如下:f(x)=西格玛(n=0到正无穷)a^n×cos(b^n×派×X),其中a,b为已知常数,如何做?具体代码. 新手,请问matlab中lsqnonlin函数怎么使用?例如:想要拟合一个圆,怎样通过拟合函数lsqnonlin求出圆心? matlab中round函数具体用法 matlab 如何求圆的圆心坐标 请教matlab中sigma函数的详细意义 用matlab如何画随角度角度变化函数,而不是弧度? 请教高手一下matlab有关知识 >> axis([0 255 0 15000]); >> imhist(f); >> plot(imhist(f));imhist函数的纵坐标是这样,但plot函数中是这样,怎样才能使plot函数的纵坐标和imhist函数一样呢imhist如下plot如下