GNU Radio使用Python Block实现模块运行时间间隔获取

文章目录

  • 前言
  • [一、timestamp_sender 模块](#一、timestamp_sender 模块)
  • [二、timestamp_receiver 模块](#二、timestamp_receiver 模块)
  • 三、测试

前言

GNU Radio 中没有实现测量两个模块之间的时间测量模块,本文记录一下通过 python block 制作一个很简单的测时 block。


一、timestamp_sender 模块

使用 python block 做一个发送端时间戳记录模块,并添加下面的代码:

python 复制代码
"""
Embedded Python Blocks:

Each time this file is saved, GRC will instantiate the first class it finds
to get ports and parameters of your block. The arguments to __init__  will
be the parameters. All of them are required to have default values!
"""

import numpy as np
from gnuradio import gr
import time
import numpy as np

class timestamp_sender(gr.sync_block):  # other base classes are basic_block, decim_block, interp_block
    """Embedded Python Block example - a simple multiply const"""

    def __init__(self):  # only default arguments here
        """arguments to this function show up as parameters in GRC"""
        gr.sync_block.__init__(
            self,
            name="timestamp_sender",   # will show up in GRC
            in_sig=None,
            out_sig=[np.float32]
        )
        self.kk = 1;
        
        # if an attribute with the same name as a parameter is found,
        # a callback is registered (properties work, too).

    def work(self, input_items, output_items):
        # Record the current time
        start = np.float32(time.perf_counter())
        
        # Output data and the current timestamp (here using a simple value for demonstration)
        output_items[0][:] = [start for _ in output_items[0]]
        
        if self.kk == 1:
            self.kk = 2;
            print(f"output_items[0][:] = {output_items[0][:]}");
        
        return len(output_items[0])

二、timestamp_receiver 模块

使用 python block 做一个接收端时间戳记录模块,并添加下面的代码:

python 复制代码
"""
Embedded Python Blocks:

Each time this file is saved, GRC will instantiate the first class it finds
to get ports and parameters of your block. The arguments to __init__  will
be the parameters. All of them are required to have default values!
"""

import numpy as np
from gnuradio import gr
import numpy as np  # 导入NumPy库
import time

class timestamp_receiver(gr.sync_block):  # other base classes are basic_block, decim_block, interp_block
    """Embedded Python Block example - a simple multiply const"""

    def __init__(self):  # only default arguments here
        """arguments to this function show up as parameters in GRC"""
        gr.sync_block.__init__(
            self,
            name="timestamp_receiver",   # will show up in GRC
            in_sig=[np.float32],
            out_sig=None
        )
        # if an attribute with the same name as a parameter is found,
        # a callback is registered (properties work, too).
        self.kk = 1

    def work(self, input_items, output_items):
        for item in input_items[0]:
            if item == 0:
                continue
            if self.kk == 1:
                self.kk = 2
                end = np.float32(time.perf_counter())
                print(f"input_items[0] = {input_items[0]}")
                print(f"Received at {end}, interval since sent: {(end - item) * 1000000} Microsecond")

        return len(input_items[0])

三、测试

按照下图将 block 进行连接:

采样率 32KHz,延时 320 * 5 = 160000 个采样点,大约 5s 的时间

打印信息:

bash 复制代码
Generating: '/home/gnep/ofdm_usrp/test.py'

Executing: /usr/bin/python3 -u /home/gnep/ofdm_usrp/test.py

Press Enter to quit: output_items[0][:] = [7809.57 7809.57 7809.57 ... 7809.57 7809.57 7809.57]
item = 7809.56982421875
input_items[0] = [   0.      0.      0.   ... 7809.57 7809.57 7809.57]
Received at 7814.44189453125, interval since sent: 4872070.3125 Microsecond

可以看到打印信息为 4872070.3125 ,大约为 5s 时间


我的qq:2442391036,欢迎交流!


相关推荐
Jonathan Star29 分钟前
MediaPipe 在Python中实现人体运动识别,最常用且高效的方案是结合**姿态估计**(提取人体关键点)和**动作分类**(识别具体运动)
开发语言·python·分类
山顶听风1 小时前
分页条初始化
python
NewsMash1 小时前
PyTorch之父发离职长文,告别Meta
人工智能·pytorch·python
硅农深芯2 小时前
如何使用ptqt5实现进度条的动态显示
开发语言·python·qt
程序员杰哥2 小时前
软件测试之压力测试详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·压力测试
今天没有盐2 小时前
Pandas完全指南:从Series到DataFrame,掌握数据分析核心技能
python·pycharm·编程语言
暴风鱼划水2 小时前
算法题(Python)数组篇 | 4.长度最小的子数组
python·算法·力扣
B站计算机毕业设计之家2 小时前
大数据python招聘数据分析预测系统 招聘数据平台 +爬虫+可视化 +django框架+vue框架 大数据技术✅
大数据·爬虫·python·机器学习·数据挖掘·数据分析
新手村领路人3 小时前
python打包成exe
python·打包