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结果可以看出,频谱的幅值存在差异,后续设计分类器进行识别

相关推荐
AI前沿晓猛哥1 小时前
暗黑4 d3d12.dll找不到解决方法:安全修复教程与工具对比
数据挖掘
清水白石0081 小时前
Free-Threaded Python 实战指南:机遇、风险与 PoC 验证方案
java·python·算法
飞Link2 小时前
具身智能核心架构之 Python 行为树 (py_trees) 深度剖析与实战
开发语言·人工智能·python·架构
桃气媛媛2 小时前
Pycharm常用快捷键
python·pycharm
Looooking3 小时前
Python 之获取安装包所占用磁盘空间大小
python
CC数分3 小时前
电商领域备考CDA数据分析师经验分享
经验分享·数据分析
WenGyyyL3 小时前
ColBERT论文研读——NLP(IR)里程碑之作
人工智能·python·语言模型·自然语言处理
lxy-up3 小时前
RAG--切片策略
python
新新学长搞科研3 小时前
第五届电子、集成电路与通信技术国际学术会议(EICCT 2026)
运维·人工智能·自动化·集成测试·信号处理·集成学习·电气自动化
ricky_fan3 小时前
(OpenAI)Codex 安装、部署使用方式
python·macos·conda·vim