做个备份,对 numpy 不熟,每次都找函数找半天。

代码里分几块:

1. 从 argc[1] 的文档中读取数据,并转化为 float。文档中有 2001 行,第一行为头,后面 2000 个是采样数据加换行。

2. wd[] 是我这里用的窗函数。是我们某产品里用的窗,参考下面一行 c:

r[p]=s[p] *(0.3125-0.46875*std::cos(*PI*p/len)+0.1875*std::cos(*PI*p/len)-0.03125*std::cos(*PI*p/len));//FDMS_1 Window

3. 使用 numpy 进行 fft。

4. 找出最大和次最大,然后估算真实最大。

5. 画图。

#!/usr/bin/env python
# -*- coding: utf-8 -*- import sys
import numpy as np
import matplotlib.pyplot as pl points1 = 2000 if len(sys.argv) == 1:
print "error, no txt file"
exit(1) fp = open(sys.argv[1], 'r')
s = fp.readline() samples=[]
i = 0
wd=[]
while i < 2000:
wd.append( 0.3125 - 0.46875 * np.cos ( 2 * np.pi * i / 2000 )
+ 0.1875 * np.cos( 4 * np.pi * i / 2000 )
- 0.03125 * np.cos( 6 * np.pi * i / 2000 ) )
s = fp.readline()
s = s.strip('\n')
s = s.strip('\r') if s:
fl = float(s)*wd[i]
samples.append(fl)
# print fl
else:
break i = i + 1 dft_a = np.fft.fft(samples)
dft_a_abs = np.fft.fftshift(abs(dft_a)) * 2 / 2000 idx = np.argmax(dft_a_abs)
if dft_a_abs[idx - 1] > dft_a_abs[ idx + 1] :
idx = idx - 1 y=dft_a_abs[idx]
y2=dft_a_abs[idx+1] beta = (y2-y)/(y2+y)
alpha = 3.5*beta; rms=(y+y2) * (3.43612+0.85434*pow(alpha,2)
+ 0.11871*pow(alpha,4) ) / 2 / 1.4142135623 freq = (idx+alpha+0.5)*1000/2000; print rms, freq axis_a = np.linspace(-points1/2, points1/2-1, num=points1)
pl.subplot(121)
pl.plot(axis_a,dft_a_abs)
pl.axis([95, 105, 0, 0.05]) pl.subplot(122)
axis_b = np.linspace(0,2000,2000)
pl.plot(axis_b,wd)
pl.show()

numpy 傅立叶得到幅值和频率的更多相关文章

  1. (DDS)正弦波形发生器——幅值、频率、相位可调(二)

    (DDS)正弦波形发生器--幅值.频率.相位可调(二) 主要关于调相方面 一.项目任务: 设计一个幅值.频率.相位均可调的正弦波发生器. 频率每次增加10kHz 相位每次增加 PI/2 幅值每次增加两 ...

  2. (DDS)正弦波形发生器——幅值、频率、相位可调(一)

    (DDS)正弦波形发生器--幅值.频率.相位可调 一.项目任务: 设计一个幅值.频率.相位均可调的正弦波发生器. 频率每次增加1kHz. 相位每次增加 2*PI/256 幅值每次增加两倍 二.文章内容 ...

  3. FFT之频率与幅值的确定(转)

    FFT之后得到的是什么数 FFT之后得到的那一串复数是波形对应频率下的幅度特征,注意这个是幅度特征不是复制,下面要讲两个问题:1.如何获取频率,2.如何获取幅值 获取频率 FFT变换如何获取频率?傅里 ...

  4. 统计numpy数组中每个值出现的个数

    统计numpy数组中某一个值或某几个值出现的个数:sum(data==4) # 统计出现了几个cluster include0Cluster = sum(res == 0) include1Clust ...

  5. 统计numpy数组中每个值的个数

    import numpy as np from collections import Counter data = np.array([1.1,2,3,4,4,5]) Counter(data) #简 ...

  6. Matlab绘制幅值谱和相位谱

    1. 对于直接给出频响函数的情况 这里以滑动平均的频响函数作为例子,滑动窗口为[0, 4]. 上式中M2=4. >> w=0:0.001:2*pi; >> h1=1-exp(- ...

  7. numpy Array[:,]的取值方法

  8. 信号处理基础概念比较----频谱vs功率谱vs能谱

    频谱: 对动态信号在频率域内进行分析,分析的结果是以频率为坐标的各种物理量的谱线和曲线,可得到各种幅值以频率为变量的频谱函数F(ω).频谱是个很不严格的东西,常常指信号的Fourier变换.频谱分析中 ...

  9. 基于DDS的任意波形发生器

    实验原理 DDS的原理 DDS(Direct Digital Frequency Synthesizer)直接数字频率合成器,也可叫DDFS. DDS是从相位的概念直接合成所需波形的一种频率合成技术. ...

随机推荐

  1. Activity间用Intent、Bundle、onActivityResult进行传值

    其实Activity间的传值就是通过Bundle,intent中也是自动生成了Bundle来传值,里面还有个onActivityResult()方法也可以传送数值. 如果一个Activity是由sta ...

  2. 利用Logstash插件进行Elasticsearch与Mysql的数据

    Logstash与Elasticsearch的安装就不多说了,我之前有两篇文章写的比较详细了ElasticSearch + Logstash + Kibana 搭建笔记 和 Filebeat+Logs ...

  3. JAVAWEB开发之HttpServletResponse和HttpServletRequest详解(下)(各种乱码、验证码、重定向和转发)

    HttpServletRequest获取请求头信息  (1)获取客户机请求头 String getHeader(String name) Enumeration<String> getHe ...

  4. pssh,pdsh,mussh,cssh,dsh运维工具介绍

    pssh 1 安装:#wget http://peak.telecommunity.com/dist/ez_setup.pypython ez_setup.py#wget http://paralle ...

  5. go语言之进阶篇通过结构体生成json

    1.通过结构体生成json 示例: package main import ( "encoding/json" "fmt" ) //成员变量名首字母必须大写 t ...

  6. IIS通过HTML5实现应用程序缓存的离线浏览

    这里我是使用的IIS7: IIS7发布了网站后要想使用HTML5的应用程序缓存,需要增加一个关于文本/缓存清单( text/cache-manifest)的新的MIME类型,选中网站添加一个MIME类 ...

  7. 华为推送 简介 集成 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  8. CSS渐变字体、镂空字体、input框提示信息颜色、给图片加上内阴影、3/4圆

    1.渐变字体 主要是看:-webkit-background-clip: text; 该属性 <style> .b1{ width: 500px; height: 200px; font- ...

  9. JS滚轮事件onmousewheel

    典型的应用时鼠标滚轮滚动控制图片或者文字的大小,例如此类的转动鼠标滚轮实现缩放等等交互效果中,会用到 Mousewheel 事件.在大多数浏览器(IE6, IE7, IE8, Opera 10+, S ...

  10. NLP--自然语言处理与机器学习会议

    http://blog.csdn.net/ice110956/article/details/17090061 整理至11月中旬在重庆参加的自然语言处理与机器学习会议,第一讲为自然语言处理. 由基本理 ...