百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

同事开玩笑说:你这个python程序要是外流出去了,可能会有危险

off999 2025-07-19 22:01 60 浏览 0 评论

引言

公司因为业务原因,购入了一些高灵敏高精度的振动传感器。老板说:“拿去进行测试,看看数据如何?”

吭哧吭哧接入数据,一看,确实精度和灵敏度非常高。具体多高呢?

将传感器固定在相关的结构物上,在办公室中人的声音但凡大一些,都能引起 波形振动

好家伙,这么高的灵敏度!众所周知,声音也是一种振动能量,能否通过这个传感器,将结构物因为声音引发的 振动转换为音频 呢?

同事说:“要是你这个程序开发了,再搞个传感器,贴在外墙,是不是就能听到屋里说话的声音了,这个外流出去很危险哦!”

怎么样,是否有黑科技的味道了!接下来看看如何操作的吧!

1、采集信号

首先需要通过 python 采集信号,具体如何获取呢?每个厂家都有不同的方式,主要有两种:

  1. 通过串口
  2. 通过socket

这两种方式的不同之处在于,串口 需要连接数据线,而 socket 仅需要保证在一个局域网中即可。除了这些区别,一般而言,在数据采集的指令上是没有多大区别的。

串口接入

串口接入需要安装库:

pip install pyserial

接入方法:

import serial

ser = serial.Serial('COM3', 9600)
while True:
    try:
        data = ser.read(1)
    except:
        break

socket接入

socket接入方式其实也还是有两种:程序作为客户端、程序作为服务端

作为客户端

import socket

client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(('192.168.2.113', 5000))
client.settimeout(60)

client.sendall('登录包信息')

# 开启线程获取数据
receive_thread = threading.Thread(target=receive_handle, args=())
receive_thread.start()
# 开启线程发送数据
send_thread = threading.Thread(target=send_handle, args=())
send_thread.start()

作为服务端

from socketserver import TCPServer, ThreadingMixIn

class CustomServer(TCPServer):
    allow_reuse_address = True

    def __init__(self, server_address, RequestHandlerClass, bind_and_activate=True):
        TCPServer.__init__(self, server_address, RequestHandlerClass, bind_and_activate=bind_and_activate)


class CustomThreadingTCPServer(ThreadingMixIn, CustomServer):
    pass
    
class Handle(socketserver.BaseRequestHandler):
    pass
    
server = CustomThreadingTCPServer(
        ('0.0.0.0', 6600),
        Handle
    )
server.daemon_threads = True
server.serve_forever()

这里有个技巧:通过 bind_and_activate为True,可以在 Linux 系统下实现迅速重启,否则需要等待资源释放后才能重启。

2、信号保存

成功接入信号以后,我们就可以将 振动信号 保存在一些文件中,例如 txt

信号文件

3、信号分析

我们可以首先通过 matplotlib 来绘制信号,首先安装库:

pip install matplotlib

绘制信号代码

# -*- coding: utf-8 -*-
from matplotlib import pyplot as plt
import matplotlib

matplotlib.use('TKAgg')

if __name__ == '__main__':
    path = 'xxxx.txt'

    data = []
    with open(path, 'r') as f:
        for line in f:
            try:
                v = float(line)
                data.append(v)
            except:
                continue

    plt.plot(data)
    plt.show()

信号绘制

可以看到信号被成功绘制出来了,然后我们将 振动数据转换为音频数据
首先安装库:

pip install scipy

转换代码

import numpy as np
from scipy import interpolate

def resample( values, original_sampling_rate=200, target_sampling_rate=44100):
    time_values = np.linspace(0, len(values) * (1 / original_sampling_rate), len(values))
    f = interpolate.interp1d(time_values, values, kind='cubic')

    new_time_values = np.linspace(0, len(values) * (1 / original_sampling_rate),
                                  int(target_sampling_rate / original_sampling_rate * len(values)))
    vibration_array = f(new_time_values)

    return vibration_array

def make_audio(values=[], sampling_rate=200, target_sampling_rate=8000):
    values = np.array(values)
    resample_values = resample(values, sampling_rate, target_sampling_rate)

    min_value = -1
    max_value = 1
    # 进行最小-最大归一化
    normalized_num = (resample_values - resample_values.min()) / (resample_values.max() - resample_values.min()) * (
            max_value - min_value) + min_value
    avg = sum(normalized_num) / len(normalized_num)
    normalized_num = [v - avg for v in normalized_num]
    return normalized_num

由于振动传感器的采集仪采样频率不一定很高,所以我们需要将振动的频率通过 升采变为音频频率

得到数据后,我们将其转换为 音频文件,首先需要安装库。

pip install soundfile

转换音频文件

import soundfile as sf

audio_data = make_audio(data, 200, 8000)
sf.write('test.wav', audio_data, 8000)

4、音频处理

转换出来的音频文件,可能人的声音不是特别清晰,我们可以使用开源软件进行处理。

下载 Audacity ,它是一个开源的音频处理软件,地址是:https://www.audacityteam.org/

通过它,我们就可以调整生成的音频质量:

软件界面

结尾

目前,文章中的音频处理是在软件中的,其实在代码中通过一些算法就可以调整声音的输出,我就不在这篇文章展开了,感兴趣的可以去了解了解 滤波、谱减法、小波等算法

相关推荐

Linux 网络协议栈_linux网络协议栈

前言;更多学习资料(包含视频、技术学习路线图谱、文档等)后台私信《资料》免费领取技术点包含了C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,Z...

揭秘 BPF map 前生今世_bpfdm

1.前言众所周知,map可用于内核BPF程序和用户应用程序之间实现双向的数据交换,为BPF技术中的重要基础数据结构。在BPF程序中可以通过声明structbpf_map_def...

教你简单 提取fmpeg 视频,音频,字幕 方法

ffmpeg提取视频,音频,字幕方法(HowtoExtractVideo,Audio,SubtitlefromOriginalVideo?)1.提取视频(ExtractVi...

Linux内核原理到代码详解《内核视频教程》

Linux内核原理-进程入门进程进程不仅仅是一段可执行程序的代码,通常进程还包括其他资源,比如打开的文件,挂起的信号,内核内部的数据结构,处理器状态,内存地址空间,或多个执行线程,存放全局变量的数据段...

Linux C Socket UDP编程详解及实例分享

1、UDP网络编程主要流程UDP协议的程序设计框架,客户端和服务器之间的差别在于服务器必须使用bind()函数来绑定侦听的本地UDP端口,而客户端则可以不进行绑定,直接发送到服务器地址的某个端口地址。...

libevent源码分析之bufferevent使用详解

libevent的bufferevent在event的基础上自己维护了一个buffer,这样的话,就不需要再自己管理一个buffer了。先看看structbufferevent这个结构体struct...

一次解决Linux内核内存泄漏实战全过程

什么是内存泄漏:程序向系统申请内存,使用完不需要之后,不释放内存还给系统回收,造成申请的内存被浪费.发现系统中内存使用量随着时间的流逝,消耗的越来越多,例如下图所示:接下来的排查思路是:1.监控系统中...

彻底搞清楚内存泄漏的原因,如何避免内存泄漏,如何定位内存泄漏

作为C/C++开发人员,内存泄漏是最容易遇到的问题之一,这是由C/C++语言的特性引起的。C/C++语言与其他语言不同,需要开发者去申请和释放内存,即需要开发者去管理内存,如果内存使用不当,就容易造成...

linux网络编程常见API详解_linux网络编程视频教程

Linux网络编程API函数初步剖析今天我们来分析一下前几篇博文中提到的网络编程中几个核心的API,探究一下当我们调用每个API时,内核中具体做了哪些准备和初始化工作。1、socket(family...

Linux下C++访问web—使用libcurl库调用http接口发送解析json数据

一、背景这两天由于一些原因研究了研究如何在客户端C++代码中调用web服务端接口,需要访问url,并传入json数据,拿到返回值,并解析。 现在的情形是远程服务端的接口参数和返回类型都是json的字符...

平衡感知调节:“系统如人” 视角下的架构设计与业务稳定之道

在今天这个到处都是数字化的时代,系统可不是一堆冷冰冰的代码。它就像一个活生生的“数字人”,没了它,业务根本转不起来。总说“技术要为业务服务”,但实际操作起来问题不少:系统怎么才能快速响应业务需求?...

谈谈分布式文件系统下的本地缓存_什么是分布式文件存储

在分布式文件系统中,为了提高系统的性能,常常会引入不同类型的缓存存储系统(算法优化所带来的的效果可能远远不如缓存带来的优化效果)。在软件中缓存存储系统一般可分为了两类:一、分布式缓存,例如:Memca...

进程间通信之信号量semaphore--linux内核剖析

什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)所拥有。信号量的值为正的时候,说明它空闲。所测试的线程可以锁定而使用它。若为0,说明它被占用,测试的线程要进入睡眠...

Qt编写推流程序/支持webrtc265/从此不用再转码/打开新世界的大门

一、前言在推流领域,尤其是监控行业,现在主流设备基本上都是265格式的视频流,想要在网页上直接显示监控流,之前的方案是,要么转成hls,要么魔改支持265格式的flv,要么265转成264,如果要追求...

30 分钟搞定 SpringBoot 视频推拉流!实战避坑指南

30分钟搞定SpringBoot视频推拉流!实战避坑指南在音视频开发领域,SpringBoot凭借其快速开发特性,成为很多开发者实现视频推拉流功能的首选框架。但实际开发中,从环境搭建到流处理优...

取消回复欢迎 发表评论: