24小时热门版块排行榜    

查看: 2574  |  回复: 9

13143747

银虫 (小有名气)

[求助] 信号分析中有两个for循环太浪费时间了求帮助怎么减少程序运行时间

我的想法:1:运用MATLAB GPU并行运算运算来把for循环放到gpu中计算;
               2:将两个for循环改成矩阵运算。
但是没成功  

close all;clear all;
fs=20000;%采样频率
f=fs/10;%调制频率
N=2000;%采样点数
t=0:1/fs:N/fs-1/fs;


fm=50;%模拟故障频率
b=fm*3000;%衰减率
Tm2=1/fm;%冲击周期
nn=Tm2*floor(t/Tm2);
x1=0.1*exp(-b*(t-nn).^2).*sin(2*pi*f*t);%模拟故障信号,冲击信号
x11=abs(hilbert(x1));%包络解调信号,参考故障诊断里的共振解调方法

%原始信号及频谱
figure;subplot(211);plot(t,x1);
subplot(212);hua_fft(x1,fs,2);

%输入噪声
%load 2000noisebearing.mat;



%% raw noise signal 含噪噪声及频谱

x33=x1+(0.15/0.6)*x2;
figure;subplot(211);plot(t,x33);
subplot(212);hua_fft(x33,fs,2);

Wn=[(1000)/(fs/2) (3000)/(fs/2)]; %对含噪信号先进行带通滤波,再解调
[b, a]=butter(3,Wn);
x333=filter(b,a,x33);
x3=abs(hilbert(x333));

figure;subplot(211);plot(t,x3);
subplot(212);hua_fft(x3,fs,2,0,1000);

S2=x3;%随机共振输入信号

%% Parameters tuning of 2bistable potential
%通过寻找信噪比最优来寻优
Max_SNR2=-50;
index2=1;

        for h=5:5:1000
            for r=0.001:0.001:0.06
            % twosr为随机共振算法
            s6=twosr(1,1,h/fs,r,S2);      
            s6=s6-mean(s6);
         
            y=fft(s6,N);
            pyy=y.*conj(y)/N;
                                 
            P_S_1=pyy(round(fm*N/fs)+1);
            P_N_1=sum(pyy(1:N/2))-P_S_1;
            SNR_B2(int32(h/5),int32(r*1000))=10*log10(P_S_1/P_N_1);
            if 10*log10(P_S_1/P_N_1)>Max_SNR2
                Max_SNR2=10*log10(P_S_1/P_N_1);
                Maxh=h;
                Maxr=r;
            end

            end
        end

%得到SNR最优的随机共振输出信号
s8=twosr(1,1,Maxh/fs,Maxr,S2);  
figure;subplot(211);plot(t,s8);
subplot(212);hua_fft(s8,fs,2,0,1500);
回复此楼

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : 2000noisebearing.mat
  • 2015-10-08 21:43:45, 15.19 K
  • 附件 2 : hua_fft.m
  • 2015-10-08 21:43:45, 2.01 K
  • 附件 3 : twosr.m
  • 2015-10-08 21:43:45, 682 bytes

» 猜你喜欢

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

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

Scorpio_0

银虫 (著名写手)

Practice makes perfect
2楼2015-10-08 21:45:04
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

13143747

银虫 (小有名气)

引用回帖:
2楼: Originally posted by Scorpio_0 at 2015-10-08 21:45:04
坐故障诊断的,哈哈

对的
3楼2015-10-08 21:47:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Scorpio_0

银虫 (著名写手)

引用回帖:
3楼: Originally posted by 13143747 at 2015-10-08 21:47:10
对的

告诉你,不要追求实效性,无意中,真想时效就和c++混合编程,matlab并行计算不行,数据集太少的时候还会更慢。还有就是并行计算很多要求,比如同层数据之间没有递归计算。

发自小木虫Android客户端
Practice makes perfect
4楼2015-10-08 21:50:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

13143747

银虫 (小有名气)

引用回帖:
4楼: Originally posted by Scorpio_0 at 2015-10-08 21:50:37
告诉你,不要追求实效性,无意中,真想时效就和c++混合编程,matlab并行计算不行,数据集太少的时候还会更慢。还有就是并行计算很多要求,比如同层数据之间没有递归计算。
...

这个程序跑完20秒,我扩大了范围,跑了2000多秒……

发自小木虫Android客户端
5楼2015-10-08 22:13:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

13143747

银虫 (小有名气)

引用回帖:
4楼: Originally posted by Scorpio_0 at 2015-10-08 21:50:37
告诉你,不要追求实效性,无意中,真想时效就和c++混合编程,matlab并行计算不行,数据集太少的时候还会更慢。还有就是并行计算很多要求,比如同层数据之间没有递归计算。
...

请问一下,同层没有递归什么意思,我这个程序同层有递归吗

发自小木虫Android客户端
6楼2015-10-08 22:15:09
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Scorpio_0

银虫 (著名写手)

引用回帖:
6楼: Originally posted by 13143747 at 2015-10-08 22:15:09
请问一下,同层没有递归什么意思,我这个程序同层有递归吗
...

就是一层循环下,数据本身或者之间没有依赖关系,比如递归。

发自小木虫Android客户端
Practice makes perfect
7楼2015-10-08 22:32:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Scorpio_0

银虫 (著名写手)

引用回帖:
6楼: Originally posted by 13143747 at 2015-10-08 22:15:09
请问一下,同层没有递归什么意思,我这个程序同层有递归吗
...

并行计算是同步的,但是一个循环下,比如1000个数据是没有顺序的,如果同层下有依赖关系,就会出问题

发自小木虫Android客户端
Practice makes perfect
8楼2015-10-08 22:33:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dk1013

木虫 (正式写手)

建议把程序简化一下,只留最核心部分代码。
简化到最简单,同时又能反映你的问题。
读别人代码是很费时间的事情。
到得还来别无事 庐山烟雨浙江潮
9楼2015-10-09 09:10:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

13143747

银虫 (小有名气)

引用回帖:
9楼: Originally posted by dk1013 at 2015-10-09 09:10:03
建议把程序简化一下,只留最核心部分代码。
简化到最简单,同时又能反映你的问题。
读别人代码是很费时间的事情。

好的,第一次发帖不好意思

发自小木虫Android客户端
10楼2015-10-09 09:43:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 13143747 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 国自科面上基金字体 +6 iwuli 2026-03-12 7/350 2026-03-16 21:18 by sculhf
[考研] 302求调剂 +3 小贾同学123 2026-03-15 5/250 2026-03-16 20:39 by zhq0425
[考研] 机械专硕325,寻找调剂院校 +3 y9999 2026-03-15 5/250 2026-03-16 19:58 by y9999
[文学芳草园] 伙伴们,祝我生日快乐吧 +17 myrtle 2026-03-10 26/1300 2026-03-16 18:32 by 青橙Ln
[考研] 梁成伟老师课题组欢迎你的加入 +8 一鸭鸭哟 2026-03-14 9/450 2026-03-16 17:35 by 沐霖12138
[考研] 085600材料与化工 求调剂 +13 enenenhui 2026-03-13 14/700 2026-03-16 15:19 by 了了了了。。
[考研] 材料与化工一志愿南昌大学327求调剂推荐 +7 Ncdx123456 2026-03-13 8/400 2026-03-16 12:15 by karry wen
[硕博家园] 深圳大学硕士招生(2026秋,传感器方向,仅录取第一志愿) +4 xujiaoszu 2026-03-11 8/400 2026-03-16 09:45 by xujiaoszu
[考研] 290求调剂 +4 @将就将就看 2026-03-10 8/400 2026-03-14 14:23 by 千千运气
[考研] 271求调剂 +10 生如夏花… 2026-03-11 10/500 2026-03-14 00:35 by 卖报员小雨
[考研] 327求调剂 +4 Ffff03 2026-03-10 4/200 2026-03-14 00:17 by JourneyLucky
[考研] 四川大学085601材料工程专硕 初试294求调剂 +4 祝我们好在冬天 2026-03-11 4/200 2026-03-13 21:39 by peike
[考研] 302求调剂 +6 负心者当诛 2026-03-11 6/300 2026-03-13 16:11 by JourneyLucky
[考研] 一志愿211化学学硕310分求调剂 +8 努力奋斗112 2026-03-12 9/450 2026-03-13 15:41 by JourneyLucky
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
[考研] 268求调剂 +4 好运连绵不绝 2026-03-12 4/200 2026-03-13 10:45 by hyswxzs
[考研] 材料专硕274一志愿陕西师范大学求调剂 +4 薛云鹏 2026-03-13 4/200 2026-03-13 10:40 by 学员8dgXkO
[基金申请] 提交后的基金本子,已让学校撤回了,可否换口子提交 +3 dut_pfx 2026-03-10 3/150 2026-03-11 08:38 by kudofaye
[考研] 化工0817调剂 +8 灿若星晨 2026-03-10 8/400 2026-03-10 22:44 by 星空星月
[考研] 298求调剂 +3 Vv呀! 2026-03-10 3/150 2026-03-10 22:40 by 剑诗杜康
信息提示
请填处理意见