查看单个帖子
旧 2012-06-11, 12:49   #2
jimmymacong
初级会员
 
注册日期: 2012-02-13
帖子: 12
声望力: 14
jimmymacong 正向着好的方向发展
微笑 回复: 我代码里循环错了,帮忙改下,急用

你的复制的代码有点小问题,可能又一个end忘记复制了,
然后主要问题是g赋值出现问题,你用一个1*4的矩阵赋给g,这样只是反复刷新了g的第一行,没有实质的变化。我只改了一行代码,你看看合不合意!!

x=rand(1,10);
y=rand(1,10);
z=cos(0.5.*x).*sin(y);
xi=linspace(0,1,30);
yi=linspace(0,1,30);
[X,Y]=meshgrid(xi,yi);
Z=griddata(x,y,z,X,Y,'nearest');
mesh(X,Y,Z);
a=(3^0.5)/3;b=(3^0.5)/3;c=(3^0.5)/3;
xa=1;ya=2;za=3;
v=sqrt(b^2+c^2);u=sqrt(a^2+b^2+c^2);
d=pi/4;
T=[1 0 0 0;0 1 0 0;0 0 1 0;-xa -ya -za 1];
Rx=[1 0 0 0;0 c/v b/v 0;0 -b/v c/v 0;0 0 0 1];
Ry=[v/u 0 -a/u 0;0 1 1 0;a/u 0 v/u 0;0 0 0 1];
Rz=[cos(d) sin(d) 0 0;-sin(d) cos(d) 0 0;0 0 1 0;0 0 1 1];
Ry1=[v/u 0 a/u 0;0 1 1 0;-a/u 0 v/u 0;0 0 0 1];
Rx1=[1 0 0 0;0 c/v -b/v 0;0 b/v c/v 0;0 0 0 1];
T1=[1 0 0 0;0 1 0 0;0 0 1 0;xa ya za 1];
g=zeros(1000,4);
for k=1:10
for m=1:10
for n=1:10
g(100*(k-1)+10*(m-1)+n ,: )=[x(k) y(m) z(n) 1]*T*Rx*Ry*Rz*Ry1*Rx1*T1;
end
end
end

此帖于 2012-06-11 12:51 被 jimmymacong 编辑。 原因: 打错了
jimmymacong 当前离线   回复时引用此帖