CanMV K230 波形识别——数据分析(2)

说明

收集ADC采集到的数据,通过Python进行数据分析,采用DFT算法

1 准备工作

  1. 采集数据的csv文件
  2. jupyter notebook/lab numpy matplotlib

2 导入数据

导入csv文件

python 复制代码
import numpy as np
FB = np.genfromtxt('***.csv', delimiter=',', dtype=float)  # 换成保存的变量名

例如,csv仅保留ADC数据列,代码如下

python 复制代码
Square = np.genfromtxt('Square.csv', delimiter=',', dtype=float)  
Triangular = np.genfromtxt('Triangular.csv', delimiter=',', dtype=float)  点数
Sine = np.genfromtxt('Sine.csv', delimiter=',', dtype=float)  

绘制波形

python 复制代码
# 绘制波形 生成数据集
import matplotlib.pyplot as plt 
plt.subplot(3, 1, 1) 
plt.plot(Triangular[0:100])
plt.title('Triangular wave')    # 添加标题
plt.show()                      # 显示图形
plt.subplot(3, 1, 2) 
plt.plot(Square[0:100])
plt.title('Square wave')        # 添加标题
plt.show()                      # 显示图形
plt.subplot(3, 1, 3) 
plt.plot(Sine[0:100])
plt.title('Sine wave')          # 添加标题
plt.show()                      # 显示图形

输入结果如下

DFT处理

这里可以采用与MicroPython近似的定义

python 复制代码
import math
def DFT(x):
    Hw=[] # Hw H(w) 频域分布
    xl=len(x)
    for m in range(xl):
        ww=[]
        for n in range(xl):
            W=x[n]*np.exp(-1j*2*math.pi*n*m/xl)
            ww.append(W)
        Hw.append(sum(ww))
    Hw=np.array(Hw,dtype=np.complex64)
    return Hw
# 调用 DFT

调用DFT,绘制DFT结果

python 复制代码
# 绘制波形 生成数据集
# 计算实际幅值
Triangular_DFT=abs(DFT(Triangular[0:20]))*2/20
Square_DFT=abs(DFT(Square[0:20]))*2/20
Sine_DFT=abs(DFT(Sine[0:20]))*2/20
import matplotlib.pyplot as plt 
plt.subplot(3, 1, 1) 
plt.plot(Triangular_DFT)
plt.title('Triangular wave DFT')  # 添加标题
plt.show()                      # 显示图形
plt.subplot(3, 1, 2) 
plt.plot(Square_DFT)
plt.title('Square wave DFT')  # 添加标题
plt.show()                      # 显示图形
plt.subplot(3, 1, 3) 
plt.plot(Sine_DFT)
plt.title('Sine wave DFT')  # 添加标题
plt.show()                      # 显示图形

从DFT结果可以看出,除了第一个直流分量外,参数对称。

数据降维

原始信号长度为20 ,去除直流分量与幅值重复部分,取DFT[1-11]个参数,重新绘制如下

python 复制代码
# 绘制波形 特征数据
import matplotlib.pyplot as plt 
plt.subplot(3, 1, 1) 
plt.plot(Triangular_DFT[1:11])
plt.title('Triangular wave DFT')  # 添加标题
plt.show()                      # 显示图形
plt.subplot(3, 1, 2) 
plt.plot(Square_DFT[1:11])
plt.title('Square wave DFT')  # 添加标题
plt.show()                      # 显示图形
plt.subplot(3, 1, 3) 
plt.plot(Sine_DFT[1:11])
plt.title('Sine wave DFT')  # 添加标题
plt.show()                      # 显示图形

从DFT结果可以看出,频谱的幅值存在差异,后续设计分类器进行识别

相关推荐
Bruk.Liu5 分钟前
(LangChain 实战14):基于 ChatMessageHistory 自定义实现对话记忆功能
人工智能·python·langchain·agent
大江东去浪淘尽千古风流人物20 分钟前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)
人工智能·python·算法
Swift社区21 分钟前
Gunicorn 与 Uvicorn 部署 Python 后端详解
开发语言·python·gunicorn
Coinsheep25 分钟前
SSTI-flask靶场搭建及通关
python·flask·ssti
IT实战课堂小元酱25 分钟前
大数据深度学习|计算机毕设项目|计算机毕设答辩|flask露天矿爆破效果分析系统开发及应用
人工智能·python·flask
码农阿豪26 分钟前
Flask应用上下文问题解析与解决方案:从错误日志到完美修复
后端·python·flask
wqq631085529 分钟前
Python基于Vue的实验室管理系统 django flask pycharm
vue.js·python·django
Q_Q196328847530 分钟前
python大学生爱心校园互助代购网站_nyvlx_django Flask vue pycharm项目
python·django·flask
码农阿豪33 分钟前
Python Flask应用中文件处理与异常处理的实践指南
开发语言·python·flask
xcLeigh34 分钟前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3