超声波网络 (TCP/IP on Audio)

简介: 我们借助于 Gnuradio 和一个麦克风和扬声器,展示了跨超声波频率的网络互连的实现. 这允许你通过一个音频连接来使用 TCP/IP,UDP 协议。

介绍

我们借助于 Gnuradio 和一个麦克风和扬声器,展示了跨超声波频率的网络互连的实现. 这允许你通过一个音频连接来使用 TCP/IP,UDP 协议。


为了实践这个教程,我们建议你使用Gnuradio的LiveDVD发行版(它就是一个已经简单安装了gnuradio的Ubuntu发行版). 这可以很容易的从 http://gnuradio.org/redmine/news/31 下载到. 首先你需要将我们为Gnuradio创建的补丁包下载到一个USB记忆棒上面. 你可以从 https://github.com/anfractuosity/ultrasonicnetworking/archive/master.zip 下载到这个补丁包. 为了使用这个补丁包,你需要root权限,因此请输入‘sudo bash’, 然后解压这个补丁包, 然后通过输入 ./setup.sh 简单的运行 setup.sh. 安装文件简单的为Gnuradio的分组编码器和译码器打上了补丁,以支持可变长的分组数据包。


运行完 setup.py 之后, 你就可以对 Gnuradio 进行初始化了, 这里你需要以root权限运行, 因此请输入 sudo gnuradio-companion. 而然后在你的第一台笔记本上面加载 a.grc。

图1 描述了我们使用超声波网络的图示. 我们现在将描述图中所示的每一块的功能. 第一块是左上角,TUNTAP PDU, 它允许你创建一个虚拟网络接口, 通过这个虚拟网络接口我们可以发送和接收包。


我们使用“PDU 到标记的流”这块功能来将来自虚拟NIC的包,转换成可以为编码补丁处理的二进制流. 我们不能直接将被标记流的输出附加到GFSK调制器上, 因为我们需要通过使用CRC向其中加入一个效验码,并且我们也需要添加一个序言和头到数据包上 – 这都是借助于数据包编码器的使用来实现的。

序言本质上就是一系列的位, 它可以在接收器的末端检测到, 为了将位正确的对齐到正确的字节码边界. 包编码器还在序言后面加入了一个头, 它使用字节的形式描述了包有多长.

图. 1

image.png

GFSK 调制器本质上就是进行频移键控调制。如你在图2中可以看到的, 被调制过的信号频率, 当一个 ’0′ 被发送时, 一个′1'就会被发送. 我们发现在使用笔记本电脑和麦克风扬声器的超声波网络环境中, FSK 的表现比 PSK 要好(相移键控Phase Shift Keying – 它利用的是相变来交换位), 这是另外的一种调制技术。

image.png

GFSK 块一个非常重要的方面是样本/符号的数量. 我们将这个设置为9. 它的意思是,调制器每接收一个符号,都将会生成9个样本. 这个数字越高信号对噪音越有弹性, 但是波特率相应的会越低(这本质上意味着它需要发送数据包的时间更长).

波特率表示每分钟被传输的符号数量。

然后我们使用合理重新采样器,来使得使得信号更具弹性. 每一个进入的样本, 它都会有 320 个输出.

我们使用了一个频率翻译FIR过滤器, 来翻译进入信号的频率. 我们通过carrier_tx来偏移信号, 在此例中是-19kHz. 这样可以让信号偏移出人类听力可及的范围。

因为在这一点上我们一直使用复数信号进行工作,我们需要将复数输出转换成声卡可用的浮点数输出。我们通过“复数转实数”块来实现它。

图的底部,描述了程序的接收器部分。它本质上也是执行了相同的功能,就是逆序了。

在“复数转实数”块后,仍然有2个其它块。乘常数块,可以让你将麦克风的输出乘上一个固定数。这个块之后是带通滤波器,它仅允许小范围的频率可以通到解调器,这有助于去除存在于麦克风输出中的大量噪音。

在图示3中,你会看到两张图片. 上面的图片展示了向信号传输器的输出,而下面的图片则展示了来自麦克风的输入(后面带上了一个适用于它的带通过滤器). 上面的图片的顶部还出现了一个滑块,让你可以用一个指定的值同来自麦克风的信号相乘. 当在使用两台相距甚远的笔记本电脑通信时这回很有用。

图示. 3

image.png

双工

图 4 描述了我们所用的全双工信号。在这个例子中,你可以看到传输所用的两个不同的频率,19kHz 与 18kHz。这允许两个笔记本同时发送他们自己的信号。

图 4

image.png

设置

在 Gnuradio-companion 里,你需要切换到 Build > Execute,来执行图中的例子。之后你需要对它为你创建的 tap0 接口指定一个 IP 地址。你需要通过终端来进行这个操作,例如输入

sudo ifconfig tap0 192.168.1.10

你需要在第二台笔记本 B 上执行同样的操作步骤,但这次不是加载 b.grc,而是使用 sudo ifconfig tap0 192.168.1.20 。

我们发现,最好是手工指定每台笔记本的 ARP 记录。为了指定一个 ARP 记录,在笔记本 A 上,执行 arp -s 192.168.1.20 -i tap0

你在两台笔记本上预置的拷贝补丁文件到 Gnuradio 里的安装脚本,和修改 TCP 选项一样,都是为了让 TCP/IP 可以工作在延迟非常大的网络上。

echo 100 > /proc/sys/net/ipv4/tcp_syn_retries

echo 0 > /proc/sys/net/ipv4/tcp_syncookies

echo 100 > /proc/sys/net/ipv4/tcp_synack_retries


第一行是必要的,为了让客户端的 TCP 连接在关闭前,处于打开状态的时间长于默认的 20 秒。


测试

为了测试网络功能运行正确,我们推荐适用netcat. 测试 TCP/IP 连通性可以在笔记本电脑A上面使用 netcat -vv -l 10000, 而用笔记本电脑B上使用 netcat -vv 192.168.1.10 10000 连接它. 因为我们使用了详细(verbose )选项, netcat 将会在已经有同笔记本电脑A的连接被确认时通知你, 然后你就可以在两边都发送文本了.


Gnuradio 补丁包

由于Gnuradio提供的编码和解码补丁包只能工作于固定数量大小的数据, 为了支持对流标记的图取,对这些数据的修改是必要的. “PDU标记流”标记来自笔记本电脑段接口附上数据大小的打包. 编码/解码补丁包不能正常的处理这些标记, 因此为了读取这些标记,我们修改了数据包编码器, 并且生成了同来自笔记本电脑0帧相近大小的数据包. 而数据包解码器则解开数据包的封装, 并且用它的数据大小标记结果数据.

相关文章
|
2月前
|
网络协议 Linux 虚拟化
配置VM网络:如何设定静态IP以访问主机IP和互联网
以上就是设定虚拟机网络和静态IP地址的基本步骤。需要注意的是,这些步骤可能会因为虚拟机软件、操作系统以及网络环境的不同而有所差异。在进行设定时,应根据具体情况进行调整。
331 10
|
7月前
|
域名解析 网络协议 安全
计算机网络TCP/IP四层模型
本文介绍了TCP/IP模型的四层结构及其与OSI模型的对比。网络接口层负责物理网络接口,处理MAC地址和帧传输;网络层管理IP地址和路由选择,确保数据包准确送达;传输层提供端到端通信,支持可靠(TCP)或不可靠(UDP)传输;应用层直接面向用户,提供如HTTP、FTP等服务。此外,还详细描述了数据封装与解封装过程,以及两模型在层次划分上的差异。
1384 13
|
5月前
|
监控 安全 Go
使用Go语言构建网络IP层安全防护
在Go语言中构建网络IP层安全防护是一项需求明确的任务,考虑到高性能、并发和跨平台的优势,Go是构建此类安全系统的合适选择。通过紧密遵循上述步骤并结合最佳实践,可以构建一个强大的网络防护系统,以保障数字环境的安全完整。
139 12
|
12月前
|
负载均衡 网络协议 网络性能优化
动态IP代理技术详解及网络性能优化
动态IP代理技术通过灵活更换IP地址,广泛应用于数据采集、网络安全测试等领域。本文详细解析其工作原理,涵盖HTTP、SOCKS代理及代理池的实现方法,并提供代码示例。同时探讨配置动态代理IP后如何通过智能调度、负载均衡、优化协议选择等方式提升网络性能,确保高效稳定的网络访问。
1168 2
|
6月前
|
监控 安全 网络安全
网络安全新姿势:多IP配置的五大好处
服务器配置多IP地址,既能提升网络速度与安全性,又能实现多站点托管和故障转移。本文详解多IP的五大妙用、配置方法及进阶技巧。从理论到实践,合理规划IP资源,让服务器性能跃升新高度。
209 2
|
9月前
|
网络协议 物联网
VB6网络通信软件上位机开发,TCP网络通信,读写数据并处理,完整源码下载
本文介绍使用VB6开发网络通信上位机客户端程序,涵盖Winsock控件的引入与使用,包括连接服务端、发送数据(如通过`Winsock1.SendData`方法)及接收数据(利用`Winsock1_DataArrival`事件)。代码实现TCP网络通信,可读写并处理16进制数据,适用于自动化和工业控制领域。提供完整源码下载,适合学习VB6网络程序开发。 下载链接:[完整源码](http://xzios.cn:86/WJGL/DownLoadDetial?Id=20)
351 12
|
8月前
|
域名解析 API PHP
VM虚拟机全版本网盘+免费本地网络穿透端口映射实时同步动态家庭IP教程
本文介绍了如何通过网络穿透技术让公网直接访问家庭电脑,充分发挥本地硬件性能。相比第三方服务受限于转发带宽,此方法利用自家宽带实现更高效率。文章详细讲解了端口映射教程,包括不同网络环境(仅光猫、光猫+路由器)下的设置步骤,并提供实时同步动态IP的两种方案:自建服务器或使用三方API接口。最后附上VM虚拟机全版本下载链接,便于用户在穿透后将服务运行于虚拟环境中,提升安全性与适用性。
439 7
|
10月前
|
安全 网络安全 UED
为何长效代理静态IP是网络管理的关键要素
在信息化时代,静态长效IP代理对网络管理至关重要。它能提升网络服务质量,确保远程办公、视频会议等应用的稳定性和连续性;减少延迟和网络拥堵,加快数据传输;提高网络安全,便于设置访问权限,防止未授权访问。91HTTP高质量代理IP服务商助力高效信息获取。
217 23
|
11月前
|
网络协议 Unix Linux
深入解析:Linux网络配置工具ifconfig与ip命令的全面对比
虽然 `ifconfig`作为一个经典的网络配置工具,简单易用,但其功能已经不能满足现代网络配置的需求。相比之下,`ip`命令不仅功能全面,而且提供了一致且简洁的语法,适用于各种网络配置场景。因此,在实际使用中,推荐逐步过渡到 `ip`命令,以更好地适应现代网络管理需求。
505 11

热门文章

最新文章