24小时热门版块排行榜    

查看: 841  |  回复: 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的回帖

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的回帖
查看全部 3 个回答

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
楼主是想通过自己研究算法来进行拟合运算还是只想得到满意的拟合结果?如果是前者,非数学/运筹学等专业的很难有任何突破或新意了,而如果是后者利用现成的商业软件如1stOpt就足够了。
2楼2017-10-11 09:19:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 296求调剂 +5 大口吃饭 身体健 2026-03-13 5/250 2026-03-17 21:05 by 不惑可乐
[考研] 299求调剂 +4 △小透明* 2026-03-17 4/200 2026-03-17 20:09 by peike
[考研] 277调剂 +5 自由煎饼果子 2026-03-16 6/300 2026-03-17 19:26 by 李leezz
[考研] 293求调剂 +6 世界首富 2026-03-11 6/300 2026-03-17 17:04 by ruiyingmiao
[考研] 0854可跨调剂,一作一项核心论文五项专利,省、国级证书40+数一英一287 +3 小李0854 2026-03-16 3/150 2026-03-17 13:40 by 热情沙漠
[考研] 0703一志愿211 285分求调剂 +5 ly3471z 2026-03-13 5/250 2026-03-16 16:16 by 哦哦123
[考研] 一志愿华中师范071000,325求调剂 +6 RuitingC 2026-03-12 6/300 2026-03-16 14:50 by 可淡不可忘
[考研] 中科大材料专硕319求调剂 +3 孟鑫材料 2026-03-13 3/150 2026-03-14 18:10 by houyaoxu
[考研] 297一志愿上交085600求调剂 +5 指尖八千里 2026-03-14 5/250 2026-03-14 17:26 by a不易
[考研] 一志愿哈工大材料324分求调剂 +5 闫旭东 2026-03-14 5/250 2026-03-14 14:53 by 木瓜膏
[考研] 331求调剂(0703有机化学 +5 ZY-05 2026-03-13 6/300 2026-03-14 10:51 by Jy?
[考研] 266求调剂 +4 学员97LZgn 2026-03-13 4/200 2026-03-14 08:37 by zhukairuo
[考研] 304求调剂 +6 Mochaaaa 2026-03-12 7/350 2026-03-13 22:18 by 星空星月
[考研] 290求调剂 +9 ADT 2026-03-11 9/450 2026-03-13 21:55 by JourneyLucky
[考研] 材料与化工085600调剂求老师收留 +9 jiaanl 2026-03-11 9/450 2026-03-13 20:22 by JourneyLucky
[考研] 274求调剂 +3 S.H1 2026-03-12 3/150 2026-03-13 15:15 by JourneyLucky
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
[考研] 0817化学工程与技术考研312分调剂 +3 T123 tt 2026-03-12 3/150 2026-03-13 10:49 by houyaoxu
[考研] 321求调剂(食品/专硕) +3 xc321 2026-03-12 6/300 2026-03-13 08:45 by xc321
[考研] 333求调剂 +3 152697 2026-03-12 4/200 2026-03-13 07:08 by Iveryant
信息提示
请填处理意见