声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 877|回复: 5

[编程技巧] 请高手指点(关于连续变量的表达式)

[复制链接]
发表于 2008-7-18 17:41 | 显示全部楼层 |阅读模式

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

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

x
以下是程序的一部分:
function  yangzh=model
t=0.25;
......
......
for i=1:4
    p(i)=16*pi/w(i);
    y(i)=-f0(i).*p(i).*sin(w(i).*t)/k0(i,i)/(1-p(i).^2)+f0(i).*sin(16*pi.*t)/k0(i,i)/(1-p(i).^2);
end
disp(y);
我的问题是我不想t 赋初值,我想输出y 是关于t 的函数,我试了几种方法都不可以,请高手指点一下。
不甚感激!!!

[ 本帖最后由 sigma665 于 2008-7-21 20:54 编辑 ]
回复
分享到:

使用道具 举报

发表于 2008-7-18 20:23 | 显示全部楼层
在disp()函数中,变量是自符串,而不是数值。可以改为
disp(num2str(y));

评分

1

查看全部评分

 楼主| 发表于 2008-7-18 20:33 | 显示全部楼层
问题是y 也只是中间的一环,我所要的结果是另外一个矩阵u 也y 的乘积
发表于 2008-7-19 09:49 | 显示全部楼层

回复 3楼 的帖子

请试着清楚一点儿描述你的问题,还有就是请使用可以准确反映帖子内容的标题。
 楼主| 发表于 2008-7-19 11:38 | 显示全部楼层
t 相当于一个变量,我要得到的结果是关于t 的表达式,像程序中的y 矩阵,是一个其元素是关于t 的表达式。
我最后的结果x 是y 与另一个矩阵相乘得到的。
如果我最开始就定义t 等于一个具体数值的话,那就可以求出y 和x ,但我想要的是连续解,也就是解是关于t 的表达式。
发表于 2008-7-20 10:40 | 显示全部楼层
自己修改了一下,看是否是你的需要
function  yangzh=myfun1
% t=0.25;
syms t
w=ones(1,4);
f0=w;
k0=2*ones(4);
for i=1:4
    p(i)=16*pi/w(i);
    yangzh(i)=-f0(i).*p(i).*sin(w(i).*t)/k0(i,i)/(1-p(i).^2)+f0(i).*sin(16*pi.*t)/k0(i,i)/(1-p(i).^2);
end
disp(yangzh);
运行结果:
>> y=myfun1
[ 8796093022208/2776947157312239*pi*sin(t)-549755813888/2776947157312239*sin(16*pi*t), 8796093022208/2776947157312239*pi*sin(t)-549755813888/2776947157312239*sin(16*pi*t), 8796093022208/2776947157312239*pi*sin(t)-549755813888/2776947157312239*sin(16*pi*t), 8796093022208/2776947157312239*pi*sin(t)-549755813888/2776947157312239*sin(16*pi*t)]


y =

[ 8796093022208/2776947157312239*pi*sin(t)-549755813888/2776947157312239*sin(16*pi*t), 8796093022208/2776947157312239*pi*sin(t)-549755813888/2776947157312239*sin(16*pi*t), 8796093022208/2776947157312239*pi*sin(t)-549755813888/2776947157312239*sin(16*pi*t), 8796093022208/2776947157312239*pi*sin(t)-549755813888/2776947157312239*sin(16*pi*t)]


>> vpa(y,3)

ans =

[ .995e-2*sin(t)-.198e-3*sin(50.2*t), .995e-2*sin(t)-.198e-3*sin(50.2*t), .995e-2*sin(t)-.198e-3*sin(50.2*t), .995e-2*sin(t)-.198e-3*sin(50.2*t)]


>> subs(y(1),0.25)

ans =

    0.0025

评分

1

查看全部评分

您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-5-18 06:32 , Processed in 0.073779 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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