matlab主函数如何调用子函数我编写了一个matlab子函数是关于龙格库塔计算的主函数内容为:format longi=145;t=i*0.001;x=zeros(2,1);x(1,1)=35;f=t*sin(x(1,1));x(2,1)=Runge_Kutta(x(1,1));子函数内容为:function x1=Rung
来源:学生作业帮助网 编辑:作业帮 时间:2024/07/14 23:31:40
![matlab主函数如何调用子函数我编写了一个matlab子函数是关于龙格库塔计算的主函数内容为:format longi=145;t=i*0.001;x=zeros(2,1);x(1,1)=35;f=t*sin(x(1,1));x(2,1)=Runge_Kutta(x(1,1));子函数内容为:function x1=Rung](/uploads/image/z/1157277-21-7.jpg?t=matlab%E4%B8%BB%E5%87%BD%E6%95%B0%E5%A6%82%E4%BD%95%E8%B0%83%E7%94%A8%E5%AD%90%E5%87%BD%E6%95%B0%E6%88%91%E7%BC%96%E5%86%99%E4%BA%86%E4%B8%80%E4%B8%AAmatlab%E5%AD%90%E5%87%BD%E6%95%B0%E6%98%AF%E5%85%B3%E4%BA%8E%E9%BE%99%E6%A0%BC%E5%BA%93%E5%A1%94%E8%AE%A1%E7%AE%97%E7%9A%84%E4%B8%BB%E5%87%BD%E6%95%B0%E5%86%85%E5%AE%B9%E4%B8%BA%EF%BC%9Aformat+longi%3D145%3Bt%3Di%2A0.001%3Bx%3Dzeros%282%2C1%29%3Bx%281%2C1%29%3D35%3Bf%3Dt%2Asin%28x%281%2C1%29%29%3Bx%282%2C1%29%3DRunge_Kutta%28x%281%2C1%29%29%3B%E5%AD%90%E5%87%BD%E6%95%B0%E5%86%85%E5%AE%B9%E4%B8%BA%EF%BC%9Afunction+x1%3DRung)
matlab主函数如何调用子函数我编写了一个matlab子函数是关于龙格库塔计算的主函数内容为:format longi=145;t=i*0.001;x=zeros(2,1);x(1,1)=35;f=t*sin(x(1,1));x(2,1)=Runge_Kutta(x(1,1));子函数内容为:function x1=Rung
matlab主函数如何调用子函数
我编写了一个matlab子函数是关于龙格库塔计算的
主函数内容为:
format long
i=145;
t=i*0.001;
x=zeros(2,1);
x(1,1)=35;
f=t*sin(x(1,1));
x(2,1)=Runge_Kutta(x(1,1));
子函数内容为:
function x1=Runge_Kutta(x)
%Runge-Kutta积分方法解算
T=0.01;
%设周期是0.01秒,具体的计算中再修改
f(x,t)=t*sin(x);
%先假设f(x,t)是一个这样的函数,具体函数在具体问题中再修改
x=x(1,1);
%x先假设一个值,到具体问题时再具体输入修改
K1=t*sin(x);
K2=(t+T/2)*sin(x+K1/2);
K3=(t+T/2)*sin(x+K2/2);
K4=(t+T)*sin(x+K3);
x1=x+(T/6)*(K1+2*K2+2*K3+K4);
%龙格库塔方法计算过程
在计算过程中提示出现的问题是Error in ==> diaoyong1 at 8
x(2,1)=Runge_Kutta(x(1,1));
请问在调用子程序时该怎么样修改这两个函数,
zcy_179的回答,我还有一个问题
就是这个f函数可不可以放在子程序里面,
在他的回答中放到了主程序中,如果可以该怎么设置,
matlab主函数如何调用子函数我编写了一个matlab子函数是关于龙格库塔计算的主函数内容为:format longi=145;t=i*0.001;x=zeros(2,1);x(1,1)=35;f=t*sin(x(1,1));x(2,1)=Runge_Kutta(x(1,1));子函数内容为:function x1=Rung
function main
format long
i=145;
t=i*0.001;
x=zeros(2,1);
x(1,1)=35;
f=t*sin(x(1,1));
x(2,1)=Runge_Kutta(t,x(1,1))
%子函数内容为:
function x1=Runge_Kutta(x)
%Runge-Kutta积分方法解算
T=0.01;
%设周期是0.01秒,具体的计算中再修改
%f(x,t)=t*sin(x); %这个语句肯定有问题,不起作用,所以注销掉
%先假设f(x,t)是一个这样的函数,具体函数在具体问题中再修改
x=x(1,1);
%x先假设一个值,到具体问题时再具体输入修改
K1=t*sin(x);
K2=(t+T/2)*sin(x+K1/2);
K3=(t+T/2)*sin(x+K2/2);
K4=(t+T)*sin(x+K3);
x1=x+(T/6)*(K1+2*K2+2*K3+K4);
%龙格库塔方法计算过程
以上计算的结果为
x =
35.000000000000000
34.999399730655441