声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1072|回复: 4

[综合讨论] 求助好心人:老版本matlab的Runge-Kutte rk45怎么转为ode45

[复制链接]
发表于 2008-12-9 15:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
clear;
clc;
A_1 = 0.11*pi/180;
A_2 = 0.08*pi/180;
t0 = 0;
tfinal = 20;
tspan = [t0, tfinal];
x0 = [0,0]';
[t,x] = rk45('sfile45', tspan , x0); %老版本rk45怎么转换为ode45格式呢??  
x_err = (A_1*sin(2*x(:,1))+A_2*sin(4*x(:,1)))*180/pi;
x_out = (x(:,1)/N)+(x_err*pi/180);
plot(t,x_err,'r');
hold on;
plot(t,x_out,'--b');
grid;


% function sfile45          % sfile45.m
function[sys,x0] = sfile45(t,x,u,flag)   %关键是怎么函数怎么改写呢,谢谢好心人!
N = 50;
u_d = pi*67.5/180;
A_1 = 0.11*pi/180;
A_2 = 0.08*pi/180;
B_in = 1.83e-4;  
B_L = 1.0e-3;   
J_in = 4.5e-3;  
J_L = 5.0e-2;   
K_P = 1.17;      
K_D = 0.3225;   
u = u_d;
if(flag == 0)   
    sys = [2,0,2,1,0,0];
    x0 = [0,0];
elseif(abs(flag) == 1)
    sys = zeros(1,2);
    sys(1) = x(2);
    sys(2) = (-(B_in+B_L*(2*A_1*cos(2*x(1))+4*A_2*cos(4*x(1))+...
        1/N)^2)*x(2)+(J_L*4*(A_1*sin(2*x(1)+4*A_2*sin(4*x(1))))*...
        (2*A_1*cos(2*x(1))+4*A_2*cos(4*x(1))+1/N)*(x(2)^2))-...
        K_D*(2*A_1*cos(2*x(1))+4*A_2*cos(4*x(1))+(x(2)/N))-K_P*...
        (A_1*sin(2*x(1))+A_2*sin(4*x(1))+(x(1)/N))+...
        K_P*u)/(J_in+J_L*(2*A_1*cos(2*x(1))+4*A_2*cos(4*x(1))+1/N));
elseif(abs(flag) == 3)
    sys = zeros(1,2);
    sys(1) = x(1);
    sys(2) = x(2);
else
    sys = [];
end;
回复
分享到:

使用道具 举报

 楼主| 发表于 2008-12-9 15:29 | 显示全部楼层
给自己顶一下。。。支持一下自己:lol :lol
发表于 2008-12-9 16:02 | 显示全部楼层

回复 楼主 youbindi 的帖子

1. 貌似新版本里不用flag了。
2. u是附加参数吗?看rk45的调用好像没有传递u啊,如果不需要就去掉u
3. [t,x] = rk45('sfile45', tspan , x0); 可以改成[t,x] = rk45(@sfile45, tspan , x0);
 楼主| 发表于 2008-12-9 17:02 | 显示全部楼层
u是控制参数,flag是判断微分还是积分还是雅可比计算。。。但是就不知道怎么改成符合ode45调用的函数!!!
发表于 2008-12-9 18:40 | 显示全部楼层

回复 地板 youbindi 的帖子


  1. [t,x] = rk45(@sfile45, tspan , x0,,u);
  2. ...
  3. function x0= sfile45(t,x,u)
复制代码
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-11-26 10:49 , Processed in 0.063942 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表