海纳百客

海纳百客

使用 Raspberry Pi 安装的 DAQ 测量加速度计

吃瓜阿阳

友情提示点击顶部放大镜 可以使用站内搜索 记住我们的地址 www.hainabaike.com

如何使用安装在树莓派上的 DAQ 测量加速度计

IEPE(集成电子压电)传感器用于测量加速度、压力或力。这些类型的压电传感器包含内置的独立转换电子设备,用于将来自压电传感器的信号转换为低阻抗电压信号。
该项目将演示如何使用 MCC 172 DAQ HAT(与 Raspberry Pi 结合使用)来测量从此类传感器接收到的信号。使用的传感器用于振动,可以安装在不同的地方,以监测不同设备的状态。

所需的硬件和软件

该项目使用 MCC 172 IEPE Measurement DAQ HAT 和 Raspberry Pi 读取输出 IEPE 传感器。该项目使用的传感器是 805 加速度计 500G IEPE T05-3(data sheet)。面包板和电线用于连接到 HAT 通道,如下所示。
在软件方面,需要以下内容:
– Raspbian OS
– GIT
– Python libraries
– MCC DAQ HAT Libraries

设置必要的软件

要将 MCC 172 DAQ HAT 与 Raspberry Pi 一起使用,首先要做的是安装制造商提供的库。
以下是步骤:
1.如果使用图形界面,请打开终端窗口并更新您的包列表:

sudo apt update

2.可选:更新已安装的软件包并重新启动:

sudo apt full-upgrade
sudo reboot

3.如果未安装安装 git:

sudo apt install git

4.使用 git 将制造商提供的软件包下载到您的用户文件夹:

cd ~
git clone https://github.com/mccdaq/daqhats.git

5.安装库。安装程序将询问您是否要安装 Python 2 和 Python 3 支持。

cd ~/daqhats
sudo ./install.sh

要执行固件更新或阅读有关 MCC 172 的更多信息,请访问 MCC DAQ HAT Library documentation.

设置硬件

对于这个项目,我们将使用 IEPE 传感器。 TE Connectivity 的 805-0500 是一款 3 针 IEPE 低成本加速度计,非常适合使用 TO-5 接头的嵌入式应用。 该型号传感器具有 500g 的动态范围和高达 12kHz 的宽带宽。 该传感器可以使用粘合剂安装到要监测的结构上。 在这个项目中,传感器将使用面包板上的 3 个引脚安装,将引脚连接到 MCC 172 的通道以方便使用。 在制造数据表中,它指定了引脚功能。 引脚 1 是传感器的输出,作为参考,传感器封装有一个缺口(如下图所示),接地引脚是相反的。

图 1:传感器连接端口

图 2:传感器 +OUT 引脚

下一步是将输出和接地连接到 MCC 172 的通道 0 输入。市场上有几种类型的 IEPE 传感器连接器,但对于这种传感器,我们将使用螺钉连接器牢固地连接通向 传感器。 该项目的代码以这样一种方式编写,即如果需要,通道 2 也用于第二个传感器。

图 3:连接到 MCC 172

程序流程

挂载组件和安装库后,下面附加的两个文件必须保存在同一个文件夹中。 “daqhats_utils.py”取自示例文件夹,它位于执行使用 git 安装库的步骤后安装的“daqhats”文件夹中。 “main.py”是这个项目的主文件。
– 下载 main.py
– 下载 daqhats_utils.py (确保它与 main.py 位于同一文件夹中)

导入库


要执行测量,我们需要 git 存储库和 daqhats_utils 中的库中提供的一些函数。 我们导入整个 MCC 118 类和一些帮助函数。 “OptionFlags” 用于设置扫描 HAT 上通道提供的值的模式,并使用“HatIDs”和“HatError”函数识别 id 和错误。

读取和显示数据

total_samples_read = 0
read_request_size = READ_ALL_AVAILABLE
dt_string = date_time.strftime(“%d/%b/%Y/ %H:%M:%S”)#convert values store in the date_tame to string
print('

', dt_string, file=open('log.txt', 'a'))
print('
Samples Read    Scan Count       Channel 0       Channel 1', file=open('log.txt', 'a'))
timeout = 5.0
while True:
read_result = hat.a_in_scan_read(read_request_size, timeout)
# Check for an overrun error
if read_result.hardware_overrun:
print('

Hardware overrun
')
break
elif read_result.buffer_overrun:
print('

Buffer overrun
')
break
samples_read_per_channel = int(len(read_result.data) / num_channels)
total_samples_read += samples_read_per_channel
# Display the last sample for each channel,in a maximum number of 12 digits.
print('
{:12}'.format(samples_read_per_channel),
' {:12} '.format(total_samples_read), end='')
print('
{:12}'.format(samples_read_per_channel),
' {:12} '.format(total_samples_read), end='', file=open('log.txt', 'a'))
# 
 is use to write over the existing line
# Display the RMS voltage for each channel.
if samples_read_per_channel > 0:
for i in range(num_channels):
value = calc_rms(read_result.data, i, num_channels,
samples_read_per_channel)
# Display the value number of 10 digits and 5 digits after the comma
print('{:10.5f}'.format(value), 'Vrms ', end=”)
# save on a log file the value number of 10 digits and 5 digits after the comma
print('{:10.5f}'.format(value), 'Vrms ', end=”, file=open('log.txt', 'a'))
stdout.flush()
sleep(0.1)
print('
')

读数在循环中执行,直到用户停止扫描或检测到溢出错误。 读取所有可用样本(最大为 read_buffer 的大小)。 由于 read_request_size 设置为 -1 (READ_ALL_AVAILABLE),函数“hat.a_in_scan_read”立即返回当前可用的样本,超时参数被忽略。 函数“hat.a_in_scan_read”返回多个元素:运行、硬件溢出、缓冲区溢出、触发和超时,所有都是布尔类型,数据是浮点列表。 数据返回是我们接下来将用来显示从缓冲区读取的信息的数据。

samples_read_per_channel = int(len(read_result.data) / num_channels)
total_samples_read += samples_read_per_channel

“samples_read_per_channel”用于显示获取的数据列表中的编号,并显示它。 “total_samples_read”存储样本总数。 这些数字以 12 位数字格式显示。
如果缓冲区中有样本,则程序将开始显示。 对于每个通道,其结果保存到列表中的某个值,每个值的位置是所用通道数的倍数。 为了显示,我们使用一个索引,为每个读数保存每个通道上每个样本的位置。

f samples_read_per_channel > 0:
for i in range(num_channels):
value = calc_rms(read_result.data, i, num_channels, samples_read_per_channel)
# Display the value number of 10 digits and 5 digits after the comma
print('{:10.5f}'.format(value), 'Vrms ', end='')
# save on a log file the value number of 10 digits and 5 digits after the comma
print('{:10.5f}'.format(value), 'Vrms ', end=”, file=open('log.txt', 'a'))

对于终端中显示的每个值,每个显示值的副本都保存在日志文件中。 为此,在显示每个数据值后,我们有另一个以“file=open(‘log.txt’, ‘a’))”结尾的打印行是在 Python 中处理文件的函数,该函数需要两个参数:文件名和模式。 “a” 在此模式下,打开一个文件以进行追加,如果该文件不存在,将创建一个具有文件名的文件。

数值显示格式

def calc_rms(data, channel, num_channels, num_samples_per_channel): “”” Calculate RMS value from a block of samples. “””
value = 0.0
index = channel
for _i in range(num_samples_per_channel):
value += (data[index]* data[index]) / num_samples_per_channel
index += num_channels
return sqrt(value)

在终端中,缓冲值显示为 Vrms(均方根电压)。 RMS 值是瞬时值平方函数的平均值的平方根。 IEPE 传感器的输出是 8 到 12 V 之间的正弦偏移。比较 MCC 172 读取的这些值的一种方法是计算 RMS 值。 这个值比读取 DAQ 直接发送的值更容易解释。 在值显示在终端之前调用 calc_rms 函数。

for i in range(num_channels):
value = calc_rms(read_result.data, i, num_channels, samples_read_per_channel)

启动脚本

要启动 Python 脚本,请使用以下命令在保存两个文件的文件夹中打开一个终端。

python main.py

之后,终端中会出现 MCC 172 所在的地址。 回答问题以启用 IEPE,其中 y 表示是,n 表示否。 之后,终端应显示:如何设置 HAT(连续扫描)、IEPE 电源状态、正在使用的通道,以及最后设置为工作的扫描速率。 按下 ENTER 键后,程序将开始扫描。 第一次运行时,程序将创建一个日志文件。 第一行将包含开始和保存扫描的日期和时间。 然后在日志文件中,将终端中显示的数据保存在不同的行中。 再次执行程序时,数据将保存在上次写入的最后一行之后的同一个日志文件中。

图 4:终端显示

图 5:日志文件
显示的解释如下:
– Samples Read 是显示的样本数,在缓冲区填满后重置为 0。
– Scan Count 是读取的样本总数,当缓冲区已满时它不会重置并继续计数。
– 通道0 和通道1 是该通道读取的值。

结论

该项目是 MCC 172 DAQ HAT 如何与基于 IEPE 的加速度计一起用于监测突然运动或振动的示例。 借助其他 IEPE 传感器,还可以监测力和压力。 该代码无需任何修改即可使用其他类型的 IEPE 传感器。

    标签:

    发布评论 条评论)

    评论列表