24小时热门版块排行榜    

查看: 3017  |  回复: 7

yangyu1002

新虫 (初入文坛)

[求助] 修改MATLAB语句,实现两个变量的循环 已有1人参与

clear all;clc;
global hx0 hy0 hz0         % 外加磁场参数
hz0=0; hy0=0;
i=0;
mz3=0;
mz4=0;

for hx0=0:0.01:5;
    y0=[0.11;0.01;pi-0.11;pi+0.01];
    t0=0:0.1:500;
    [t,y]=ode45('rhssys',t0,y0);
                        

     mx1=sin(y(:,1)).*cos(y(:,2));
     my1=sin(y(:,1)).*sin(y(:,2));
     mz1=cos(y(:,1));
     mx2=sin(y(:,3)).*cos(y(:,4));
     my2=sin(y(:,3)).*sin(y(:,4));
     mz2=cos(y(:,3));

     i=i+1;
     mz3(i)=cos(y(5000,1));
     mz4(i)=cos(y(5000,3));
  
   
end

hx0=0:0.01:5;
subplot(2,1,1);
plot(hx0,mz3,'LineWidth',2);
xlabel('h_x0','fontsize',20);ylabel('m_z1','fontsize',20);
title('eta=0.33','fontsize',20);
set(gca,'FontSize',20);

subplot(2,1,2);
plot(hx0,mz4,'LineWidth',2);
xlabel('h_x0','fontsize',20);ylabel('m_z2','fontsize',20);
set(gca,'FontSize',20);


此循环程序现在实现了hx0和t0的双循环吗?即每一个hx0,此程序算了t0从0到500所对应的mx,my,mz吗?如果没有,如何实现hx0和t0的双循环?最后怎样改变语句,可以读出所有t0对应的y0值,而不是只是最后一组y0.
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tuburfransth

金虫 (正式写手)

可以告诉你,循环实现了,但是你没有在每次循环中把需要的结果保存下来,所以下一次循环进行时,前一次循环的结果被清除了。

发自小木虫Android客户端
2楼2016-11-14 16:34:43
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yangyu1002

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by tuburfransth at 2016-11-14 16:34:43
可以告诉你,循环实现了,但是你没有在每次循环中把需要的结果保存下来,所以下一次循环进行时,前一次循环的结果被清除了。

那如何把每次循环后解出的y0保存在一个数组里

发自小木虫IOS客户端
3楼2016-11-14 16:37:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tuburfransth

金虫 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
yangyu1002: 金币+40, ★★★★★最佳答案 2016-11-14 20:35:00
引用回帖:
3楼: Originally posted by yangyu1002 at 2016-11-14 16:37:26
那如何把每次循环后解出的y0保存在一个数组里
...

在循环外面设置一个空数组,在循环里面每计算一次就储存一次。

发自小木虫Android客户端
4楼2016-11-14 16:39:04
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tuburfransth

金虫 (正式写手)

引用回帖:
4楼: Originally posted by tuburfransth at 2016-11-14 16:39:04
在循环外面设置一个空数组,在循环里面每计算一次就储存一次。
...

你的程序是不是有问题?因为每次循环里面y0都是一样的,没变过,应该不需要每个循环都把它储存起来吧。

发自小木虫Android客户端
5楼2016-11-14 16:41:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yangyu1002

新虫 (初入文坛)

引用回帖:
5楼: Originally posted by tuburfransth at 2016-11-14 16:41:18
你的程序是不是有问题?因为每次循环里面y0都是一样的,没变过,应该不需要每个循环都把它储存起来吧。
...

clear all;clc;
global hx0 hy0 hz0         % 外加磁场参数
hz0=0; hy0=0;
i=0;
mz3=0;
mz4=0;

y0=[0.11;0.01;pi-0.11;pi+0.01];
for hx0=0:0.01:5;
     t0=0:0.1:500;
     [t,y]=ode45('rhssys',t0,y0);
                        

     mx1=sin(y(:,1)).*cos(y(:,2));
     my1=sin(y(:,1)).*sin(y(:,2));
     mz1=cos(y(:,1));
     mx2=sin(y(:,3)).*cos(y(:,4));
     my2=sin(y(:,3)).*sin(y(:,4));
     mz2=cos(y(:,3));

     i=i+1;
     mz3(i)=cos(y(5000,1));
     mz4(i)=cos(y(5000,3));
     y0=[y(5000,1);y(5000,2);y(5000,3);y(5000,4)];
   
end
6楼2016-11-14 16:49:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yangyu1002

新虫 (初入文坛)

引用回帖:
5楼: Originally posted by tuburfransth at 2016-11-14 16:41:18
你的程序是不是有问题?因为每次循环里面y0都是一样的,没变过,应该不需要每个循环都把它储存起来吧。
...

clear all;clc;
global hx0 hy0 hz0         % 外加磁场参数
hz0=0; hy0=0;
i=0;
mz3=0;
mz4=0;

y0=[0.11;0.01;pi-0.11;pi+0.01];
for hx0=0:0.01:5;
     t0=0:0.1:500;
     [t,y]=ode45('rhssys',t0,y0);
                        

     mx1=sin(y(:,1)).*cos(y(:,2));
     my1=sin(y(:,1)).*sin(y(:,2));
     mz1=cos(y(:,1));
     mx2=sin(y(:,3)).*cos(y(:,4));
     my2=sin(y(:,3)).*sin(y(:,4));
     mz2=cos(y(:,3));

     i=i+1;
     mz3(i)=cos(y(5000,1));
     mz4(i)=cos(y(5000,3));
     y0=[y(5000,1);y(5000,2);y(5000,3);y(5000,4)];
   
end
这个程序每次y0为t0=5000时的值,请问如何保存每次循环计算出的y0.
7楼2016-11-14 16:51:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tuburfransth

金虫 (正式写手)

在循环外面添加i=0,Y=zeros(4,500),循环内部计算完后添加Y(:,i)=y0;

发自小木虫Android客户端
8楼2016-11-14 17:02:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 yangyu1002 的主题更新
信息提示
请填处理意见