STM32
直播中

王玉兰

7年用户 1292经验值
私信 关注
[问答]

STM32G4多个参数如何实现精准的计时?

电压电流等十余个参数需要做到超过额定值一定的时间后输出故障指示
请问多个参数如何实现精准的计时?多个参数的计时又不能互相影响?
也许同一时间只有一个参数会超过额定值,也许同一时间有多个参数超过额定值
计时精度:有的参数需要精确到1ms 有的参数需要100s
systick已经用作精准延时,在延时中计数器会清零。
那么计时有什么好的方法呢?
感谢 大神们请指点个思路

回帖(1)

李蒙娜

2024-3-11 16:12:32
给你说一个方法,你定义一个结构体,比如:
typedef struct{unsigned long err_trig_ms;   //开始超过额定值的时间点,只起记录作用用来产生err_commit_msunsigned long err_commit_ms;  // 等待确认故障的时间点,由触发时间点确认uint8_t err_id;               // 每个错误的id,建议使用enum定义好uint8_t is_err_trigged;       // 是否此错误已经被触发}PassLimit_Fault_Info_t;这个结构体每个故障定义一个。
typedef struct{uint8_t next_trig_id = 0;  // 0表示无故障,其它id表示下一次需要检查的fault的err_idunsigned long next_check_point; //下一次需要比较的时间点,由next_trig_id确定uint8_t on_fault_cnt;      // 正在发生等待确认的故障id,故障已经清除或者已经确认的不再此列表中不计算}FAULT_MGMT_t;static FAULT_MGMT_t sys_fault_mgmt;  //系统故障管理结构体每次故障被触发的时候就刷新当前发生故障的结构体,然后更新一下sys_fault_mgmt。比如当前的sys_fault_mgmt.next_trig_id不为零,就比较一下当前发生的故障要检查的时间点是否早于sys_fault_mgmt.next_check_point.如果更早就用这个故障的特征刷新。如果更晚就不用刷新。总之在故障产生、清除和确认的时候都刷新sys_fault_mgmt。而每次1ms中断的时候就只比较sys_fault_mgmt上面的事件。这个比较很简单不会耗费很多资源。
个人觉得当故障是这样的时候,裸机程序可以这样管理故障。当然如果你的系统有现成的链表。那么用链表的方法可能更好。就是说每次将最先需要检查的id放在链表的头部。依照事件顺序,插入新发生故障的链表可能会更好。
举报

更多回帖

发帖
×
20
完善资料,
赚取积分