当前位置:   article > 正文

基于FPGA的波束形成verilog开发_fpga波束形成

fpga波束形成

目录

一、理论基础

二、核心程序

三、仿真测试结果


一、理论基础

1.1 基于FPGA的波束形成理论概述

        基于FPGA的波束形成(Beamforming)是一种信号处理技术,用于控制阵列天线的方向性。它通过对阵列天线接收到的信号进行加权和相位调节,实现增强特定方向上的信号强度,同时减弱其他方向上的干扰信号。这种技术在无线通信、雷达、声呐、医学影像等领域得到广泛应用。

在Verilog开发中,波束形成可以通过以下步骤实现:

  1. 信号采集:通过阵列天线接收信号,将其转换为数字信号并送入FPGA进行处理。
  2. 信号加权:对每个天线接收到的信号施加不同的权重,以改变信号的幅度和相位。
  3. 信号叠加:将加权后的信号进行叠加,形成波束。
  4. 波束输出:将形成的波束输出到外部设备或发送到无线信道。

下面是一些常用的波束形成算法和公式:

基于权重的波束形成:

      这种方法通过对每个天线接收到的信号施加不同的权重,从而改变信号的幅度和相位。权重可以是固定的,也可以是可调的。权重的计算公式如下:

w = exp(-j2pidsin(theta)/lambda)

其中,w表示权重,d表示天线之间的距离,theta表示信号的入射角度,lambda表示信号的波长。

基于空间谱估计的波束形成:

       这种方法通过对信号的空间谱进行估计,从而确定信号的入射角度。空间谱估计的方法有多种,比如MUSIC算法、ESPRIT算法等。在计算出信号的入射角度后,可以通过对每个天线接收到的信号施加不同的权重来调节信号的幅度和相位。权重的计算公式与基于权重的波束形成相同。

基于最小均方误差的波束形成:

       这种方法通过最小化输出信号与期望信号之间的均方误差来确定权重。权重的计算公式如下:

w = R^(-1)*p

其中,w表示权重,R表示输入信号的自相关矩阵,p表示期望信号与输入信号的互相关向量。

       以上是一些常用的波束形成算法和公式。在实际应用中,需要根据具体的应用场景和信号处理需求选择适合的算法和公式。同时,在Verilog开发中,还需要考虑到硬件资源的限制和优化问题,以确保设计的实现和优化。

1.2 基于FPGA的波束形成实现

根据原理可知,整个波束形成的基本结构框图如下图所示:

这里,我们使用的加权函数为:

 这个模块,相当于上述结构的:

二、核心程序

  1. `timescale 1ns / 1ps
  2. module beamformer(
  3. i_clk,
  4. i_rst,
  5. i_din00,i_din01,i_din02,i_din03,i_din04,i_din05,i_din06,i_din07,
  6. i_din08,i_din09,i_din10,i_din11,i_din12,i_din13,i_din14,i_din15,
  7. i_din16,i_din17,i_din18,i_din19,i_din20,i_din21,i_din22,i_din23,
  8. i_din24,i_din25,i_din26,i_din27,i_din28,i_din29,i_din30,i_din31,
  9. i_din32,i_din33,i_din34,i_din35,i_din36,i_din37,i_din38,i_din39,
  10. i_din40,i_din41,i_din42,i_din43,i_din44,i_din45,i_din46,i_din47,
  11. o_dut
  12. );
  13. input i_clk;
  14. input i_rst;
  15. input signed[7:0]i_din00,i_din01,i_din02,i_din03,i_din04,i_din05,i_din06,i_din07,
  16. i_din08,i_din09,i_din10,i_din11,i_din12,i_din13,i_din14,i_din15,
  17. i_din16,i_din17,i_din18,i_din19,i_din20,i_din21,i_din22,i_din23,
  18. i_din24,i_din25,i_din26,i_din27,i_din28,i_din29,i_din30,i_din31,
  19. i_din32,i_din33,i_din34,i_din35,i_din36,i_din37,i_din38,i_din39,
  20. i_din40,i_din41,i_din42,i_din43,i_din44,i_din45,i_din46,i_din47;
  21. output signed[21:0]o_dut;
  22. wire[7:0]r_dut00,r_dut01,r_dut02,r_dut03,r_dut04,r_dut05,r_dut06,r_dut07;
  23. wire[7:0]r_dut08,r_dut09,r_dut10,r_dut11,r_dut12,r_dut13,r_dut14,r_dut15;
  24. wire[7:0]r_dut16,r_dut17,r_dut18,r_dut19,r_dut20,r_dut21,r_dut22,r_dut23;
  25. wire[7:0]r_dut24,r_dut25,r_dut26,r_dut27,r_dut28,r_dut29,r_dut30,r_dut31;
  26. wire[7:0]r_dut32,r_dut33,r_dut34,r_dut35,r_dut36,r_dut37,r_dut38,r_dut39;
  27. wire[7:0]r_dut40,r_dut41,r_dut42,r_dut43,r_dut44,r_dut45,r_dut46,r_dut47;
  28. delays_tao delays_tao_u(
  29. .i_clk (i_clk),
  30. .i_rst (i_rst),
  31. .i_din00(i_din00),
  32. .i_din01(i_din01),
  33. .i_din02(i_din02),
  34. .i_din03(i_din03),
  35. .i_din04(i_din04),
  36. .i_din05(i_din05),
  37. .i_din06(i_din06),
  38. .i_din07(i_din07),
  39. .i_din08(i_din08),
  40. .i_din09(i_din09),
  41. .i_din10(i_din10),
  42. .i_din11(i_din11),
  43. .i_din12(i_din12),
  44. .i_din13(i_din13),
  45. .i_din14(i_din14),
  46. .i_din15(i_din15),
  47. .i_din16(i_din16),
  48. .i_din17(i_din17),
  49. .i_din18(i_din18),
  50. .i_din19(i_din19),
  51. .i_din20(i_din20),
  52. .i_din21(i_din21),
  53. .i_din22(i_din22),
  54. .i_din23(i_din23),
  55. .i_din24(i_din24),
  56. .i_din25(i_din25),
  57. .i_din26(i_din26),
  58. .i_din27(i_din27),
  59. .i_din28(i_din28),
  60. .i_din29(i_din29),
  61. .i_din30(i_din30),
  62. .i_din31(i_din31),
  63. .i_din32(i_din32),
  64. .i_din33(i_din33),
  65. .i_din34(i_din34),
  66. .i_din35(i_din35),
  67. .i_din36(i_din36),
  68. .i_din37(i_din37),
  69. .i_din38(i_din38),
  70. .i_din39(i_din39),
  71. .i_din40(i_din40),
  72. .i_din41(i_din41),
  73. .i_din42(i_din42),
  74. .i_din43(i_din43),
  75. .i_din44(i_din44),
  76. .i_din45(i_din45),
  77. .i_din46(i_din46),
  78. .i_din47(i_din47),
  79. .o_dut00(r_dut00),
  80. .o_dut01(r_dut01),
  81. .o_dut02(r_dut02),
  82. .o_dut03(r_dut03),
  83. .o_dut04(r_dut04),
  84. .o_dut05(r_dut05),
  85. .o_dut06(r_dut06),
  86. .o_dut07(r_dut07),
  87. .o_dut08(r_dut08),
  88. .o_dut09(r_dut09),
  89. .o_dut10(r_dut10),
  90. .o_dut11(r_dut11),
  91. .o_dut12(r_dut12),
  92. .o_dut13(r_dut13),
  93. .o_dut14(r_dut14),
  94. .o_dut15(r_dut15),
  95. .o_dut16(r_dut16),
  96. .o_dut17(r_dut17),
  97. .o_dut18(r_dut18),
  98. .o_dut19(r_dut19),
  99. .o_dut20(r_dut20),
  100. .o_dut21(r_dut21),
  101. .o_dut22(r_dut22),
  102. .o_dut23(r_dut23),
  103. .o_dut24(r_dut24),
  104. .o_dut25(r_dut25),
  105. .o_dut26(r_dut26),
  106. .o_dut27(r_dut27),
  107. .o_dut28(r_dut28),
  108. .o_dut29(r_dut29),
  109. .o_dut30(r_dut30),
  110. .o_dut31(r_dut31),
  111. .o_dut32(r_dut32),
  112. .o_dut33(r_dut33),
  113. .o_dut34(r_dut34),
  114. .o_dut35(r_dut35),
  115. .o_dut36(r_dut36),
  116. .o_dut37(r_dut37),
  117. .o_dut38(r_dut38),
  118. .o_dut39(r_dut39),
  119. .o_dut40(r_dut40),
  120. .o_dut41(r_dut41),
  121. .o_dut42(r_dut42),
  122. .o_dut43(r_dut43),
  123. .o_dut44(r_dut44),
  124. .o_dut45(r_dut45),
  125. .o_dut46(r_dut46),
  126. .o_dut47(r_dut47)
  127. );
  128. wire signed[15:0]r2_dut00,r2_dut01,r2_dut02,r2_dut03,r2_dut04,r2_dut05,r2_dut06,r2_dut07;
  129. wire signed[15:0]r2_dut08,r2_dut09,r2_dut10,r2_dut11,r2_dut12,r2_dut13,r2_dut14,r2_dut15;
  130. wire signed[15:0]r2_dut16,r2_dut17,r2_dut18,r2_dut19,r2_dut20,r2_dut21,r2_dut22,r2_dut23;
  131. wire signed[15:0]r2_dut24,r2_dut25,r2_dut26,r2_dut27,r2_dut28,r2_dut29,r2_dut30,r2_dut31;
  132. wire signed[15:0]r2_dut32,r2_dut33,r2_dut34,r2_dut35,r2_dut36,r2_dut37,r2_dut38,r2_dut39;
  133. wire signed[15:0]r2_dut40,r2_dut41,r2_dut42,r2_dut43,r2_dut44,r2_dut45,r2_dut46,r2_dut47;
  134. multer_sum multer_sum_u(
  135. .i_clk (i_clk),
  136. .i_rst (i_rst),
  137. .i_din00(r_dut00),
  138. .i_din01(r_dut01),
  139. .i_din02(r_dut02),
  140. .i_din03(r_dut03),
  141. .i_din04(r_dut04),
  142. .i_din05(r_dut05),
  143. .i_din06(r_dut06),
  144. .i_din07(r_dut07),
  145. .i_din08(r_dut08),
  146. .i_din09(r_dut09),
  147. .i_din10(r_dut10),
  148. .i_din11(r_dut11),
  149. .i_din12(r_dut12),
  150. .i_din13(r_dut13),
  151. .i_din14(r_dut14),
  152. .i_din15(r_dut15),
  153. .i_din16(r_dut16),
  154. .i_din17(r_dut17),
  155. .i_din18(r_dut18),
  156. .i_din19(r_dut19),
  157. .i_din20(r_dut20),
  158. .i_din21(r_dut21),
  159. .i_din22(r_dut22),
  160. .i_din23(r_dut23),
  161. .i_din24(r_dut24),
  162. .i_din25(r_dut25),
  163. .i_din26(r_dut26),
  164. .i_din27(r_dut27),
  165. .i_din28(r_dut28),
  166. .i_din29(r_dut29),
  167. .i_din30(r_dut30),
  168. .i_din31(r_dut31),
  169. .i_din32(r_dut32),
  170. .i_din33(r_dut33),
  171. .i_din34(r_dut34),
  172. .i_din35(r_dut35),
  173. .i_din36(r_dut36),
  174. .i_din37(r_dut37),
  175. .i_din38(r_dut38),
  176. .i_din39(r_dut39),
  177. .i_din40(r_dut40),
  178. .i_din41(r_dut41),
  179. .i_din42(r_dut42),
  180. .i_din43(r_dut43),
  181. .i_din44(r_dut44),
  182. .i_din45(r_dut45),
  183. .i_din46(r_dut46),
  184. .i_din47(r_dut47),
  185. .o_dut00(r2_dut00),
  186. .o_dut01(r2_dut01),
  187. .o_dut02(r2_dut02),
  188. .o_dut03(r2_dut03),
  189. .o_dut04(r2_dut04),
  190. .o_dut05(r2_dut05),
  191. .o_dut06(r2_dut06),
  192. .o_dut07(r2_dut07),
  193. .o_dut08(r2_dut08),
  194. .o_dut09(r2_dut09),
  195. .o_dut10(r2_dut10),
  196. .o_dut11(r2_dut11),
  197. .o_dut12(r2_dut12),
  198. .o_dut13(r2_dut13),
  199. .o_dut14(r2_dut14),
  200. .o_dut15(r2_dut15),
  201. .o_dut16(r2_dut16),
  202. .o_dut17(r2_dut17),
  203. .o_dut18(r2_dut18),
  204. .o_dut19(r2_dut19),
  205. .o_dut20(r2_dut20),
  206. .o_dut21(r2_dut21),
  207. .o_dut22(r2_dut22),
  208. .o_dut23(r2_dut23),
  209. .o_dut24(r2_dut24),
  210. .o_dut25(r2_dut25),
  211. .o_dut26(r2_dut26),
  212. .o_dut27(r2_dut27),
  213. .o_dut28(r2_dut28),
  214. .o_dut29(r2_dut29),
  215. .o_dut30(r2_dut30),
  216. .o_dut31(r2_dut31),
  217. .o_dut32(r2_dut32),
  218. .o_dut33(r2_dut33),
  219. .o_dut34(r2_dut34),
  220. .o_dut35(r2_dut35),
  221. .o_dut36(r2_dut36),
  222. .o_dut37(r2_dut37),
  223. .o_dut38(r2_dut38),
  224. .o_dut39(r2_dut39),
  225. .o_dut40(r2_dut40),
  226. .o_dut41(r2_dut41),
  227. .o_dut42(r2_dut42),
  228. .o_dut43(r2_dut43),
  229. .o_dut44(r2_dut44),
  230. .o_dut45(r2_dut45),
  231. .o_dut46(r2_dut46),
  232. .o_dut47(r2_dut47)
  233. );
  234. weight_sum2 weight_sum_u(
  235. .i_clk (i_clk),
  236. .i_rst (i_rst),
  237. .i_din00(r2_dut00),
  238. .i_din01(r2_dut01),
  239. .i_din02(r2_dut02),
  240. .i_din03(r2_dut03),
  241. .i_din04(r2_dut04),
  242. .i_din05(r2_dut05),
  243. .i_din06(r2_dut06),
  244. .i_din07(r2_dut07),
  245. .i_din08(r2_dut08),
  246. .i_din09(r2_dut09),
  247. .i_din10(r2_dut10),
  248. .i_din11(r2_dut11),
  249. .i_din12(r2_dut12),
  250. .i_din13(r2_dut13),
  251. .i_din14(r2_dut14),
  252. .i_din15(r2_dut15),
  253. .i_din16(r2_dut16),
  254. .i_din17(r2_dut17),
  255. .i_din18(r2_dut18),
  256. .i_din19(r2_dut19),
  257. .i_din20(r2_dut20),
  258. .i_din21(r2_dut21),
  259. .i_din22(r2_dut22),
  260. .i_din23(r2_dut23),
  261. .i_din24(r2_dut24),
  262. .i_din25(r2_dut25),
  263. .i_din26(r2_dut26),
  264. .i_din27(r2_dut27),
  265. .i_din28(r2_dut28),
  266. .i_din29(r2_dut29),
  267. .i_din30(r2_dut30),
  268. .i_din31(r2_dut31),
  269. .i_din32(r2_dut32),
  270. .i_din33(r2_dut33),
  271. .i_din34(r2_dut34),
  272. .i_din35(r2_dut35),
  273. .i_din36(r2_dut36),
  274. .i_din37(r2_dut37),
  275. .i_din38(r2_dut38),
  276. .i_din39(r2_dut39),
  277. .i_din40(r2_dut40),
  278. .i_din41(r2_dut41),
  279. .i_din42(r2_dut42),
  280. .i_din43(r2_dut43),
  281. .i_din44(r2_dut44),
  282. .i_din45(r2_dut45),
  283. .i_din46(r2_dut46),
  284. .i_din47(r2_dut47),
  285. .o_dut (o_dut)
  286. );
  287. endmodule

三、仿真测试结果

        首先介绍一下延迟模块,根据各个延迟值,将其量化之后,获得不同数据的延迟值:

通过上面双口RAM的原理,获得延迟模块的设计与实现。

        那么对于不同element个数的系统,只要调用上述模块即可。

四个数据,我们分别调用8次,24次,36次,48次即可。

那么,对于8element,仿真结果如下图所示,其余几组类似:

这里,还是以8element为例子,进行仿真,其modelsim仿真结果如下图所示:

然后是加权和模块。

       这个模块,主要采用流水线的树状结构进行逐级累积,其RTL图如下图所示:

对于24.36.48element,其RTL图如下图所示:

最后得到完整的波束形成系统。

8element

24element

36element

48element

       我们首先获得类似论文中的波形效果:

8element

 然后matlab进行成像,获得如下的效果:

8element

 A21-08

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/470070
推荐阅读
相关标签
  

闽ICP备14008679号