声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1024|回复: 3

[编程技巧] 这个小程序的错误在哪?

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

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

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

x
fid1=fopen('Hk1.dat','a+');
for z=0:0.1:k;
    f=z;
    g=inline('cos(f*sin(x))');
    [S,n]=quad(g,-pi,pi);
    %J0=1/(2*pi)*S;
    fprintf(fid1,'% f % f\n',f,S);
end
fclose(fid1)
出现的错误为:
??? Error using ==> inline.subsref
Not enough inputs to inline function.

Error in ==> quad at 62
y = f(x, varargin{:});

Error in ==> fhkl at 5
    [S,n]=quad(g,-pi,pi);
我不明白到底第五行到底出现了啥错误,请求指点!
谢谢了
回复
分享到:

使用道具 举报

发表于 2008-5-27 20:44 | 显示全部楼层
原帖由 jgchen1973 于 2008-5-27 19:28 发表
fid1=fopen('Hk1.dat','a+');
for z=0:0.1:k;
    f=z;
    g=inline('cos(f*sin(x))');
    [S,n]=quad(g,-pi,pi);
    %J0=1/(2*pi)*S;
    fprintf(fid1,'% f % f\n',f,S);
end
fclose(fid1)
出现的错误 ...

doc quad
个人觉得好像不可以用inline,可以试试下面的代码:
fid1=fopen('Hk1.dat','a+');
z=0:0.1:2;
for i=1:length(z)
    f=z(i);
    g=@(x)cos(f*sin(x));
    [S,n]=quad(g,-pi,pi);
    %J0=1/(2*pi)*S;
    fprintf(fid1,'% f % f\n',f,S);
end
fclose(fid1)
发表于 2008-5-27 20:51 | 显示全部楼层

回复 楼主 的帖子

带参数积分,搜索论坛精华贴
 楼主| 发表于 2008-5-27 23:05 | 显示全部楼层

谢谢2楼和3楼

我已经参考已有的帖子,做出来了!谢谢关心!
我看2楼的好象比我的还简单,再试试.
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

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

GMT+8, 2024-9-23 09:29 , Processed in 0.051019 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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