24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 3641  |  回复: 12
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

cs24451

铁虫 (初入文坛)

[求助] matlab使用自定义函数文件拟合出现错误 已有1人参与

代码如下,x,y是想要拟合的曲线对应的x,y值;L1,L2是想要拟合的参数;
下面就是一系列的矩阵计算,通过x求得y
使用ft=fittype('c(x,,L1,L2)');
出现错误:
错误使用 fittype/testCustomModelEvaluation (line 12)
Expression c(x,L1,L2) is not a valid MATLAB expression, has non-scalar coefficients, or cannot be evaluated:
Error in fittype expression ==> c(x,L1,L2)
??? 索引超出矩阵维度。
出错 fittype>iCreateFittype (line 371)
    testCustomModelEvaluation( obj );
出错 fittype (line 328)
                obj = iCreateFittype( obj, varargin{:} );
原因:
    错误使用 fittype/evaluate (line 102)
    Error in fittype expression ==> c(x,L1,L2)
    ??? 索引超出矩阵维度。
怎么解决这个问题?还有其他拟合办法吗?求助好心的坛友~~~~~~~~~~~~~~~~~~~

function [ y ] = c(x,L1,L2)
%UNTITLED2 此处显示有关此函数的摘要
%   此处显示详细说明
m=20; % number of section
n1 = 2.8924;   %AlAs
n2 = 3.3702;   %GaAS
na=1;
ns=n2;
ra=(na-n2)/(na+n2);
r=(n2-n1)/(n2+n1);
ta=sqrt(1-ra^2);
t=sqrt(1-r^2);
y=zeros(1,2500);
ab1=0;
ab2=0;
for kl=1:2500

    beta1 = 2*pi*n1/x(kl)-1i*ab1/2;
    beta2 = 2*pi*n2/x(kl)-1i*ab2/2;
   
    T11_a = exp(1i*beta2*L2)/ta;
    T12_a = ra*exp(-1i*beta2*L2)/ta;
    T21_a = ra*exp(1i*beta2*L2)/ta;
    T22_a = exp(-1i*beta2*L2)/ta;
    T=[T11_a,T12_a;T21_a,T22_a];
   
        for k=1:m-1
            T11_n2 = exp(1i*beta1*L1)/t;
            T12_n2 = r*exp(-1i*beta1*L1)/t;
            T21_n2 = r*exp(1i*beta1*L1)/t;
            T22_n2 = exp(-1i*beta1*L1)/t;
            T_n2=[T11_n2,T12_n2;T21_n2,T22_n2];
            T=T*T_n2;
            
            T11_n1 = exp(1i*beta2*L2)/t;
            T12_n1 = -r*exp(-1i*beta2*L2)/t;
            T21_n1 = -r*exp(1i*beta2*L2)/t;
            T22_n1 = exp(-1i*beta2*L2)/t;  
            T_n1=[T11_n1,T12_n1;T21_n1,T22_n1];
            T=T*T_n1;

        end
        T11_n2 = exp(1i*beta1*L1)/t;
        T12_n2 = r*exp(-1i*beta1*L1)/t;
        T21_n2 = r*exp(1i*beta1*L1)/t;
        T22_n2 = exp(-1i*beta1*L1)/t;
        T_n2=[T11_n2,T12_n2;T21_n2,T22_n2];
        T=T*T_n2;
        
        T_12=[1/t,-r/t;-r/t,1/t]; % from n1 to n2, just cross the interface
        T = T*T_12;
        
        T11_c = exp(1i*beta2*2*L2);
        T12_c = 0;
        T21_c = 0;
        T22_c = exp(-1i*beta2*2*L2);
        T_c = [T11_c,T12_c;T21_c,T22_c]; % n2 cavity
        T = T*T_c;
        
        for k=(1:m)
            T11_n2 = exp(1i*beta1*L1)/t;
            T12_n2 = r*exp(-1i*beta1*L1)/t;
            T21_n2 = r*exp(1i*beta1*L1)/t;
            T22_n2 = exp(-1i*beta1*L1)/t;
            T_n2=[T11_n2,T12_n2;T21_n2,T22_n2];
            T=T*T_n2;
            T11_n1 = exp(1i*beta2*L2)/t;
            T12_n1 = -r*exp(-1i*beta2*L2)/t;
            T21_n1 = -r*exp(1i*beta2*L2)/t;
            T22_n1 = exp(-1i*beta2*L2)/t;  
            T_n1=[T11_n1,T12_n1;T21_n1,T22_n1];
            T=T*T_n1;
        end   
        

        T11_n2 = exp(1i*beta1*L1)/t;
        T12_n2 = r*exp(-1i*beta1*L1)/t;
        T21_n2 = r*exp(1i*beta1*L1)/t;
        T22_n2 = exp(-1i*beta1*L1)/t;
        T_n2=[T11_n2,T12_n2;T21_n2,T22_n2];
        T=T*T_n2;
        
        T_12=[1/t,-r/t;-r/t,1/t];
        T = T*T_12;
        
        T11_c = exp(1i*beta2*9*L2);
        T12_c = 0;
        T21_c = 0;
        T22_c = exp(-1i*beta2*9*L2);
        T_c = [T11_c,T12_c;T21_c,T22_c]; % n2 cavity
        T = T*T_c;
        
        T11_n2 = exp(1i*beta1*L1)/t;
        T12_n2 = r*exp(-1i*beta1*L1)/t;
        T21_n2 = r*exp(1i*beta1*L1)/t;
        T22_n2 = exp(-1i*beta1*L1)/t;
        T_n2=[T11_n2,T12_n2;T21_n2,T22_n2];
        T=T*T_n2;
        
        rs1=(n1-ns)/(ns+n1);
        ts1=sqrt(1-rs1^2);
        T11_s = 1/ts1;  % n1 to substrate
        T12_s = rs1/ts1;
        T21_s = rs1/ts1;
        T22_s = 1/ts1;
        T_s = [T11_s,T12_s;T21_s,T22_s];
        T=T*T_s;
        y(kl) = (abs(T(2,1)/T(1,1)))^2;
end

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

cs24451

铁虫 (初入文坛)

引用回帖:
6楼: Originally posted by 512095518 at 2016-09-01 13:31:34
L1 = -9.02438565124979e-09
L2 = -8.31832684073256e-09
你验证下对不对...

额  楼主怎么实现的  能说下么  我这个L1 L2代表长度, 希望在我给出的值附近浮动,不能为负。。。
7楼2016-09-01 16:13:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 13 个回答

512095518

专家顾问 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
你先给出你的拟合数据,x,y,然后给出你估计的L1 L2的值
你的这个函数function [ y ] = c(x,L1,L2),是表示用x,L1,L2就可以计算出y值对吧
没有极限,只有超越!
2楼2016-08-31 19:11:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

cs24451

铁虫 (初入文坛)

引用回帖:
2楼: Originally posted by 512095518 at 2016-08-31 19:11:07
你先给出你的拟合数据,x,y,然后给出你估计的L1 L2的值
你的这个函数function  = c(x,L1,L2),是表示用x,L1,L2就可以计算出y值对吧

是的 ,我已经设置了x,y值, 想通过我的函数c(x,L1,L2)来求得合适的L1与L2值
3楼2016-08-31 23:37:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

512095518

专家顾问 (正式写手)

【答案】应助回帖

引用回帖:
3楼: Originally posted by cs24451 at 2016-08-31 23:37:42
是的 ,我已经设置了x,y值, 想通过我的函数c(x,L1,L2)来求得合适的L1与L2值...

我想帮你,就必须只要你的x,y数值,还有待定的L1 L2,然后我再尝试看看怎么编写代码
没有极限,只有超越!
4楼2016-08-31 23:48:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料工程302分求调剂 +7 zyx上岸! 2026-04-04 7/350 2026-04-05 13:52 by imissbao
[考研] 266分,一志愿电气工程,本科材料,求材料专业调剂 +5 哇呼哼呼哼 2026-04-02 6/300 2026-04-05 11:49 by 风雨无晴
[考研] 285求调剂 +11 哦呦呼o 2026-04-04 11/550 2026-04-05 08:15 by 544594351
[考研] 一志愿北京化工大学,初试成绩350求调剂 +9 沿岸?贝壳 2026-04-04 14/700 2026-04-05 01:09 by 沿岸?贝壳
[考研] 302求调剂一志愿华中师范大学 +8 小江小江江江 2026-04-02 8/400 2026-04-04 19:50 by 蓝云思雨
[考研] 321求调剂 +13 认真求上学 2026-04-02 13/650 2026-04-04 18:23 by macy2011
[考研] 化工调剂303分,过四级 +28 栖梧待风 2026-04-02 28/1400 2026-04-03 21:40 by qlm5820
[考研] 一志愿重庆大学085404,总分314分,求调剂 +4 zf83hn 2026-04-03 4/200 2026-04-03 21:25 by 啵啵啵0119
[考研] 求调剂 +3 usbdndj 2026-04-03 3/150 2026-04-03 14:10 by dxiaoxin
[考研] 285求调剂 +6 FZAC123 2026-03-30 6/300 2026-04-03 12:22 by xingguangj
[考研] 一志愿中国科学院大学265求调剂 +9 恬淡ye 2026-03-31 10/500 2026-04-03 11:10 by txp1986
[考研] 316求调剂 +14 舟自梗 2026-04-01 18/900 2026-04-03 10:28 by linyelide
[考研] 260求调剂 +3 朱芷琳 2026-04-02 3/150 2026-04-03 08:44 by yulian1987
[考研] 调剂 +3 osbbx 2026-04-02 3/150 2026-04-03 07:47 by cc8418
[考研] 一志愿山东大学,085600,344 +7 魏子per 2026-04-02 8/400 2026-04-02 21:12 by 百灵童888
[考研] 260求调剂 +6 朱芷琳 2026-04-02 6/300 2026-04-02 20:27 by 6781022
[考研] 085602化工求调剂(331分) +9 111@127 2026-03-30 9/450 2026-04-02 20:00 by dick_runner
[考研] 318求调剂,计算材料方向 +10 吸喵有害笙命 2026-04-01 11/550 2026-04-02 16:29 by oooqiao
[考研] 0710生物学求调剂! +6 叙述文 2026-03-31 6/300 2026-04-01 09:39 by JourneyLucky
[考研] 083000环境科学与工程调剂,总分281 +4 橙子(胜意) 2026-03-30 4/200 2026-03-31 00:44 by Linzejun
信息提示
请填处理意见