最优信号分解的例子(Python)

146 篇文章 33 订阅
39 篇文章 0 订阅
import numpy as np


import matplotlib.pyplot as plt
import matplotlib.patches as patches


# Pull out common plotting settings:
from plot_params import get_plot_params
full_params, half_params = get_plot_params()
full_params['lines.linewidth'] = 1
full_params['figure.figsize'] = (7, 3.5)
plt.rcParams.update(full_params)
# Generate an example signal
fs = 5000
t_max = 1
n = int(fs*t_max)


# Build signal
t = np.linspace(0,t_max,n)
dt = t[1]-t[0]




# Define a time-dependent phase function
f_base = 350
df_1 = 10
tau_1 = 0.5
omega_1 = lambda x: f_base + (df_1)*(1-np.exp(-x/tau_1))
amp_1 = lambda x: 1 + 0.5*np.exp(-x/3)




omega_2 = lambda x: 80-2*x
amp_2 = lambda x: 8 - 0.5*np.exp(-x)




mu = lambda x: 1.5 + 2.5*np.exp(-x/(1.5))
#mu = lambda x: 2*x-0.3*x**2
#mu = lambda t: (0.2)*np.sin(t)


# Create data with time-dependent frequency
z_1 = lambda t: amp_1(t)*np.cos(2*np.pi*omega_1(t)*t)
z_2 = lambda t: amp_2(t)*np.cos(2*np.pi*omega_2(t)*t) 


z = z_1(t) 
z += z_2(t)
z += mu(t)
#z = z/np.std(z)
text_props = dict(rotation=90, horizontalalignment='center', verticalalignment='center')


fig3 = plt.figure()
gs = fig3.add_gridspec(3, 3)




#################################
## Axes 1 -- Top Row -- Signal ##
#################################
ax1 = fig3.add_subplot(gs[0, :2])
ax1.plot(t, z, label='Signal')
l3, = plt.plot(t, mu(t), '--k', label='Mean')
ax1.set_ylabel('$z(t)$')


################################
## Axes 2 -- 2nd Row - Mode 1 ##
################################
ax2 = fig3.add_subplot(gs[1, :2], sharex=ax1)
l1, = plt.plot(t, z_1(t))
l2, = plt.plot(t, amp_1(t))
ax2.set_ylabel('$z_1(t)$')


ax2a = fig3.add_subplot(gs[1, 2:])
l1, = plt.plot(t, omega_1(t), '-', color='grey')
ax2a.set_ylabel('$\omega_1(t)$')


################################
## Axes 2 -- 2nd Row - Mode 1 ##
################################
ax3 = fig3.add_subplot(gs[2, :2], sharex=ax1)
plt.plot(t, z_2(t))
plt.plot(t, amp_2(t))
ax3.set_ylabel('$z_2(t)$')
ax3.set_xlabel('Time (s)')
ax3.set_xlim([0,0.1])


ax3a = fig3.add_subplot(gs[2, 2:], sharex=ax2a)
l4, = plt.plot(t, omega_2(t), '-', color='grey')
ax3a.set_ylabel('$\omega_2(t)$')
ax3a.set_xlabel('Time (s)')
ax3a.set_xlim([0,1])


# Do some formatting of the shared axes, etc
plt.setp(ax1.get_xticklabels(), visible=False)
plt.setp(ax2.get_xticklabels(), visible=False)
plt.setp(ax2a.get_xticklabels(), visible=False)


# Create the legend on top right axes
leg_ax = fig3.add_subplot(gs[0, 2:], frameon=False)
leg_ax.set_xticks([])
leg_ax.set_yticks([])
leg_ax.legend((l1, l2, l3, l4), 
           ('Signal', '$A(t)$', '$\mu(t)$', '$\omega(t)$'),
           ncol=2, bbox_to_anchor=(0.4,0.5), loc='center')


# Mode labels
plt.text(-0.2, 0.5, "Mode 1", transform=ax2.transAxes, **text_props)
plt.text(-0.2, 0.5, "Mode 2", transform=ax3.transAxes, **text_props)




#plt.tight_layout()
plt.subplots_adjust(left=None, bottom=None, right=None, top=None, wspace=0.4, hspace=None)


plt.savefig("shea3.png")


plt.show()

 
擅长领域:现代信号处理,机器学习,深度学习,数字孪生,时间序列分析,设备缺陷检测、设备异常检测、设备智能故障诊断与健康管理PHM等。
知乎学术咨询:https://www.zhihu.com/consult/people/792359672131756032?isMe=1
擅长领域:现代信号处理,机器学习,深度学习,数字孪生,时间序列分析,设备缺陷检测、设备异常检测、设备智能故障诊断与健康管理PHM等。

擅长领域:现代信号处理,机器学习,深度学习,数字孪生,时间序列分析,设备缺陷检测、设备异常检测、设备智能故障诊断与健康管理PHM等。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哥廷根数学学派

码字不易,且行且珍惜

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值