From da9ce9541aee3b4f4d55cf114758a44ae98b8b1f Mon Sep 17 00:00:00 2001 From: zhyinch <zhyinch@gmail.com> Date: 星期三, 11 十二月 2019 21:44:23 +0800 Subject: [PATCH] 增加40米异常滤波 --- 源码/核心板/Src/application/dw_app.c | 14 ++++++++++---- 1 files changed, 10 insertions(+), 4 deletions(-) diff --git "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/dw_app.c" "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/dw_app.c" index 34f43ff..93bc9a8 100644 --- "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/dw_app.c" +++ "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/application/dw_app.c" @@ -613,7 +613,7 @@ dwt_write32bitreg(SYS_STATUS_ID, SYS_STATUS_ALL_RX_ERR); } } - +u8 misdist_num; void Anchor_RecNearPoll(u8 ancrec_nearbasepos) //0 mainbase 1 first near_base { tmp_time=TIM3->CNT; @@ -677,10 +677,12 @@ LED0_BLINK; //每成功一次通讯则闪烁一次 dis_after_filter=dist_cm; hex_dist = dist_cm+(int16_t)g_com_map[DIST_OFFSET]; - if(abs(hex_dist-his_dist[tag_id_recv-TAG_ID_START])<1000) + if(hex_dist>-1000&&hex_dist<100000) { - tagdist_list[taglist_pos] = hex_dist; - } + if(abs(hex_dist-his_dist[taglist_pos])<1500||misdist_num>3) + { + misdist_num=0; + tagdist_list[taglist_pos] = hex_dist; his_dist[taglist_pos]=hex_dist; usart_send[2] = 1;//正常模式 usart_send[3] = 17;//数据段长度 @@ -693,7 +695,11 @@ checksum = Checksum_u16(&usart_send[2],17); memcpy(&usart_send[19],&checksum,2); UART_PushFrame(usart_send,21); + }else{ + misdist_num++; + } } + } }else{ dwt_write32bitreg(SYS_STATUS_ID, SYS_STATUS_ALL_RX_ERR); } -- Gitblit v1.9.3