24小时热门版块排行榜    

查看: 729  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料080500调剂求收留 +6 一颗meteor 2026-03-13 6/300 2026-03-20 10:41 by EBSD
[考研] 一志愿西南交通 专硕 材料355 本科双非 求调剂 +3 西南交通专材355 2026-03-19 3/150 2026-03-20 09:34 by 每天只摆一小会
[考研] 一志愿苏州大学材料求调剂,总分315(英一) +3 sbdksD 2026-03-19 3/150 2026-03-19 23:21 by fmesaito
[考研] 085600材料与化工求调剂 +6 绪幸与子 2026-03-17 6/300 2026-03-19 13:27 by houyaoxu
[考研] 材料考研调剂 +3 xwt。 2026-03-19 3/150 2026-03-19 11:22 by w沐阳w
[考研] 材料专业求调剂 +5 hanamiko 2026-03-18 5/250 2026-03-18 20:19 by 星空星月
[考研] 295求调剂 +3 一志愿京区211 2026-03-18 5/250 2026-03-18 17:03 by zhaoqian0518
[考研] 297求调剂 +8 戏精丹丹丹 2026-03-17 8/400 2026-03-18 14:30 by laoshidan
[考研] 一志愿西南交大,求调剂 +4 材化逐梦人 2026-03-18 4/200 2026-03-18 14:22 by 007_lilei
[考研] 280求调剂 +6 咕噜晓晓 2026-03-18 7/350 2026-03-18 11:25 by 无际的草原
[考研] 278求调剂 +5 烟火先于春 2026-03-17 5/250 2026-03-18 08:43 by 星空星月
[考研] 332求调剂 +6 Zz版 2026-03-13 6/300 2026-03-17 17:03 by ruiyingmiao
[考研] 290求调剂 +3 p asserby. 2026-03-15 4/200 2026-03-17 16:35 by wangkm
[考研] 274求调剂 +5 时间点 2026-03-13 5/250 2026-03-17 07:34 by 热情沙漠
[考研] 药学383 求调剂 +3 药学chy 2026-03-15 4/200 2026-03-16 20:51 by 元子^0^
[基金申请] 今年的国基金是打分制吗? 50+3 zhanghaozhu 2026-03-14 3/150 2026-03-16 17:07 by 北京莱茵润色
[考研] 中科院材料273求调剂 +4 yzydy 2026-03-15 4/200 2026-03-16 15:59 by Gaodh_82
[考研] 0703化学调剂 290分有科研经历,论文在投 +7 腻腻gk 2026-03-14 7/350 2026-03-16 10:12 by houyaoxu
[考研] 中科大材料专硕319求调剂 +3 孟鑫材料 2026-03-13 3/150 2026-03-14 18:10 by houyaoxu
[硕博家园] 085600 260分求调剂 +3 天空还下雨么 2026-03-13 5/250 2026-03-13 18:46 by 天空还下雨么
信息提示
请填处理意见