24小时热门版块排行榜    

Znn3bq.jpeg
查看: 747  |  回复: 1

n01096

新虫 (正式写手)

[求助] 函数调用过程,参数传递出大问题了,求大神指点

本人编写了4阶龙格库塔迭代方程,刚开始全部写在一个m脚本文件里,运行都没问题。后面考虑到可读性与模块化,打算用函数模块化的形式来写。
模块程序写好后,首次运行与第二次运行的提示错误信息都不一样。
第一次是

<font color="#ff0000">??? Error using ==> horzcat
CAT arguments dimensions are not consistent.

Error in ==> sym.subs>@(x)[char(x),','] at 249
    s = cellfun(@(x)[char(x) ','],X,'UniformOutput',false);

Error in ==> sym.subs>getNames at 249
    s = cellfun(@(x)[char(x) ','],X,'UniformOutput',false);

Error in ==> sym.subs>tryFunctionHandle at 193
xvarnames = getNames(X);

Error in ==> sym.subs>mupadsubs at 140
[G,worked] = tryFunctionHandle(F,X,Y);

Error in ==> sym.subs at 127
    G = mupadsubs(F,X,Y);

Error in ==> Runge_Kutta_Iteration at 167
            f0Nwl_new=subs(f0Nwl,{I,Nwl,Nes,Ngs,f12,f13,f14,f15},...

Error in ==> Runge_Kutta_Main at 23
    Runge_Kutta_Iteration(Light_in_section,Runge_Kutta_Iteration_num)

Error in ==> ModeLocking_20150427_main at 45
            Runge_Kutta_Main(Light_in_section);</font>

第二次是
<font color="#ff0000">??? Error using ==> Runge_Kutta_Iteration at 90
Error due to multiple causes.

Error in ==> Runge_Kutta_Main at 23
    Runge_Kutta_Iteration(Light_in_section,Runge_Kutta_Iteration_num)

Error in ==> ModeLocking_20150427_main at 45
            Runge_Kutta_Main(Light_in_section);

Caused by:
    Error using ==> Runge_Kutta_Iteration at 90
    Error evaluating parameter 'Denominator' in 'f14/Actuator Model': Undefined
    function or variable 'Ta'.
    Error using ==> Runge_Kutta_Iteration at 90
    Error evaluating parameter 'Gain' in 'f14/Aircraft Dynamics Model/Gain3':
    Undefined function or variable 'Uo'.</font>

这个问题查了一下,看好多人都说是变量调用的问题,相关帖子的链接是http://www.ilovematlab.cn/forum. ... &tid=206897
然后就用global定义了全局变量,主函数和每个子函数都进行了global定义变量,定义格式为:

    global n m groupn modeln ith pa  Main_data RK_data;

但是还是出现这个问题。 重新查了书本之后,使用了evalin 和assignin方法进行了数据传递,在"Runge_Kutta_Iteration"这个迭代函数的刚开始就进行了数据传递,代码如下,但还是出现了上述报错信息。
n=evalin('base','n');
m=evalin('base','m');
groupn=evalin('base','groupn');
modeln=evalin('base','modeln');
ith=evalin('base','ith');
pa=evalin('base','pa');
Main_data=evalin('base','Main_data');
RK_data=evalin('base','RK_data');

于是我进行脚本文档的调试,文档前面部分的代码如下(我把函数名给注释了):
% function Runge_Kutta_Iteration(Light_in_section,Runge_Kutta_Iteration_num)
%%%the iteration program of 4th Runge_Kutta method

%     n=evalin('base','n');
%     m=evalin('base','m');
%     groupn=evalin('base','groupn');
%     modeln=evalin('base','modeln');
%     ith=evalin('base','ith');
%     pa=evalin('base','pa');
%     Main_data=evalin('base','Main_data');
%     RK_data=evalin('base','RK_data');
%    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    TEST_POINT=0;
    dt=0.5e-12*1.09
   
    n=50;%the total steps of time
    t=(1:n)*dt/1e-12;
    m=2;
    dt1=dt/m;
    ith=1;
    inner_loop_steps=[3*ones(1,10),10*ones(1,10)];% change the inner loop number in different time to be more effecient in SignalModulation simulation
    groupn=100;%the group number of ES and GS
    modeln=600;%the lasering model number
   
    Main_data_initiate;% intializing the Main_data
    Is_gain_section=1;
    Light_in_section=1;
    Runge_Kutta_Iteration_num=20;
    parameters(1);
    RK_Iteration_Data_Init(1,20)

这个时候,运行这个脚本文件,程序就不报错。。。:L
一调回函数的形式就会出错。。。。
自己已经看了3/4天了,头都看大了,,,
我在”Runge_Kutta_Iteration"这个迭代函数用了符号变量

syms S I f12 f13 f14 f15 f22
刚开始用这些符号定义其他符号时,都还是正确的,但是到了中间某个位置就出错了,,,
感觉问题好像出在这,但是不知道是不是
求论坛里的大神指点一下,小弟感激不尽。。。。
回复此楼

» 收录本帖的淘帖专辑推荐

matlab编程绘图

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

n01096

新虫 (正式写手)

这个问题也自行解决了,把f14 改成E14就可以了,具体的不知道为啥,,,,估计是f14被当成函数什么的,,,吧
2楼2015-08-25 11:43:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 n01096 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂 +18 MAX怅惘 2026-04-09 20/1000 2026-04-11 23:31 by zhen~
[考研] 359求调剂 +5 胃痉挛累了 2026-04-11 5/250 2026-04-11 19:55 by lbsjt
[考研] 机械专硕270求调剂,接受跨专业 +12 老师看看我吧aba 2026-04-09 14/700 2026-04-11 10:21 by laoshidan
[考研] 311求调剂 +13 xyp想读书 2026-04-10 14/700 2026-04-11 09:41 by 猪会飞
[考研] 281求调剂 +11 觉得好的吧 2026-04-10 11/550 2026-04-11 09:35 by 逆水乘风
[考研] 080500求调剂 +17 黄宇博 2026-04-06 17/850 2026-04-11 08:36 by zhq0425
[考研] 考研调剂 +26 硕星赴 2026-04-09 27/1350 2026-04-10 22:24 by 猪会飞
[考研] 284求调剂 +19 梵@@ 2026-04-06 21/1050 2026-04-10 21:12 by zhouxiaoyu
[考研] 344求调剂 +7 丶风雪夜归人丶 2026-04-09 7/350 2026-04-10 12:05 by pengliang8036
[考研] 调剂 +19 2261744733 2026-04-08 19/950 2026-04-09 19:11 by vgtyfty
[考研] 284求调剂 +7 让我上岸吧阿西 2026-04-09 7/350 2026-04-09 18:59 by haironglove
[考研] 材料299专硕求调剂 +10 +21 2026-04-09 10/500 2026-04-09 17:34 by 1753564080
[考研] 材料工程调剂 +12 小刘同学吖吖 2026-04-06 13/650 2026-04-09 17:07 by luoyongfeng
[考研] 材料调剂 +10 18815505510 2026-04-09 11/550 2026-04-09 17:07 by 544594351
[考研] 085801 总分275 本科新能源 求调剂 +8 bradoner 2026-04-08 9/450 2026-04-09 13:43 by only周
[考研] 材料工程322 +18 哈哈哈吼吼吼哈 2026-04-07 19/950 2026-04-09 10:44 by cymywx
[考研] 270求调剂 +3 031127 2026-04-06 4/200 2026-04-08 21:00 by 逆水乘风
[考研] 336求调剂,一志愿中科大 +9 墨彧 yuyu 2026-04-06 9/450 2026-04-08 11:24 by 想读书的菌菌
[考研] 22408 266求调剂 +11 masss11222 2026-04-07 14/700 2026-04-08 11:06 by yulian1987
[考研] 考研调剂 +3 Wwwwwww哇 2026-04-06 3/150 2026-04-06 20:55 by lbsjt
信息提示
请填处理意见