运行系统和环境:Linux Unbuntu 18.04 - CodeBlocks
Error: Stream aborted on error
Analyze:检查代码。
1、嵌入式系统中常用的数据类型及其位宽整理:
typedef char INT8;/**< -127~+127 */
typedef unsigned char UINT8;/**< 0~255 */
typedef short INT16;/**< -32767~+32767 */
typedef unsigned short UINT16;/**< 0~+65535 */
typedef int INT32;/**< -2147483647 ~+2147483647*/
typedef unsigned int UINT32;/**< 0~4294967295 */
整型字面值:
123;/**< int */
123L;/**< long int */
123UL;/**< unsigned long int */
八进制&十六进制:
int a;
a=12;/**< 十进制 */
a=012;/**< 八进制 */
a=0x12;/**< 十六进制 */
解决pre-trigger data太少问题思路:
首先得编写software trigger,对4个通道software trigger,并且同时Streaming,对于第4个通道,记录actually trigger,当第4个通道被实际闪电信号触发之后,记录时间值,当采集的样本截止于segmentsize大小后,停止采样。再根据记录的时间戳,找到前面三个通道这个时间点,这样就可以无限的得到pre-trigger的数据。
思路 -> 在程序采样结束的位置上,增加代码,在RAM上开一个循环缓冲区,然后可以把采样完的数据放到循环缓冲区里面区,大小可以设置为5G,这样就可以充足的保留更多预触发数据。
软件触发:
通过软件主动查询信号或仪器当前状态,符合条件则控制系统采集信号。软触发有着更大的柔性,但系统整体速度和测量精度一般不如硬触发,特别是有着复杂信号处理模块的时候。软件触发会占用到一定的计算机资源。使用软件触发的话可以先设计一个查询程序,在规定的时间间隔里定时查询触发信号,如果有触发信号,则输出一个真值的布尔量,执行数据采集的分支,如果没有触发信号,则输出一个假值的布尔量,执行空分支。