使用Octave分析GNU Radio的数据
Octave 是 GNU Radio 的最流行的分析工具,因此 GNU Radio 软件包也包含它自身的一组脚本用于读取和语法分析输出。本文介绍如何使用 Octave 分析 GNU Radio 产生的数据, 并解决"error: 'read_complex_binary' undefined"这类错误信息!
1. 安装Octave
在 Ubuntu 下使用如下命令安装 Octave
$ sudo apt-get install octave
为了可以使用 GNURadio 的 Octave 脚本,你必须将 gnuradio 的路径添加了 Octave 的路径变量中。可以通过配置~/.octaverc文件完成。将gnuradio的路径命令添加到 .octaverc 文件中.具体方法为:
1) 打开新终端(Ctrl + Alt + t)
$ gedit .octaverc
2) 在.octaverc文件中输入如下, 根据gnuradio所在路径与版本自行修改, 然后保存退出即可.
addpath("/home/hao/software/gnuradio-3.7.5.1/gr-utils/octave")
如果不执行上面的步骤, 在调用函数 read_complex_binary() 则会产生error: error: 'read_complex_binary' undefined near line column
从语法上分析 GNU Radio 的数据输出,最便捷的方法便是使用 GNU Radio 提供的脚本。如上安装指导所示,确保把 GNU Radio 的脚本的路径已经添加到 Octave 的路径中。这便可帮助读取那些被使用 gr.file_sink (大小、文件名) 顷倒到磁盘的数据。
下 面的方法函数是基于参数 size 的用在 gr.file_sink() 内的,它把文件名作为第一个参数、第二个参数是可选项,它表示了从文件中要读取的数量。
read_complex_binary(): gr.sizeof_gr_complex
read_float_binary(): gr.sizeof_float
read_int_binary(): gr.sizeof_int
read_short_binary(): gr.sizeof_short
read_char_binary(): gr.sizeof_char
比如:在 Python 脚本中,使用 gr.file_sink(gr.sizeof_gr_complex, "capture.dat") 获取了 64 位的复合数据如下:
c = read_complex_binary('capture.dat');
从 USRP 直接能获取的数据是以 32 位复合数据形式存储的,而不是 64 位复合型 (gr.sizeof_gr_complex)。为了能读取此数据,首先,使用 read_short_binary() 然后将其分离进入 - a two dimensional vector 如下:
d = read_short_binary(data);
c = split_vect(d, 2);
2. 安装gnuplot
使用 Octave 来绘制数据,最简便的方法是使用 gnuplot。在 Ubuntu 上键入如下命令:
$ sudo apt-get install gnuplot gnuplot-doc
在时间轴上的 I 和 Q,可如下分别地绘制各个元素:
plot([real(c), imag(c)])
如下可生成一个 I/Q 曲线(x 表示 I, y 表示 Q):
plot(c)
3. 举例说明
例子背景: LTE下行数据链路中, 每个帧1ms, 每个帧包含10个子帧, 每个子帧包含14个 OFDM 符号, 在3M带宽条件下, 其时频资源格为14 * 180的 std::vector <std::vector<gr_complex> > 类型. 在发端2天线, 收端2天线的LTE MOMI-OFDM无线通信系统中, 进行信道估计和插值后得到插值后的信道估计值, 或称信道特征矩阵. 其类型也为 std::vector <std::vector<gr_complex> > 使用如下C++程序, 将信道特征矩阵存入本地文件, 2×2 MIMO 可以得到4个信道特征矩阵(s00, s01, s10, s11):
for (int i = ; i < d_channel_estimate_s00.size(); ++i)
{
dump_array("s00.dat", &d_channel_estimate_s00[i][], d_channel_estimate_s00[i].size());
}
for (int i = ; i < d_channel_estimate_s01.size(); ++i)
{
dump_array("s01.dat", &d_channel_estimate_s01[i][], d_channel_estimate_s01[i].size());
}
for (int i = ; i < d_channel_estimate_s10.size(); ++i)
{
dump_array("s10.dat", &d_channel_estimate_s10[i][], d_channel_estimate_s10[i].size());
}
for (int i = ; i < d_channel_estimate_s11.size(); ++i)
{
dump_array("s11.dat", &d_channel_estimate_s11[i][], d_channel_estimate_s11[i].size());
}
其中dump_array()函数的定义如下:
template <typename T>
static void dump_array(const char* filename, T* arr, int len)
{
std::string sname = filename;
FILE* f = fopen(sname.c_str(), "ab+");//"ab+"是可读可写追加方式的打开一个二进制文件
fwrite(arr, sizeof(T), len, f);//fwrite(buffer, size, count, fp);//从buffer地址读size*count个字节写到f文件中.
fclose(f);
}
如果数据为 std::vector<gr_complex> 类型, 可以这样调用dump_array()函数
dump_array("fd_user_data_subf_1tx1rx_before.dat", &fd_user_data[], fd_user_data.size());
使用 Octave 对这4个信道特征矩阵(s00, s01, s10, s11)进行分析, 代码如下(文件名为test.m):
a = read_complex_binary('s00.dat', );
plot(abs(a), 'b+');
title("");
figure;
b = read_complex_binary('s01.dat', );
plot(abs(b), 'ro');
title("");
figure;
c = read_complex_binary('s10.dat', );
plot(abs(c), 'g-');
title("");
figure;
d = read_complex_binary('s11.dat', );
plot(abs(d), 'bo');
title("");
运行程序:
$ octave
octave:> test
注意: 如果没有把 gnuradio 的脚本的路径已经添加到 Octave 的路径中, 将会有如下提示错误
error: 'read_complex_binary' undefined near line column
4. 使用Octave画星座图:
以QPSK调制为例, 用前面所述的dump_array()函数, 将接收端均衡前后的数据存到文件里, 然后使用Octave处理数据, 程序如下:(文件名: plot_scatter.m)
a = read_complex_binary('before.dat', );
a1 = real(a);
a2 = imag(a);
scatter(a1, a2);
title("Before Equalization");
figure;
b = read_complex_binary('after.dat', );
b1 = real(b);
b2 = imag(b);
scatter(b1, b2);
title("After Equalization");
运行结果如下, 左图为均衡前, 又图为均衡后

用Python作为Octave和Matlab之外的另一个选择
很有可能你已经安装了一些Python的科学分析包,例如SciPy和NumPy (特别是Matplotlib)。利用这些工具,你可以使用Python来绘制或者分析数据。
本文地址:
http://www.cnblogs.com/moon1992/p/5717706.html
参考连接:
使用Octave分析GNU Radio的数据的更多相关文章
- [SDR] GNU Radio 系列教程(二) —— 绘制第一个信号分析流程图
目录 1.前言 2.启动 GNU Radio 3.新增块 4.运行 本文视频 参考链接 1.前言 本文将介绍如何在 GNU Radio 中创建和运行第一个流程图. 2.启动 GNU Radio GNU ...
- GNU Radio 入门培训
1. GNU Radio介绍 1.1 什么是GNU Radio GNU Radio是一个完全开源的软件无线电结构平台,它可以用来设计和仿真,也可以用来连接真实的无线电系统.GNU Radio是一个高度 ...
- [SDR] GNU Radio 系列教程(一) —— 什么是 GNU Radio
目录 1.GNU Radio 是什么 2.我为什么要用 GNU Radio 3.数字信号处理 3.1 一点信号理论 3.2 将数字信号处理应用于无线电传输 4.基于流程图的模块化数字信号处理方法 本文 ...
- GNU Radio: Overview of the GNU Radio Scheduler
Scetion 1: The Flowgraph The flowgraph moves data from sources into sinks. 一个流图由多个模块组成,其中一般包括信源(Sour ...
- GNU Radio: Synchronization and MIMO Capability with USRP Devices
Application Note Synchronization and MIMO Capability with USRP Devices Ettus Research Introduction S ...
- GNU Radio: USRP2 and N2x0 Series
Comparative features list 相对性能清单 Hardware Capabilities: 1 transceiver card slot External PPS referen ...
- GNU Radio在SDR领域的应用
1 Software Defined Radio 软件无线电(Software Defined Radio,SDR)是一种实现无线通信的新概念和体制.其中以往只能在硬件中实现的组件(例如混频器,滤波器 ...
- 【译】GNU Radio How to write a block 【如何开发用户模块及编写功能块】
本文讲解如何在GNU Radio中添加用户开发的信号处理模块,译文如有不当之处可参考原文地址:http://gnuradio.microembedded.com/outoftreemodules Ou ...
- GNU Radio Radar Toolbox
GNU Radio Radar Toolbox Install guide Change to any folder in your home directory and enter followin ...
随机推荐
- HDU 4665 Mutiples on a circle (圆环DP)
题意 N个数的圆环上有多少种方案可以使得选出来的一段数是K的倍数(N<=50000, K<=200, a[i]<=1000). 思路 多校第七场1004.圆上的DP--大脑太简单处理 ...
- python sort与sorted使用笔记
Python list内置sort()方法用来排序,也可以用python内置的全局sorted()方法来对可迭代的序列排序生成新的序列 一,最简单的排序 1.使用sort排序 my_list = [3 ...
- SSH 暴力破解趋势——植入的恶意文件属 DDoS 类型的恶意文件最多,接近70%,包括 Ganiw、 Dofloo、Mirai、 Xarcen、 PNScan、 LuaBot、 Ddostf等家族。此外挂机、比特币等挖矿程序占5.21%
SSH 暴力破解趋势:从云平台向物联网设备迁移 | 云鼎实验室出品 from: http://www.freebuf.com/articles/paper/177473.html 导语:近日,腾讯云发 ...
- js点击复制功能的实现
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- HDU 5793 A Boring Question (找规律 : 快速幂+乘法逆元)
A Boring Question Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others ...
- QMainWindow: No such file or directory 问题的解决方法
这种问题往往是由于QT4的程序转换到QT5所导致的,在.pro文件中加上一句 greaterThan(QT_MAJOR_VERSION, 4): QT += widgets 就可以解决问题
- L163
Chickens slaughtered in the United States, claim officials in Brussels, are not fit to grace Europea ...
- js中top、self、parent
1.在应用iframe或者frameset的时候 parent指的是父窗口.top指的是顶级的窗口.self指的是当前的窗口-window window.self 功能:是对当前窗口自身的引用.它和w ...
- softmax的多分类
关于多分类 我们常见的逻辑回归.SVM等常用于解决二分类问题,对于多分类问题,比如识别手写数字,它就需要10个分类,同样也可以用逻辑回归或SVM,只是需要多个二分类来组成多分类,但这里讨论另外一种方式 ...
- EasyPusher/EasyDarwin支持H.265 RTSP/RTP直播推流与分发播放
前言描述 随着大屏时代和高清时代的到来,人们已经不再满足于VGA.CIF这种小分辨率了,取而代之的是720P.1080P.4K级的视频传输,虽然我们国家的基础带宽一直在上升,但普遍情况下,传输高清视频 ...