声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 888|回复: 1

[编程技巧] 如何实现MATLAB中的循环运算

[复制链接]
发表于 2007-4-10 11:47 | 显示全部楼层 |阅读模式

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

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

x
我碰到一个比较棘手的问题,希望大家帮忙解答一下.
自己编写的程序,运行起来就有问题;还有,关于函数调用上不太明白,希望大家指点下.

自己编写的程序如下:
%
function f=yo_11(a,b)
l=0.5;m=0.1;mc=1;
f=(9.8*sin(a)-m*l*b^2*cos(a)*sin(a)/(mc+m))/l/(4/3-m*cos(a)^2/(mc+m));
%
function g=yo_12(a)
l=0.5;m=0.1;mc=1;
g=cos(a)/(mc+m)/l/(4/3-m*cos(a)^2/(mc+m));
%
function [A;A1]=yo_02()
h=0.01;A[1 1]=0.3491;A1[1 1]=0;
for(i=1:1000)
   x=A[1 i]+A1[1 i]*h;
   u=-25*A[1 i]-A1[1 i]+0.2*cos((2*pi/50)*i);
   f=yo_11(A[1,i],A1[1,1]);
   g=yo_12(A[1,i]);
   y=A1[1 i]+(f+g*u)*h;
   A=[A [x]];
   A1=[A1 [y]];
end
%
function C=yo_01()
k=0.95;D[1,i]=[A[1,i];A1[1,i];u];
F=[1,0,0;0,1,0;0,0,1];
C=[0,0;0,0;0,0];
for(i=1:1000)
   e=[A[1,i];A1[1,i]]-C`*D[1,i]`;
   F=1/k*(F-F*D[1,i]`*D[1,i]*F/(k+D[1,i]*F*D[1,i]`));
   C=C+F*D[1,i]`*e;
end
%
怎么才能使我编写的函数能运行起来,然后得到矩阵C.
麻烦大家了
回复
分享到:

使用道具 举报

发表于 2007-4-10 15:45 | 显示全部楼层
原帖由 yoyoo 于 2007-4-10 11:47 发表
我碰到一个比较棘手的问题,希望大家帮忙解答一下.
自己编写的程序,运行起来就有问题;还有,关于函数调用上不太明白,希望大家指点下.

自己编写的程序如下:
%
function f=yo_11(a,b)
l=0.5;m=0.1;mc=1;
f= ...



请阅读matlab的基础书,看看矩阵的定义和调用方式等
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-11-19 10:28 , Processed in 0.392336 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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