24小时热门版块排行榜    

CyRhmU.jpeg
查看: 661  |  回复: 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
刚开始用这些符号定义其他符号时,都还是正确的,但是到了中间某个位置就出错了,,,
感觉问题好像出在这,但是不知道是不是
求论坛里的大神指点一下,小弟感激不尽。。。。
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

n01096

新虫 (正式写手)

这个问题也自行解决了,把f14 改成E14就可以了,具体的不知道为啥,,,,估计是f14被当成函数什么的,,,吧
2楼2015-08-25 11:43:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 n01096 的主题更新
信息提示
请填处理意见