24小时热门版块排行榜    

Znn3bq.jpeg
北京石油化工学院2026年研究生招生接收调剂公告
查看: 856  |  回复: 2

manmanbobo

新虫 (初入文坛)

[求助] LM算法碰到分段函数该怎么处理 已有1人参与

各位虫友大家好,本虫在目前在用LM算法进行函数的曲线拟合,函数分两段,一部分类似于余弦,另一部分类似于幂函数。在循环中,因为分段点也是一个未知的变量,所以不能进行比较大小,特地求助广大虫友,感激不尽。这个问题卡了我好久。谢谢。下面附上一些代码。
代码1:单一函数的拟合,为了虫友能更好理解LM算法。
% 计算函数f的雅克比矩阵,是解析式
syms a b c d y x real;
f=a+b*cos((pi/c)*(x-d));
Jsym=jacobian(f,[a b c d])


% 拟合用数据。
data_1=[0.25 0.5 1 1.5 2 3 4 6 8];
obs_1=[19.21 18.15 15.36 14.10 12.89 9.32 7.45 5.24 3.01];

% 2. LM算法
% 初始猜测s


a0=4; b0=20;c0=14;d0=13;
y_init = a0+b0*cos((pi/c0)*(x-d0));
% 数据个数
Ndata=length(obs_1);
% 参数维数
Nparams=4;
% 迭代最大次数
n_iters=50;
% LM算法的阻尼系数初值
lamda=0.01;

% step1: 变量赋值
updateJ=1;
a_est=a0;
b_est=b0;
c_est=c0;
d_est=d0;
% step2: 迭代
for it=1:n_iters
    if updateJ==1
        % 根据当前估计值,计算雅克比矩阵
        J=zeros(Ndata,Nparams);
        J
        for i=1:length(data_1)
            i
            
            J(i,=[ 1 cos((pi*(d_est - data_1))/c_est) (b_est*pi*sin((pi*(d_est - data_1))/c_est).*(d_est - data_1))/c_est^2  -(b_est*pi*sin((pi*(d_est - data_1))/c_est))/c_est];
        end
        % 根据当前参数,得到函数值
        y_est =a_est+b_est*cos((pi/c_est)*(data_1-d_est)) ;
        % 计算误差
        d=obs_1-y_est;
        % 计算(拟)海塞矩阵
        H=J'*J;
        % 若是第一次迭代,计算误差
        if it==1
            e=dot(d,d);
        end
    end

    % 根据阻尼系数lamda混合得到H矩阵
    H_lm=H+(lamda*eye(Nparams,Nparams));
    % 计算步长dp,并根据步长计算新的可能的\参数估计值
    dp=inv(H_lm)*(J'*d();
    g = J'*d(;
    a_lm=a_est+dp(1);
    b_lm=b_est+dp(2);
    c_lm=c_est+dp(3);
    d_lm=d_est+dp(4);
    % 计算新的可能估计值对应的y和计算残差e
    y_est_lm =a_lm+b_lm*cos((pi/c_lm)*(data_1-d_lm)) ;
    d_lm=obs_1-y_est_lm;
    e_lm=dot(d_lm,d_lm);
    % 根据误差,决定如何更新参数和阻尼系数
    if e_lm<e
        lamda=lamda/10;
        a_est=a_lm;
        b_est=b_lm;
        c_est=c_lm;
        d_est=d_lm;
        e=e_lm;
        disp(e);
        updateJ=1;
    else
        updateJ=0;
        lamda=lamda*10;
    end
end
%显示优化的结果
a_est
b_est
c_est
d_est
代码2(部分):对代码1进行改进,想求分段函数的偏导。
% 计算函数f的雅克比矩阵,是解析式
syms a b c d f  g x k y1 y2 real;
if x<f
y1=a+b*cos((pi/c)*(x-d));
y1x=jacobian(y1,[a b c d]);
else
y2=(a+g)+[b*cos((pi/c)*(f-d))-g]*exp(-(x-f)/k);
y2x=jacobian(y2,[a b c d g ])
end
%Jsym=jacobian(f,[a b c d f g h]);
% 拟合用数据。
data_1=[0.25 0.5 1 1.5 2 3 4 6 8];
obs_1=[19.21 18.15 15.36 14.10 12.89 9.32 7.45 5.24 3.01];
% 2. LM算法
% 初始猜测s
a0=4; b0=20;c0=14;d0=13;f0=17;g0=0.9;
y_init = a0+b0*cos((pi/c0)*(x-d0));
% 数据个数
Ndata=length(obs_1);
% 参数维数
Nparams=4;
% 迭代最大次数
n_iters=50;
% LM算法的阻尼系数初值
lamda=0.01;
% step1: 变量赋值
updateJ=1;
a_est=a0;
b_est=b0;
c_est=c0;
d_est=d0;
f_est=f0;
g_est=g0;
% step2: 迭代
for it=1:n_iters
    if updateJ==1
        % 根据当前估计值,计算雅克比矩阵
        J=zeros(Ndata,Nparams);
    a=ones(9,1);
  if x<h
         
    J=[ a cos((pi*(d_est - data_1))/c_est)' ((b_est*pi*sin((pi*(d_est - data_1))/c_est).*(d_est - data_1))/c_est^2)'  (-(b_est*pi*sin((pi*(d_est - data_1))/c_est))/c_est)']
   else
  J=[ a cos((pi*(d - f))/c)*exp((f - x)/k), (b*pi*exp((f - x)/k)*sin((pi*(d - f))/c)*(d - f))/c^2, -(b*pi*exp((f - x)/k)*sin((pi*(d - f))/c))/c, 1 - exp((f - x)/k), (b*pi*exp((f - x)/k)*sin((pi*(d - f))/c))/c]
   end
再次感谢虫友,谢谢!
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
楼主是想通过自己研究算法来进行拟合运算还是只想得到满意的拟合结果?如果是前者,非数学/运筹学等专业的很难有任何突破或新意了,而如果是后者利用现成的商业软件如1stOpt就足够了。
2楼2017-10-11 09:19:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

manmanbobo

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by dingd at 2017-10-11 09:19:32
楼主是想通过自己研究算法来进行拟合运算还是只想得到满意的拟合结果?如果是前者,非数学/运筹学等专业的很难有任何突破或新意了,而如果是后者利用现成的商业软件如1stOpt就足够了。

嗯嗯,你说的很中肯,不过,我是数据量大,所以想用MATLAB,你说的1stopt拟合万金油嘛,也挺不错。同样也谢谢你。
3楼2017-10-16 10:31:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 manmanbobo 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 288求调剂 +12 没有答案_ 2026-04-05 12/600 2026-04-08 00:17 by T可可西里T
[考研] 297求调剂 +14 GENJIOW 2026-04-07 15/750 2026-04-07 23:30 by JourneyLucky
[考研] 277、学硕,求调剂 数一104, +11 瓶子PZ 2026-04-07 12/600 2026-04-07 23:30 by 一只好果子?
[考研] 材料调剂 +5 小刘同学吖吖 2026-04-06 5/250 2026-04-06 18:34 by sherry_1901
[考研] 0703化学调剂325分 +12 15771691647 2026-04-04 13/650 2026-04-06 12:00 by lijunpoly
[考研] 348求调剂 +3 车厘子zzz 2026-04-05 3/150 2026-04-05 20:30 by 啵啵啵0119
[考研] 22408 总分320,一篇论文二作,两个国三,求调剂 +3 Leomulufu 2026-04-04 5/250 2026-04-05 19:04 by chongya
[考研] 271分求调剂学校 +12 zph158488! 2026-04-02 13/650 2026-04-05 10:13 by lqwchd
[考研] 材料调剂 +12 一样YWY 2026-04-04 12/600 2026-04-05 08:24 by 544594351
[考研] 278求调剂 +14 范婷娜 2026-04-04 15/750 2026-04-04 22:15 by lqwchd
[考研] 一志愿0817化学工程与技术,求调剂 +24 我不是只因 2026-04-02 28/1400 2026-04-04 15:15 by dongzh2009
[考研] 085701求调剂 +7 龚禹铭 2026-04-04 8/400 2026-04-04 13:49 by 小小树2024
[考研] 317分 一志愿江南大学 化学工程学硕 求调剂 +6 YinTai 2026-04-03 6/300 2026-04-03 22:30 by 无际的草原
[基金申请] esi高被引论文是不是能对中标有所加分和帮助呢 +5 redcom 2026-04-01 6/300 2026-04-03 15:15 by Howard28
[考研] 274求调剂 +9 顺理成张 2026-04-03 10/500 2026-04-03 15:10 by 啊俊!
[考研] 303求调剂 +3 一色清羽 2026-04-02 4/200 2026-04-03 10:22 by 蓝云思雨
[考研] 348求调剂 +6 吴彦祖24k 2026-04-02 6/300 2026-04-02 14:07 by 给你你注意休息
[考研] 材料调剂 +12 一样YWY 2026-04-01 12/600 2026-04-02 09:15 by olim
[考研] 353求调剂 +4 拉钩不许变 2026-04-01 4/200 2026-04-01 18:10 by 记事本2026
[考研] 一志愿北交材料工程总分358 +5 cs0106 2026-04-01 7/350 2026-04-01 11:45 by wangjy2002
信息提示
请填处理意见