24小时热门版块排行榜    

查看: 904  |  回复: 1

忘忧谷3987

银虫 (小有名气)

[求助] 有关非负矩阵的MATLAB程序优化

亲们:我编了一个有关非负矩阵分解算法的MATLAB程序,但是与别人的实验结果相比,迭代次数和时间比原始数据差很多,但是我不会优化程序,麻烦大神们给指导指导,非常感谢
function [W,iter_W,gradW]=QRPBB(V,Winit,H,maxiter,tol)
W=Winit;
alpha_max=1.0e+20;
alpha_min=1.0e-20;
M=5;
row=0.25;
gama=1.0e-4;
HHt=H*H';
VHt=V*H';
L=norm(HHt);
delta0=-sum(sum(H.*(W'*V)));
dQd0=sum(sum((H.*(W'*W*H))));
f0=delta0+0.5*dQd0;
for k=1:maxiter;
    gradW=W*HHt-VHt;%计算W的梯度;
    projgrad = norm(gradW(gradW<0 | W>0),'fro');%W的投影范数;
    if projgrad<tol;%终止条件的判断;
        break;
    end
    if k==1;
        alpha=1;%初始alpha
    end
    Z=max(0,W-gradW/L);%由构造的严格凸二次函数求出的封闭解;
    gradZ=Z*HHt-VHt;
    Zn=max(0,Z-alpha*gradZ);%为定义方向而定义的一个中间变量;
    D=Zn-Z;%迭代方向;
    delta=sum(sum(D.*gradZ));
    dQd=sum(sum((H.*(Z'*Z*H))));
    %搜步长
    if k==1;
        func(k)=f0 ;
    else
        func(k)=fn;
    end
    jj=min(k-1,M-1);
    fmax=max(func(k-jj:k));
  
    m=0;maxm=20;mk=0;
    while (m<maxm);
        fn=func(k)+row^m*delta+0.5*row^(2*m)*dQd;
        if(fn<=fmax+gama*row^m*delta),%判断目标函数下降;
            mk=m;%满足使的目标函数下降的最小正整数;
            break;
        end
        m=m+1;
    end
    lamda=row^mk;%更新lamda用于产生新的迭代点W;
    %迭代格式
    W=Z+lamda*D;
    %BB步更新方向D;
    s=D;
    y=D*HHt;
    b=sum(sum(s.*s));
    c=sum(sum(s.*y));
    alphaBB=b/c;
    if (c<=0),
        alpha=alpha_max;
    else
        alpha=min(alpha_max,max(alpha_min,alphaBB));
    end
    iter_W=k;
   
end
if k==maxiter,
    fprintf('Max k in QRPBB\n');
end
测试问题

clear
clc

l= 100;
n = 200;
r =15;
% V = rand(;l,n);
Winit= rand(l,r);
Hinit= rand(r,n);
V = abs(rand(l,r))*abs(rand(r,n));
tol=1.e-7;
maxtime=1000;
maxiter=5000;%最大迭代次数
tic
[W,iter_W,gradW]=QRPBB(V,Winit,H,maxiter,tol);
toc
希望可以教教我具体怎样优化一个程序,才能使得它的迭代次数和时间降低,谢谢!!
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

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

hyk2006

木虫 (小有名气)

2楼2018-02-06 11:06:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 忘忧谷3987 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 289求调剂 +8 硕星赴 2026-03-23 8/400 2026-03-24 20:17 by peike
[考研] 299求调剂 +7 某某某某位 2026-03-21 7/350 2026-03-24 15:24 by cuifj
[考研] 一志愿北京化工大学材料与化工 264分各科过A区国家线 +3 哈哈157349 2026-03-21 3/150 2026-03-24 14:11 by zhyzzh
[考研] 279分求调剂 一志愿211 +18 chaojifeixia 2026-03-19 20/1000 2026-03-24 10:34 by dolphin_ycj
[考研] 一志愿哈工大,085400,320,求调剂 +3 gdlf9999 2026-03-24 3/150 2026-03-24 10:08 by 搏击518
[考研] 276求调剂。有半年电池和半年高分子实习经历 +9 材料学257求调剂 2026-03-23 10/500 2026-03-24 07:36 by wangy0907
[考研] 考研化学308分求调剂 +7 你好明天你好 2026-03-23 8/400 2026-03-23 18:39 by macy2011
[考研] 接收2026硕士调剂(学硕+专硕) +4 allen-yin 2026-03-23 6/300 2026-03-23 15:04 by 汪!?!
[考研] 306求调剂 +9 chuanzhu川烛 2026-03-18 9/450 2026-03-23 13:17 by luoyongfeng
[考研] 263求调剂 +6 yqdszhdap- 2026-03-22 9/450 2026-03-23 12:57 by yqdszhdap-
[考研] 一志愿070300浙大化学358分,求调剂! +4 酥酥鱼.. 2026-03-21 4/200 2026-03-23 08:12 by Iveryant
[考研] 285求调剂 +6 ytter 2026-03-22 6/300 2026-03-22 12:09 by 星空星月
[考研] 354求调剂 +7 Tyoumou 2026-03-18 10/500 2026-03-22 11:11 by 人来盛
[考研] 材料学学硕080502 337求调剂-一志愿华中科技大学 +4 顺顺顺mr 2026-03-18 5/250 2026-03-21 10:22 by luoyongfeng
[考研] 324分 085600材料化工求调剂 +4 llllkkkhh 2026-03-18 4/200 2026-03-21 01:24 by JourneyLucky
[考研] 22408 344分 求调剂 一志愿 华电计算机技术 +4 solanXXX 2026-03-20 4/200 2026-03-20 23:49 by alg094825
[考研] 317求调剂 +5 申子申申 2026-03-19 9/450 2026-03-20 22:26 by JourneyLucky
[考研] 一志愿吉林大学材料学硕321求调剂 +11 Ymlll 2026-03-18 15/750 2026-03-20 19:40 by 丁丁*
[考研] 求调剂 +3 eation27 2026-03-20 3/150 2026-03-20 19:32 by JourneyLucky
[考研] 材料考研调剂 +3 xwt。 2026-03-19 3/150 2026-03-19 11:22 by w沐阳w
信息提示
请填处理意见