24小时热门版块排行榜    

查看: 903  |  回复: 12
【悬赏金币】回答本帖问题,作者ZXR319将赠送您 50 个金币

ZXR319

新虫 (小有名气)

[求助] Matlab 拟合动力学参数时设置的初值不同,输出的结果不同怎么办?已有3人参与

我在做 LH 机理动力学参数估计,发现设置的参数初值不同输出的结果就不同,我通过调整参数初值能使 lnk 和1/T 呈线性相关,但 lnK 和1/T 就不成线性了怎么办?我该怎么调整参数初值?以下是我的代码:
% 主脚本
% 步骤1: 读取Excel文件中的数据
filename = 'D:\桌面文件\新60.xlsx';
data = readtable(filename);
time = data{:, 't'}; % 时间数据
CA_exp_333K = data{:, 'CA'}; % 333K下反应物A的浓度数据
CB_exp_333K = data{:, 'CB'}; % 333K下生成物B的浓度数据
% 步骤2: 初始参数估计
params_initial = [0.5,0.5,0.5,0.5,0.5]; % 需要根据实际情况进行调整
lb=[0 0 0 0 0];
ub=[100 100 100 100 100];
% 使用非线性最小二乘法拟合参数
options = optimoptions('lsqnonlin', 'Algorithm', 'levenberg-marquardt', 'Display', 'iter');
params_est = lsqnonlin(@(params) ObjFunc(params, time, CA_exp_333K, CB_exp_333K), params_initial, [], [], options);
% 使用拟合参数重新计算浓度
options = odeset('RelTol', 1e-6, 'AbsTol', 1e-9);
[t, C] = ode45(@(t, C) KineticModel2(t, C, params_est), time, [CA_exp_333K(1); CB_exp_333K(1)], options);
CA_pred = C(:, 1);
CB_pred = C(:, 2);
% 步骤3: 计算总方差和 (SST) 并检查
residuals = ObjFunc(params_est, time, CA_exp_333K, CB_exp_333K);
SST = sum(residuals.^2); % 计算总方差和
% 步骤4: 根据SST值绘制图形或重新设定初值
if SST < 1
% 如果SST小于1,绘制图形并输出参数
fprintf('拟合的参数值为:\n');
fprintf('k: %f\n', params_est(1));
fprintf('K_A: %f\n', params_est(2));
fprintf('K_B: %f\n', params_est(3));
fprintf('K_H: %f\n', params_est(4));
fprintf('K_bc: %f\n', params_est(5));
fprintf('总方差和 (SST): %f\n', SST); % 输出总方差和
% 绘制实验浓度和计算浓度相关图
figure;
plot(time, CA_exp_333K, 'b-', time, CA_pred, 'r--');
hold on;
plot(time, CB_exp_333K, 'g-', time, CB_pred, 'k--');
legend('实验CA', '拟合CA', '实验CB', '拟合CB');
xlabel('时间 (min)');
ylabel('浓度 (mol/L)');
title('实验浓度与计算浓度对比');
hold off;
else
% 如果SST大于或等于1,提示需要重新设定初值
fprintf('SST值过大,需要重新设定参数初值。当前SST: %f\n', SST);
% 这里可以添加代码来调整初始参数或采取其他措施
end
function dCdt = KineticModel2(t, C, params)
k = params(1);
K_A = params(2);
K_B = params(3);
K_H = params(4);
K_bc = params(5);
P_H2 = 3e3; % 氢气压力,单位为KPa
c_A = C(1);
c_B = C(2);
numerator = k * K_A * c_A * sqrt((K_H * P_H2) / K_bc);
denominator = (1 + K_A * c_A + K_B * c_B+ sqrt((K_H * P_H2) / K_bc))^2;
r = numerator / denominator;
dC_A_dt = -r;
dC_B_dt = r;
dCdt = [dC_A_dt; dC_B_dt];
end
function res = ObjFunc(params, time, CA_exp, CB_exp)
options = odeset('RelTol', 1e-6, 'AbsTol', 1e-9);
[t, C] = ode45(@(t, C) KineticModel2(t, C, params), time, [CA_exp(1); CB_exp(1)], options);
CA_pred = C(:, 1);
CB_pred = C(:, 2);
% 计算总方差和
res = (CA_exp - CA_pred).^2 + (CB_exp - CB_pred).^2;
end
以下图片中是我的数据,跪求大佬指导?
参数初值通过查文献给出的方法不现实,因为我做这个没有人做过,类似的文献初值差距也很大,我觉得没有什么参考价值???而且我不太明白,比如我有五个参数 k、KA、KB、KH、Kbc,那这五个参数初值应该一样吗?

Matlab 拟合动力学参数时设置的初值不同,输出的结果不同怎么办?


发自小木虫Android客户端
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xrs333

木虫 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
你的方程有多个根,比如,0.1 - x + 2*x^3 = 0,有三个根。使用不同的迭代算法以及给定不同预估值,可能会收敛到不同的根,需要提供适当的预估值(迭代初值)才能迭代求得所要求的根。
2楼2024-10-07 09:10:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

johnliu1983

至尊木虫 (著名写手)

【答案】应助回帖

感谢参与,应助指数 +1
matlab在拟合是时候,你应该可以限制参数范围,先找到你认为比较合理的参数范围,然后把设置参数的范围设置好就行。
3楼2024-10-08 18:39:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ZXR319

新虫 (小有名气)

引用回帖:
2楼: Originally posted by xrs333 at 2024-10-07 09:10:05
你的方程有多个根,比如,0.1 - x + 2*x^3 = 0,有三个根。使用不同的迭代算法以及给定不同预估值,可能会收敛到不同的根,需要提供适当的预估值(迭代初值)才能迭代求得所要求的根。

谢谢您的回复!关键问题是我不知道合适的参数初值应该是多少?我做的东西别人没做过,类似的文献中的参数带进去拟合效果又不好,所以我应该考虑全局最优化算法吗?

发自小木虫Android客户端
4楼2024-10-09 11:47:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ZXR319

新虫 (小有名气)

引用回帖:
3楼: Originally posted by johnliu1983 at 2024-10-08 18:39:53
matlab在拟合是时候,你应该可以限制参数范围,先找到你认为比较合理的参数范围,然后把设置参数的范围设置好就行。

谢谢您的回复!你说的意思我明白,可我参数初值代0.5或1的时候得到的结果都不一样,这个参数范围实在是不好确定,而且就算确定了范围,给出一个初值,拟合效果也不好,不知道为什么,真的愁死了

发自小木虫Android客户端
5楼2024-10-09 11:50:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xrs333

木虫 (正式写手)

引用回帖:
4楼: Originally posted by ZXR319 at 2024-10-09 11:47:21
谢谢您的回复!关键问题是我不知道合适的参数初值应该是多少?我做的东西别人没做过,类似的文献中的参数带进去拟合效果又不好,所以我应该考虑全局最优化算法吗?
...

可以尝试,把方程增加一个变量b,然后,在给定状态下,计算一系列待定系数时该变量的值,找到使变量b为零(或接近为零)的待定系数。
6楼2024-10-09 18:12:01
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

johnliu1983

至尊木虫 (著名写手)

【答案】应助回帖

引用回帖:
5楼: Originally posted by ZXR319 at 2024-10-09 11:50:23
谢谢您的回复!你说的意思我明白,可我参数初值代0.5或1的时候得到的结果都不一样,这个参数范围实在是不好确定,而且就算确定了范围,给出一个初值,拟合效果也不好,不知道为什么,真的愁死了
...

要不你把数据和你的m文件发给我,我有空帮你看看。 johnliu1983@126.com

» 本帖已获得的红花(最新10朵)

7楼2024-10-09 20:17:28
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hzlhm

至尊木虫 (著名写手)

【答案】应助回帖

1、先用rand函数作为初值
2、然后修正初值
3、最后得到结果
链接: https://pan.baidu.com/s/1X3gWCp4EEbFsWrwCKLyeEA?pwd=wur3 提取码: wur3 复制这段内容后打开百度网盘手机App,操作更方便哦

» 本帖已获得的红花(最新10朵)

QQ:2120156492
8楼2024-10-09 21:36:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hzlhm

至尊木虫 (著名写手)

【答案】应助回帖

CA
R^2=  0.98593573
CB
R^2=  0.98593573
333℃时的系数:
k:  0.45591792
K_A:  0.45589602
K_B:  0.47448748
K_H:  0.50329217
K_bc:  0.45984830
QQ:2120156492
9楼2024-10-09 21:37:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ZXR319

新虫 (小有名气)

送红花一朵
引用回帖:
7楼: Originally posted by johnliu1983 at 2024-10-09 20:17:28
要不你把数据和你的m文件发给我,我有空帮你看看。 johnliu1983@126.com...

太感谢您了,邮件已发,请查收

发自小木虫Android客户端
10楼2024-10-10 11:14:27
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ZXR319 的主题更新
不应助 确定回帖应助 (注意:应助才可能被奖励,但不允许灌水,必须填写15个字符以上)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[论文投稿] MDPI投稿连续拒稿是什么原因?文章质量不好吗?还是其他原因? 2+8 多听多看多学 2024-12-17 17/850 2024-12-21 18:51 by 6681981668
[教师之家] 为啥很多高校老师不愿意当副院长? +8 意得辑_editage 2024-12-18 8/400 2024-12-21 18:18 by csyky2007
[论文投稿] 挑数据是造假吗 +5 电话的建设 2024-12-21 5/250 2024-12-21 17:16 by 科研皮皮猪
[考博] 华南理工大学 “新能源交叉创新团队--主动安全”课题组招收海外联合培养博士生 +4 hubble 2024-12-20 5/250 2024-12-21 16:16 by 那片叶落
[有机交流] 装柱干法上样 +3 刘松垚 2024-12-20 3/150 2024-12-21 14:37 by hanjianwei
[考博] 申博的科研计划书怎么写? +5 爱喝风的龙卷茶 2024-12-19 9/450 2024-12-21 09:47 by 爱喝风的龙卷茶
[硕博家园] “认怂了”还是“认清了”:青年博士纷纷“逃离”科研的背后…… +13 柏舟0000 2024-12-16 14/700 2024-12-21 08:36 by steven_198377
[有机交流] 工艺需求,付费 +4 想当然灬 2024-12-17 6/300 2024-12-21 06:23 by a893069456
[论文投稿] 论文校稿 50+5 whale_full 2024-12-17 10/500 2024-12-20 16:39 by 北京莱茵润色
[硕博家园] 柔性引进硕博人才 +6 大发财树 2024-12-20 6/300 2024-12-20 15:32 by owlmac
[论文投稿] 投稿投错期刊,怎么撤稿? 200+4 birrd 2024-12-17 8/400 2024-12-20 14:53 by yiran909
[论文投稿] sci二区的审稿周期 22+5 分外含晴 2024-12-16 11/550 2024-12-20 13:56 by TopEdit
[教师之家] 只是硕士不是博士,即便有教授职称,换工作也很受限 +12 河西夜郎 2024-12-15 13/650 2024-12-20 11:01 by zhzhzhi
[论文投稿] Molecular Crystals and Liquid Crystals投稿8个月没有信息 +4 书剑如风 2024-12-17 12/600 2024-12-20 04:40 by 胖胖的大海
[基金申请] 除了评职称,除了考评,你对社科项目是什么态度? +9 xinrenxf 2024-12-16 15/750 2024-12-19 11:31 by cwwqt
[论文投稿] 投稿意见求助,没弄清回答的方向 8+3 moonlig 2024-12-18 3/150 2024-12-19 08:59 by 北京莱茵润色
[论文投稿] 毕业论文疑虑 20+6 风吹荷叶煞 2024-12-17 17/850 2024-12-18 17:35 by holypower
[考博] 招收2025级博士 +3 cake1 2024-12-15 5/250 2024-12-18 10:59 by cake1
[有机交流] 细丝状的晶体可以测单晶吗? +5 好气好气 2024-12-16 5/250 2024-12-17 22:53 by 请让我滚去学习
[考博] 东北师范大学 有机光电材料、柔性电子器件 招收25届博士 +5 糊糊涂涂好 2024-12-14 5/250 2024-12-16 11:45 by Ricoch4t
信息提示
请填处理意见