zoukankan      html  css  js  c++  java
  • [Python]使用python的工具箱做数字滤波器设计和频域分析

     1 # -*- coding: utf-8 -*-
     2 """
     3 Spyder Editor
     4 
     5 This is a temporary script file.
     6 """
     7 
     8 import matplotlib.pyplot  as plt
     9 import scipy as sci
    10 import numpy as np
    11 
    12 
    13 
    14 plt.rcParams['font.sans-serif']=['SimHei'] #用来正常显示中文标签
    15 plt.rcParams['axes.unicode_minus']=False #用来正常显示负号
    16 
    17 
    18 fs = 200; #采样频率
    19 f1 = 10;  #信号分量1频率
    20 f2 = 20;  #信号分量2频率
    21 f3 = 30;  #信号分量3频率
    22 f4 = 40;  #信号分量1频率
    23 n  = np.arange(100)/fs; #采样点
    24 
    25 # 生成信号
    26 yn = [20*np.sin(2*np.pi*f1*i) + 10*np.sin(2*np.pi*f2*i) + 5*np.sin(2*np.pi*f3*i) + 20*np.sin(2*np.pi*f4*i) for i in n];
    27 
    28 
    29 
    30 # fft分析原始信号
    31 fft_result_abs1 = np.abs(sci.fft(yn))*2/len(n);
    32 f_idx = np.arange(len(n))*fs/len(n);
    33 
    34 # 滤波器设计和滤波
    35 (b,a) = sci.signal.butter(N=5,Wn=(15),btype='lowpass',output='ba',fs=200); #生成低通滤波器参数
    36 #print(b)
    37 #print(a)
    38 yn_filtered = sci.signal.filtfilt(b,a,yn); #滤波器
    39 # fft分析滤波后的信号
    40 fft_result_abs2 = np.abs(sci.fft(yn_filtered))*2/len(n);
    41 
    42 
    43 
    44 # 画图
    45 plt.close('all');
    46 plt.figure();
    47 plt.subplot(2,2,1);
    48 plt.plot(n,yn);
    49 plt.title(U'原始时域信号');
    50 plt.subplot(2,2,2);
    51 plt.plot(f_idx[range(int(len(n)/2))],fft_result_abs1[range(int(len(n)/2))]);
    52 plt.title(U'原始信号频域分析');
    53 
    54 plt.subplot(2,2,3);
    55 plt.plot(n,yn_filtered);
    56 plt.title(U'低通滤波后时域信号');
    57 
    58 
    59 plt.subplot(2,2,4);
    60 plt.plot(f_idx[range(int(len(n)/2))],fft_result_abs2[range(int(len(n)/2))]);
    61 plt.title(U'低通滤波信号频域分析');
    62 
    63 
    64 plt.figure();
    65 (w,h) = sci.signal.freqs(b,a);
    66 #plt.plot(w, 20 * np.log10(abs(h)))     #绘制幅频响应,频率轴取对数,幅度轴转换成dB。
    67 
    68 plt.plot(w, abs(h)) 

    图片显示:

    Ref:

    https://blog.csdn.net/qq7835144/article/details/88838537

    https://segmentfault.com/a/1190000005144275

    ~不再更新,都不让我写公式,博客园太拉胯了
  • 相关阅读:
    对soc-audio体系snd_soc_machine和snd_soc_dai_link简单理解
    I2S
    alsa和oss声音系统比较
    break 和 continue
    phalcon查询:单条查询,多条查询,多表查询
    phalcon: 独立的映射,字段名名别名
    phpexcel: 数据导出
    php:Mcrypt响应慢的原因解决备注
    js:s上次预览,上传图片预览,图片上传预览
    yii2: 点击编辑后,左侧的连接(a.navtab)失效,变成在新窗口打开
  • 原文地址:https://www.cnblogs.com/alimy/p/11800381.html
Copyright © 2011-2022 走看看