随机梯度辨识方法

Matlab

利用随机梯度方法进行辨识的举例,可以结合不同情况进行优化处理(例如需要复现文献中结果)

Matlab代码如下:

matlab 复制代码
clc;clear;close; format short g;
M = 'Stochastic gradient method';
sigma = 0.5;    % Noise standard deviation
FF = 0.88;      % Forgetting factor
PlotLength = 3000; length1 = PlotLength + 200;  
na = 4; nb = 4; n = na + nb;    % order
alp = [1, 0, -0.96, 0, 0.64]; bet = [0.412, 0.9682, 0.824, 0.2472]; d = [1];
par0 = [alp(2 : na + 1), bet(1 : nb)]';
p0 = 1e6; P = eye(n) * p0; r = 1;   % initial value
par1 = ones(n, 1) * 1e-6;

sy = f_integral(alp, bet); sv = f_integral(alp, d); % the complex integral 
delta_ns = sqrt(sv / sy) * 100 * sigma; % the noise to signal ratio
[sy, sv, delta_ns];

u = normrnd(0, 1, length1, 1);
v = normrnd(0, sigma, length1, 1);
Gz = tf(bet, alp, 1);
Gn = tf(d, alp, 1);
y = lsim(Gz, u) + lsim(Gn, v);

%% Stochastic gradient
jj = 0; j1 = 0;
for k = 20 : length1
    jj = jj + 1;
    varphi = [-y(k - 1: -1: k - na); u(k - 1: -1: k - nb)]; 
    r = FF * r + varphi' * varphi;  % SG
    par1 = par1 + varphi / r * (y(k) - varphi' * par1); 
    %L = P * varphi / (FF + varphi' * P *varphi);   % RLS
    %P = P - L * varphi' * P;
    %par1 = par1 + L * (y(k) - varphi' * par1);
    delta = norm(par1 - par0) / norm(par0);
    sg(jj, :) = [jj, par1', delta];
    if (jj == 100) | (jj == 200) | (jj == 500) | mod(jj, 1000) == 0
        j1 = j1 + 1;
        sg_100(j1, :) = [jj, par1', delta * 100];
    end
    if jj == PlotLength
        break
    end
end
sg_100(j1 + 1, :) = [0, par0', 0];

%fprintf('\n', 't & \t a_1 & \t a_2 & \t b_1 & \t b_2 & \delta');
fprintf('%6d & %6.3f & %6.3f & %6.3f & %6.3f & %6.3f & %6.3f & %6.3f & %6.3f & %6.3f \\\\ \n', sg_100');
figure(1)
jk = (19: 10: PlotLength - 1)';
plot(sg(jk, 1), sg(jk, n + 2));

xlabel('\it       k'); ylabel('{\it         \delta}');

仿真结果图:

随着迭代次数的增加,可见误差越来越小,命令行窗口输出如下:

尝试修改参数加深理解~

相关推荐
imbackneverdie21 小时前
6个常用国自然课题项目查询网站,码住以备不时之需
论文阅读·人工智能·aigc·科研·国自然·ai工具·国家自然科学基金
蓝田生玉12321 小时前
qwen2.5论文阅读笔记
论文阅读·笔记
SUNNY_SHUN1 天前
ICLR 2026 | Judo: 7B小模型工业缺陷问答超越GPT-4o,用对比学习+强化学习注入领域知识
论文阅读·人工智能·学习·视觉检测·github
sin°θ_陈1 天前
前馈式3D Gaussian Splatting 研究地图(总览篇):解构七大路线,梳理方法谱系,看懂关键分歧与未来趋势
论文阅读·深度学习·算法·3d·aigc·空间计算·3dgs
智算菩萨2 天前
【实战讲解】ChatGPT 5.4深度文献检索完全指南:提示词工程与学术实战策略
论文阅读·人工智能·gpt·搜索引擎·chatgpt·提示词·论文笔记
檐下翻书1732 天前
音乐产业版权管理与运营流程图表制作方法
论文阅读·信息可视化·毕业设计·流程图·论文笔记
森诺Alyson2 天前
前沿技术借鉴研讨-2026.3.26(解决虚假特征x2/混合专家对比学习框架)
论文阅读·人工智能·经验分享·深度学习·学习·论文笔记
森诺Alyson2 天前
前沿技术借鉴研讨-2026.3.19(睡眠分期/Agents模拟临床会诊/多模态抑郁症检测)
论文阅读·经验分享·深度学习·论文笔记·论文讨论
imbackneverdie3 天前
如何从海量文献中跨界汲取创新灵感?
论文阅读·人工智能·ai·自然语言处理·aigc·ai写作·ai工具
云霄星乖乖的果冻4 天前
【文献阅读:RobustRAG】Certifiably Robust RAG against Retrieval Corruption
论文阅读