全景图像实时展开在FPGA上的实现
算法模块为本系统的核心模块,利用EP2C70内嵌的M4K存储器和正余弦生成器实现了极坐标视图到直接坐标视图的实时。
人眼视角约为120°。考虑到人眼观察的习惯,系统将圆形的极坐标视图分割成为第一、二、三、四象限四个部分,每部分90°,由使用者选取感兴趣的部分进行展开,这样既符合人眼观察的习惯,又节省了空间。
视频分块
全景极坐标视图在显示器上显示时类似于图5,其中矩形代表整个显示器显示的内容,分辨率为640×480,圆形代表全景图像出现的位置,半径大约为240个像素,所以可以按图5中虚线部分将视频每一帧分为4块,每一块分辨率为240×240。系统使用VGA控制器生成的行列扫描信号标定当前像素的位置,当像素位置位于全景图像区域内时,则将像素值存入M4K存储器,否则继续搜索下一个满足条件的像素。
M4K存储器设计
M4K存储器是内嵌在EP2C70中的存储器块,其中每一块容量达到4096bit,可配置为真双口存储器,在EP2C70芯片上共有250块M4K存储器块。本系统使用了209块M4K存储器块,借助其高寻址精度,实现图像的实时展开。
M4K存储器写地址
将数据写入M4K存储器时,可以将数据流按照图像显示顺序全部存入,这样就需要生成0~360°的所有正余弦查找表;同时,由于存入了全部图像信息,将会有1/4左右的无效像素点,浪费了宝贵的存储器资源。系统利用M4K存储器精确的寻址操作将第二、三、四象限的信息在存入时进行翻转,使得存入M4K存储器的图像仅显示为第一象限的特性,则只需要生成0~90°的正余弦表就可以完成对整幅图像的展开计算。其次,固定摄像头之后,圆形全景图像在显示器中的位置是固定的,所以可以确定每一行有效像素的坐标范围。当行列扫描信号在此范围之内,则将该像素值存入M4K存储器中,否则,继续寻找下一个符合条件的像素点。所以,对第i象限的第M行第N个像素,如果为有效像素,则存入M4K存储器的地址按如下规则计算:
这里的M和N取值范围均为[0,239],Invalid_pixel(K)表示在第K行第一个有效像素之前所有无效像素点总数。
M4K存储器读地址
M4K存储器的读操作完成了全景图像的展开。本系统采用极坐标与直角坐标的对应关系实现全景图像展开。如图6所示,全景图像中的点P(x,y)在矩形图像中对应的点为P’(x’,y’),则x’,y’与x,y的对应关系应为:
???
其中xΔ为横坐标方向角度步长,yΔ为纵坐标方向上的半径步长,分别由以下参数确定:
之前对不同象限图像的翻转存储操作已经简化了M4K中数据的读取,所以只需要0~90°的正余弦查找表,查找表长度为640。在VGA显示器上的第M行第N个像素,其对应像素值在M4K存储器中的地址按如下规则进行计算:
其中sin_table(N)和cos_table(N)为正余弦查找表中第N列对应的正余弦值。
VGA控制模块
VGA控制模块根据系统时钟生成行同步信号和场同步信号,同时接收前端模块生成的RGB像素信号,并参照VGA显示标准对VGA显示进行控制。本系统采用640×480的显示分辨率,帧速为64.4fps。
系统性能
本系统每一帧画面分辨率为640×480,像素时钟为27MHz,在不考虑实时显示而只考虑存储的条件下,一秒钟内可存储87.89帧图像。另外,如果忽视人眼观察习惯,一次性展开整幅图像,帧速将降低为原来的四分之一,即21.97fps,展开图像分辨率提高到2560×480。
总结
本文以Terasic公司的DE2-70开发板为平台,实现了对反射式全景摄像机采集的全景视频流的实时展开,系统结构清晰,具有较高的稳定性和可操作性。系统时钟为27MHz,显示分辨率为640×480,帧速达到64.4fps,达到了实时性的要求。
- 在采用FPGA设计DSP系统中仿真的重要性 (06-21)
- 基于 DSP Builder的FIR滤波器的设计与实现(06-21)
- 基于FPGA的快速并行FFT及其在空间太阳望远镜图像锁定系统中的应用(06-21)
- 3DES算法的FPGA高速实现(06-21)
- 用FPGA实现FFT算法(06-21)
- FPGA的DSP性能揭秘(06-16)