历史上的今天
返回首页

历史上的今天

今天是:2025年03月25日(星期二)

正在发生

2021年03月25日 | 基于STM32f4的三维旋转显示平台

2021-03-25 来源:eefocus

现实的世界是一个拥有宽度、高度和深度的三维立体世界。在平面二维显示技术已经成熟的今天,三维立体显示技术首当其冲的成为了当今显示技术领域的研究热点。


本作品搭建了基于stm32f4的三维旋转显示平台,它的显示原理属于三维显示中的体三维显示一类。它是通过适当方式来激励位于透明显示体内的物质,利用可见辐射光的产生三维体像素。当体积内许多方位的物质都被激励后,便能形成由许多分散的体像素在三维空间内构成三维图像。


体三维显示又称为真三维显示,因为他所呈现的图像在真实的三维空间中,展示一个最接近真实物体的立体画面,可同时允许多人,多角度裸眼观看场景,无序任何辅助眼镜。


本作品的特点在于,利用stm32f4的浮点运算能力,实现了低成本的体三维显示数据的生产,并利用类似分布式处理的系统结构,满足了体三维显示所需要的巨大数据吞吐量,等效吞吐量可达约300Mb/s


1.系统方案


众所周知人眼在接收被观察物体的信息时,携带物体信息的光信号通过人眼细胞及神经传入大脑神经,光的作用时间只是一个很短暂的时间段,当光的作用时间结束后,视觉影像并不会立即消失,这种残留的视觉称“后像”,视觉的这一现象则被称为“视觉暂留”( duration of vision)物体在快速运动时, 当人眼所看到的影像消失后,人眼仍能继续保留其影像0.1---0.4秒左右的图像。在空间立体物体离散化的基础上,再利用人眼视觉暂留效应,基于LED阵列的“三维体扫描”立体显示系统便实现了立体显示效果。如图1所示,以显示一个空心的边长为单位1的正方体为例。LED显示阵列组成的二维显示屏即为正方体每个离散平面的显示载体,LED显示屏上的被点亮的LED即为正方体的平面离散像素。我们将该LED显示平面置于轴对称的角度机械扫描架构内,在严格机电同步的立体柱空间内进行各离散像素的寻址、赋值和激励,由于机械扫描速度足够快,便在人眼视觉上形成一个完整的正方体图像。图1(a)所示为立方体0度平面二维切片图,图1(b)所示为立方体45度平面二维切片图,图1(c)所示为立方体135度平面二维切片图,图1(d)所示为立方体180度平面二维切片图,图1(e)所示为观看者观察到的完整立方体显示效果。

图1


系统方案如图2所示,整个系统由四个模块组成,其中数据获取单元主要由在PC上的上位机完成,利用3D-Max,OpenCV,OpenGL,将三维建模数据转化成三维矢量表述文件,传给由STM32F4 Discovery开发板构成的控制单元,利用其上的角度传感器,结合wifi模块或以太网模块通过电力线模式传给LED旋转屏单元,其中的STM32F4负责将ASE文件解析成LED显示阵列所需的点云数据流,通过串行总线传输给由FPGA驱动的LED显示阵列,通过LED刷新速率与机械单元旋转速率相匹配,从而实现体三维显示的效果。

图2


2.系统硬件设计


系统的机械部分如图3所示,显示面板的硬件结构如图4,图5所示。本系统的底部是直流电机和碳刷,直流电机主要负责带动上层的显示屏幕高速旋转,而碳刷则负责传递能量和通信信号。在显示屏幕的正面是由96*128构成的三色LED点阵,FPGA的PWM信号通过驱动芯片控制三色LED从而实现真彩显示。在屏幕背面由多块STM32F4,SD卡,FIFO构成,主要负责解析由控制单元传过来的ASE文件,并实时生成体三维显示数据,并传给LED灯板的驱动FPGA,并通过其实现最终的图像显示。





3.系统软件设计


3.1软件控制流程:

3.2关于实时生成体三维显示数据的讨论:


一个瓦片64*32


LED层FPGA*8:每个16*16LED


中间层stm32*2:每个4LED层的FPGA,也即32*32


由于经过压缩,一个led数据为4bits


所以一个stm32每一帧所要生成的数据为32*32*0.5bytes = 512bytes


转速800转,一帧1/800s = 1.25ms = 1250000ns


stm32f4主频168Mhz,指令周期 = 5.93ns


约可执行20万多条指令


假设fsmc总线的速度为50Mhz,则每帧写入的时间大概在0.02ms内


程序总体思路


事先算出所有电子帧上非零的点,以及连续0的个数,在每一个电子帧同步后,算出生成下一帧的数据,写入fifo


输入:线段端点的集合


//input: endpoints of segments which formed the outline of a 3D model


//x position with range 0-95


//y position with range 0-95


//z position with range 0-128


/******************************************/


//from later discussion, one of the Q format


//type should replace the char type


/******************************************/


struct Coordinate_3D


{


_iq xPosition;


_iq yPosition;


_iq zPosition;


};


//after you get the intersection points in 3d coordinate, you need to remap it into 2d coordinate on the very electrical plane,


//and the conversion is quite simple Coordinate_2D.yPosition = Coordinate_3D.zPosition; Coordinate_2D.xPosition = sqrt(xPosition^2+yPosition^2)


struct Coordinate_2D


{


char xPosition;


char yPosition;


};


struct Line


{


struct Coordinate_3D beginPoint;


struct Coordinate_3D endPoint;


unsigned char color;


};


//frame structure to store the visible points in one electrical frame


//need to be discussed


//here's the prototype of the Frame structure, and basically the frame struture should contain the visible points,


//and the zero points. As we have enclosed the number of zero points after each visible points in their own data structure,


//only the number of zero points at the beginning of the whole frame should be enclosed in the frame struture


struct Frame


{


int zerosBefore;


PointQueue_t visiblePointQueue;


};


//we need a union structure like color plane with bit fields to store the color imformation of every four FPGAs in one data segment


//actually, it's a kind of frustrateing thing that we had to rebind the data into such an odd form.


union ColorPalette


{


struct


{


unsigned char color1 : 4;


unsigned char color2 : 4;


unsigned char color3 : 4;


unsigned char color3 : 4;


}distributedColor;


unsigned short unionColor;


};


//and now we need a complete point structure to sotre all the imformation above


//here we add a weight field = yPosition*96 + xPosition, which will facilitate


//our sort and calculation of the zero points number between each visible point


//it's important to understand that, 4 corresponding points on the LED panel


//will share one visiblepoint data structure.(一块stm32负责4块16*16的LED,每块对应的点的4位颜色信息,拼成16位的数据段)


struct VisiblePoint


{


struct Coordinate_2D coord;


union Colorplane ColorPalette;


int weight;


int zerosAfter;


};


//as now you can see, we need some thing to store the visible points array


typedef struct QueueNode


{


struct VisiblePoint pointData;


struct QueueNode * nextNode;


}QueueNode_t, *QueueNode_ptr;


typedef struct


{


QueueNode_ptr front;


QueueNode_ptr rear;


}PointQueue_t;


//finally, we will have 16*16 words(16 bits)to write into the fifo after each electrial frame sync cmd.


//it may hard for us to decide the frame structure now, let's see how will the work flow of the algorithm be.


//firstly, the overall function will be like this


void Real3DExt(struct Line inputLines[], int lineNumber, struct Frame outputFrames[])


//then we need some real implementation function to calculate the intersection points


//with 0 = no intersection points, 1 = only have one intersection points, 2 = the input line coincides the given electrical plane


//2 need to be treated as an exception


//the range of the degree is 0-359


//it's important to mention that each intersection point we calculate, we need to


//remap its coordinate from a 32*32 field to x,y = 0-15, as each stm32 only have a 32*32


//effective field(those intersection points out of this range belong to other stm32), which can be decided by its address


int InterCal(struct Line inputLine, struct VisiblePoint * outputPoint, int degree)


//so we will need something like this in the Real3DExt function:


for (int j = 0; j < 360; j++)


{


for(int i = 0; i < lineNumber; i++ )


InterCal(struct Line inputLine, struct VisiblePoint outputPoint, int degree);


......


}


/******************************************/


//simple float format version of InterCal


/******************************************/


//calculate formula


//Q = [-1,1,-1];


//P = [1,1,-1];


//V = Q - p = [-2,0,0];


//Theta = pi/6;


//Tmp0 = Q(1)*sin(Theta) - Q(2)*cos(Theta);


//Tmp1 = V(1)*sin(Theta) - V(2)*cos(Theta);


//Result = Q - (Tmp0/Tmp1)*V


float32_t f32_point0[3] = {-1.0f,1.0f,-1.0f};


float32_t f32_point1[3] = {1.0f,1.0f,-1.0f};


float32_t f32_directionVector[3], f32_normalVector[3], f32_theta,


f32_tmp0, f32_tmp1, f32_tmp2, f32_result[3];


arm_sub_f32(f32_point0,f32_point1,f32_directionVector,3);


f32_theta = PI/6.0f;


f32_normalVector[0] = arm_sin_f32(f32_theta);


f32_normalVector[1] = arm_cos_f32(f32_theta);


f32_normalVector[2] = 0.0f;


arm_dot_prod_f32(f32_point0, f32_normalVector, 3, &f32_tmp0);


arm_dot_prod_f32(f32_directionVector, f32_normalVector, 3, &f32_tmp1);


f32_tmp2 = f32_tmp0/f32_tmp1;


arm_scale_f32(f32_normalVector, f32_tmp2, f32_normalVector, 3);


arm_sub_f32(f32_point0, f32_normalVector, f32_result, 3);


//and than we need to decide whether to add a new visible point in the point queue, or to update


//the color field of a given point in the point queue(as 4 visible point share one data structure). from this point, you will find that, it may be


//sensible for you not to diretly insert a new point into the end of point queue but to insert it in order


//when you build the pointqueue. it seems more effective.


void EnPointQueue(PointQueue_t * inputQueue, QueueNode_t inputNode);


//finally we will get an sorted queue at the end of the inner for loop


//than we need to calculate the number of invisible points between these visible points


//and to store it in each frame structure. the main purpose to do so is to offer an quick generation


//of the blank point(color field = 16'b0) between each electrical frame


//the work flow will be like this:


loop


{


dma output of the blank points;


output of the visible points;


}


/******************************************/


//some points need more detailed discussion


/******************************************/


//1.memory allocation strategy


//a quite straight forward method will be establishing a big memnory pool in advance, but the drawback of this method


//is that it's hard for you to decide the size of the memory pool. Another way would be the C runtime library method,


// and you can use build-in function malloc to allocate the memory, but it will be a quite heavy load for the m3 cpu


// as you need dynamic memeory allocation throughout the algorithm.


//2.the choice of Q format of the IQMATH library


//from the discussion above, the range of the coordnate is about 1-100, but the range of sin&cos is only 0-1,so there's a large gap between them.


//may be we can choose iq24?? Simultaneously, another big problem will be the choice between IQMATH and arm dsp library as their q format is


//incompatible with each other. as far as my knowledge is concerned, we should choose IQMATH with m3 without fpu, and cmsis dsp library with m4 with fpu.


//more detail discussion about the range of the algorithm


//x,y range is -64 to 64


//the formula is


//Tmp0 = Q(1)*sin(Theta) - Q(2)*cos(Theta);


//Tmp0 range is -128 to 128


//Tmp1 = V(1)*sin(Theta) - V(2)*cos(Theta);


//Tmp1 range is -128 to 128


//Result = Q - (Tmp1/Tmp2)*V


//because the minimal precision of the coordinate is 1, so if the result of Tmp1/Tmp2 is bigger than 128, the Result will be


//saturated. With the same reson, if (Tmp1/Tmp2)*V >= 128 or <= -127, the result will be saturated


4.系统创新


其一,由于高效解析算法的提出,大幅简化了真三维显示器显示数据的获取难度,只需在PC端获得当前较为标准化的三维图形的三角面顶点数据流文件,即可在真三维显示平台上显示出来,使得真三维显示器的整体显示流程大为简化。


其二,由于显示体的结构分为并行的若干区块,各个区块只显示自身的部分,因此显示屏幕的扩大并不会造成数据计算量的大幅增加,这就使得本显示器的扩展性大大增强,可以适用于多种多样的显示范围与领域。


其三,由于高效算法的优化与区块化显示的优势,并行结构的计算量相对较少,这就使得实时控制得以实现,大大增强了真三维显示器的应用领域。


其四,高效算法与区块化显示使得本三维体显示器不需要如国内外其他同类产品的中所需的高速传输方式,因此大大减少了从产品研发到材料再到加工中各个环节的成本。


5.评测与结论


在作品的过程中,我们发现本作品虽然还不是很成熟,也同样具备较大的应用前景与价值。价格成本的极大降低,使得真三维立体显示的门槛很低,那么在一些对清晰度要求不高,但是希望多层次全角度呈现三维图像的应用领域,我们的真三维立体显示器能发挥较大的作用。


附录





推荐阅读

史海拾趣

Adamant Co Ltd公司的发展小趣事

随着国内市场的饱和,Adamant Co Ltd决定将目光投向更广阔的国际市场。公司通过市场调研和精准定位,成功进入了欧洲和北美市场。在国际市场的拓展过程中,Adamant Co Ltd积极寻求与当地企业的合作,通过技术共享和市场互通,实现了双赢局面。这不仅提高了公司在国际市场的竞争力,也为公司的长远发展打下了坚实基础。

EMBEST公司的发展小趣事

随着公司业务的不断拓展和市场规模的逐步扩大,EMBEST在XXXX年成立了Timll和Giayee两个子公司。其中,Timll主要负责ARM工控业务,而Giayee则专门负责PDA/Smart Phone等业务。这两个子公司的成立不仅进一步拓展了EMBEST的业务领域,也为其未来的发展注入了新的活力。通过多元化的业务布局和精细化的管理,EMBEST在电子行业中的影响力日益增强。

ELINA INDEK公司的发展小趣事

因美纳始终将创新与研发作为公司的核心竞争力。随着技术的不断进步,公司不断推出更先进、更便捷的基因测序产品,满足市场的多样化需求。同时,因美纳还积极与全球各大科研机构合作,共同推动基因测序技术的发展和应用。这种持续的创新和研发精神使得因美纳在电子行业中保持领先地位。

Hirschmann公司的发展小趣事
在通信领域中,定时电路也扮演着重要角色。例如,在数字通信系统中,定时电路可以用于产生同步信号或控制信号的定时发送。这种可编程定时电路可以根据通信协议的要求灵活设置定时参数,确保通信过程的稳定性和可靠性。
BCD Semi(Diodes)公司的发展小趣事

在电子行业的发展过程中,市场波动和风险挑战是不可避免的。某一年,全球半导体市场出现了严重的产能过剩,导致产品价格大幅下跌。面对这一挑战,BCD Semi(Diodes)公司及时调整生产策略,优化产品结构,降低生产成本,成功度过了这一行业寒冬。

DUCATI公司的发展小趣事

BCD Semi(Diodes)公司自成立以来,一直致力于模拟半导体产品的设计和制造。在某一时期,公司研发团队成功突破了某项关键技术,开发出了具有更高性能、更低功耗的新型模拟器件。这一技术突破使得BCD Semi的产品在市场上更具竞争力,赢得了众多客户的青睐。随着产品升级的不断推进,公司逐渐在模拟半导体领域树立了良好的口碑。

问答坊 | AI 解惑

从WiFi收发器的PCB布局看射频电路电源和接地的设计方法

射频(RF)电路的电路板布局应在理解电路板结构、电源布线和接地的基本原则的基 础上进行。本文探讨了相关的基本原则,并提供了一些实用的、经过验证的电源布 线、电源旁路和接地技术,可有效提高RF 设计的性能指标。考虑到实际设计中 PLL 杂散信 ...…

查看全部问答>

4路模拟量数据采集

本人欲外包一项目,价格再议,其具体要求如下:     1、4路 4--20ma电流型传感器的数据采集;     2、精度要求12位以上;     3、采用51系列单片机,C语言编程;     4、有隔离栅功能,能进行过流保护 ...…

查看全部问答>

win CE 初学平台如何搭建啊

请大虾们列下自己的开发软件 …

查看全部问答>

在使用:ARM926EJ-S MP2530F方案的机器上,运行程序报非法应用程序错误

在使用ARM926EJ-S MP2530F方案的导航仪上,程序运行报非法应用程序错误,请问怎么办?怎样做与系统无关的程序?…

查看全部问答>

为什么要划分operating mode?

在arm上有7种模式:user fiq irq 。。。。 为什么要作这样的划分?作用是什么? 每一种模式的限制在哪里? 有没有什么书,会比较详细的介绍这些问题的? 谢谢。…

查看全部问答>

我在本机上写了个网页,怎么用pda模拟器来访问??

如题,还有我准备用asp.net来做这个网页,怎么控制这个网页的长宽比呢??就是说大小问题.本机是800*600的大小.怎么适应pda的屏幕呢??…

查看全部问答>

上传一个lm3s8962较新的勘误文档

如果你采用的硅版本是A1或者A2的话,有些时候程序出现莫名奇妙的问题,有可能不是你的错,看看勘误文档能不能帮你迅速找到出错的地方,以及在使用的时候去避免这些芯片本身的小问题,应该是有点帮助的。 [ 本帖最后由 academic 于 2010-11-16 09: ...…

查看全部问答>

【求助】430双电源设计

我做的双电源设计 锂电池3.6V---二极管-------MSP430 ××CC DVCC 纽扣电池3V------二极管------msp430 ××CC 用作外部电池断电以后 RAM 数据保持 不知是否可行,还有就是不知道二极管再导通后的功耗多大 请教楼住 有没有成 ...…

查看全部问答>

一个车友的请教。求帮助

比亚迪汽车车载导航用的是winc5.0的系统ARM9+64MB内存的一体机,我们研究发现只有用他原厂的导航软件才有声音出来,如果换了导航软件就不出声了。具体分析了原厂导航软件的启动过程,发现他是调用了coredll、dll文件的函数了?我想问问一体机的注册 ...…

查看全部问答>

(74HC595驱动3个数码管+2个按键)模块原理图和电路板

这个模块是我前些日子给人开发产品的一部分电路,可以给设计人员一个参考。…

查看全部问答>