From 6facaabcb51a77459d098b4957213038e6bb0a73 Mon Sep 17 00:00:00 2001
From: WXK <287788329@qq.com>
Date: 星期三, 05 三月 2025 16:06:30 +0800
Subject: [PATCH] 1.1,功能开发完成

---
 keil/uwb_app.c |  468 +++++++++------------------------------------------------
 1 files changed, 77 insertions(+), 391 deletions(-)

diff --git a/keil/uwb_app.c b/keil/uwb_app.c
index 9cd795b..d58da14 100644
--- a/keil/uwb_app.c
+++ b/keil/uwb_app.c
@@ -279,14 +279,15 @@
 
 /* RX done process handler. */
 int8_t rssi;
-uint32_t range_timeout_us = 2000000;//yuan5000
+uint32_t range_timeout_us = 1000000;//yuan5000
 uint8_t flag_temp2,flag_temp1;
 uint16_t uwb_losttimer;
+uint32_t rxnum;
 static void rx_int_callback(struct MAC_HW_REPORT_T *rx_report)
 {		uint8_t valid_sts=0;
     // Power off radio
     power_off_radio();
-
+    rxnum++;
     /** UWB RX success */
     if (rx_report->err_code == UWB_RX_OK)
     {
@@ -331,7 +332,10 @@
         rx_length = 0;
 			//	OpenUWB();//再次开启UWB接收
     }
+//    CloseUWB();
 	OpenUWB();//再次开启UWB接收
+//    Uwb_init();
+//    OpenUWB();
 }
 
 /* TX done process handler. */
@@ -354,7 +358,7 @@
  uint16_t anchordata_id[TAG_NUM_IN_SYS],anchordata_dist[TAG_NUM_IN_SYS];
 static uint8_t anchordata_bat[TAG_NUM_IN_SYS];
 uint8_t anchordata_num = 0;
-static int32_t tagdist_list[TAG_NUM_IN_SYS];
+static int16_t tagdist_list[TAG_NUM_IN_SYS];
 uint16_t random_time;
 //anchor
 int32_t hist_dist;
@@ -571,6 +575,10 @@
 	}
 }
 uint16_t g_com_receive_id;
+uint8_t usart_send[400];
+extern uint8_t userkey_state;
+extern uint8_t bat_percent;
+uint16_t tagseq;
 void CloseUWB(void)
 {
 		uwb_rx_force_off(1);
@@ -579,8 +587,11 @@
 }
 void OpenUWB(void)
 {
+//        while(!mac_is_busy())
+//        {
 		flag_temp1=uwb_rx(0, 0,range_timeout_us);//提交接收请求
 		uwb_rx_flag=1;
+//        }
 		//LOG_INFO(TRACE_MODULE_APP,"打开uwb_rx\r\n");
 }	
 void UWBOneSecondTask(void)
@@ -590,6 +601,68 @@
  if(uwb_losttimer>g_com_map[UWB_RNAGE_TIME])
  uwb_losttimer=g_com_map[UWB_RNAGE_TIME]+1;//防止溢出
 }
+void UWBSendUDPTask(void)
+{
+	uint16_t checksum,tempdistarray[20];
+//    UDP_TEST();
+    for(uint16_t i=0;i<taglist_num-1;i++)
+    {
+        for(uint16_t j=0;j<taglist_num-1-i;j++)
+        {
+            if(tagdist_list[j]>tagdist_list[j+1])
+            {
+                uint16_t id,dist;
+                uint8_t bat;
+                id = tagid_list[j];
+                dist = tagdist_list[j];
+                bat = anchordata_bat[j];
+                tagid_list[j] = tagid_list[j+1];
+                tagdist_list[j] = tagdist_list[j+1];
+                anchordata_bat[j] = anchordata_bat[j+1];
+                tagid_list[j+1] = id;
+                tagdist_list[j+1] = dist;
+                anchordata_bat[j+1] = bat;
+            }
+        }
+    
+    }
+//    if(taglist_num>0)
+//    {
+//        if(uwbled==LEDOFF)
+//        {
+//            uwbled = BLUE;
+//        }else{
+//            uwbled = LEDOFF;
+//        }
+//    }
+//    Set4LEDColor(uwbled,rtkled,led4g,powerled);
+    
+    if(taglist_num>20)       //最多上传20个基站数据,距离最近的20个
+        taglist_num = 20;
+                    usart_send[0]= 0x55;
+                    usart_send[1]= 0xaa;
+					usart_send[2] = 0x12;//正常模式 
+					usart_send[3] = 15+5*(taglist_num);//数据段长度
+					memcpy(&usart_send[4],&dev_id,2);
+					usart_send[6] = tagseq;
+					usart_send[7] = (tagseq++)>>8;
+					usart_send[8] = bat_percent;
+					usart_send[9] = userkey_state|0<<1|0<<2|0<<5|uwb_state<<6;
+				//	memcpy(&usart_send[10],&rec_tagheight,2);
+					usart_send[12] = 0;
+					usart_send[13] = 0;
+					usart_send[14] = 0;
+					usart_send[15] = 0;
+					usart_send[16] = taglist_num;
+				 
+					memcpy(&usart_send[17],&tagid_list,2*taglist_num);
+					memcpy(&usart_send[17+taglist_num*2],&tagdist_list,2*taglist_num);
+                    memcpy(&usart_send[17+taglist_num*4],&anchordata_bat,taglist_num);
+					checksum = Checksum_u16(&usart_send[2],15+5*taglist_num);
+					memcpy(&usart_send[17+5*taglist_num],&checksum,2);
+					HexToAsciiSendUDP(usart_send,19+5*taglist_num);
+                    taglist_num = 0;                    
+}
 void UWBIdleTask(void)
 {
 
@@ -597,50 +670,11 @@
 	{
 		uwbtasktimer = HIDO_TimerGetTick();
 		UWBOneSecondTask();
+        UWBSendUDPTask();
 	}
 }
 int uwb_app_poll(void)
 {
-//	switch(wltag_state)
-//	{
-//	case RANGE:
-//	if(HIDO_TimerGetTick()-wltag_uwbtimer>2&&uwb_rx_flag==0)
-//		{
-//				wltag_uwbtimer = HIDO_TimerGetTick();
-//				OpenUWB();
-//		}
-//	else if(HIDO_TimerGetTick()-wltag_uwbtimer>1&&uwb_rx_flag==1)
-//		{
-//				wltag_uwbtimer = HIDO_TimerGetTick();
-//				CloseUWB();
-//		}
-//		if(uwb_losttimer>g_com_map[UWB_RNAGE_TIME])
-//		{ 
-//		 wltag_statetimer = HIDO_TimerGetTick();
-//			if(uwb_rx_flag==0)//若要切换到搜索模式时没有开启则开启UWB
-//			{
-//				OpenUWB();
-//			}
-//     wltag_state = SEARCH;
-//		}
-//		break;
-//	case SEARCH:
-//		if(HIDO_TimerGetTick()-wltag_statetimer>1)
-//		{
-//		wltag_statetimer = HIDO_TimerGetTick();
-//    wltag_state = CLOSE;
-//    CloseUWB();
-//		}
-//		break;
-//	case CLOSE:
-//		if(HIDO_TimerGetTick()-wltag_statetimer>g_com_map[UWB_WAIT_TIME])
-//		{
-//		wltag_statetimer = HIDO_TimerGetTick();
-//    wltag_state = SEARCH;
-//    OpenUWB();
-//		}
-//		break;
-//	}
 	 UWBIdleTask();
 }
 int Anchor_App(void)
@@ -713,141 +747,7 @@
 				
 				
 }
-int UwbRange(void)
-{
-    uint8_t i;
-    uint16_t tempid;
-    // The following peripherals will be initialized in the uwb_open function
-    // phy/mac/aes/lsp/phy timers initialized
-    //uwb_open();
 
-//    // Set calibration parameters
-//    uwb_calibration_params_set(config.phy_cfg.ch_num);
-
-//    // set advanced parameters
-//    struct PHY_ADV_CONFIG_T adv_config = {
-//        .thres_fap_detect = 40,
-//        .nth_scale_factor = 4,
-//        .ranging_performance_mode = 0,
-//        .skip_weakest_port_en = 0,
-//    };
-//    phy_adv_params_configure(&adv_config);
-
-//    // uwb configure
-//    uwb_configure(config.phy_work_mode, board_param.tx_power_fcc[CALIB_CH(config.phy_cfg.ch_num)], &config.phy_cfg);
-
-//    ranging_frame_type_set(config.phy_cfg.sts_pkt_cfg);
-
-    // Register rx interrupt callback function
-    //mac_register_process_handler(tx_int_callback, rx_int_callback);
-
-    receive_flag = 0;
-		flag_recsuccess = 0;
-    temp_count3=phy_timer_count_get();
-    gpio_pin_set(SCL_PIN);
-		sts_lsp_store();
-    flag_temp1=uwb_rx(0, 0, range_timeout_us);//开启接收
-	
-   // while(mac_is_busy());
-  //  temp_count2=phy_timer_count_get();
-		start_receive_count=phy_timer_count_get();
-	poll_timeout=US_TO_PHY_TIMER_COUNT(range_timeout_us);//多一个多0.4ms默认0.4ms计算为0.125*4*100000,默认开启1mss
-	end_receive_count=start_receive_count+poll_timeout;
-	if(end_receive_count>=UINT32_MAX)
-	{end_receive_count-=UINT32_MAX;}
-	current_count=phy_timer_count_get();
-		while(current_count<end_receive_count||current_count>end_receive_count+HALF_SECOND_TIME)//循环接受包体,若为124.8K则是+62400000
-		{
-			current_count=phy_timer_count_get();
-			while(mac_is_busy())
-        {
-						Calibration_Time();
-            IdleTask();
-            current_count=phy_timer_count_get();
-            if(current_count>end_receive_count&&current_count<end_receive_count+HALF_SECOND_TIME)
-            {
-                    break;
-            }
-        }
-			sts_lsp_store_stop();
-			
-			
-    if(receive_flag==1)//成功接收
-    {
-
-        //if(group_id==rx_buf[GROUP_ID_IDX]&&rx_buf[MESSAGE_TYPE_IDX] == MBX_POLL&&!memcmp(&rx_buf[TAG_ID_IDX],&g_com_map[BIND_DEV_ID],2))//判断是否是和自己是同一组通讯的且为poll包
-			if(group_id==rx_buf[GROUP_ID_IDX]&&rx_buf[MESSAGE_TYPE_IDX] == MBX_POLL)//判断是否是和自己是同一组通讯的且为poll包
-        {    flag_recsuccess = 1;
-					memcpy(&g_com_receive_id,&rx_buf[TAG_ID_IDX],2);
-//					 sleep_timer_start(__MS_TO_32K_CNT(UWB_DELAY_TIME_US));//测试
-					  temp_count2=phy_timer_count_get();
-            frame_seq_nb2 = rx_buf[SEQUENCE_IDX];//获取包序
-            battary = rx_buf[BATTARY_IDX];
-            rec_nearbase_num=rx_buf[FZ_NEARBASENUM_INDEX];  //标签传过来的他与基站交互的基站id数目
-            memcpy(&tag_id_recv,&rx_buf[TAG_ID_IDX],2);
-            memcpy(rec_ancidlist,&rx_buf[FZ_NEARBASEID_INDEX],2*rec_nearbase_num);
-            memcpy(rec_ancdistlist,&rx_buf[FZ_NEARBASEID_INDEX+2*rec_nearbase_num],2*rec_nearbase_num);
-            memcpy(&rec_antdelay,&rx_buf[FZ_NEARBASEID_INDEX+rec_nearbase_num*4],2);
-            for(i=0; i<rec_nearbase_num; i++)
-            {
-                if(rec_ancidlist[i] == dev_id)
-                {		temp_recdist_before_offset=rec_ancdistlist[i];
-                    rec_ancdistlist[i]+=(int16_t)g_com_map[DIST_OFFSET];
-                    PushAnchorDataArray(tag_id_recv,rec_ancdistlist[i],battary);
-                }
-            }
-            for(i=0; i<rec_nearbase_num; i++)
-            {
-                memcpy(&tempid,&rx_buf[FZ_NEARBASEID_INDEX+i*2],2);
-                if(tempid==dev_id)//也是比id如果有就更新没有就抢占
-                {
-                    seize_anchor=0;  //非抢占。已存在列表中
-                    Anchor_RecNearPoll(i);
-                    break;
-                }
-            }
-
-            if(i==rec_nearbase_num)
-            {
-                seize_anchor=1;   //抢占anchor
-                Anchor_RecNearPoll(i);
-            }
-						recev_error_num=0;
-           	//range_timeout_us=5000;//恢复为5000进入range后
-           //LOG_INFO(TRACE_MODULE_APP,"标签ID:%X,距离: %d 包序%d\r\n",g_com_receive_id,distance,frame_seq_nb2);
-					
-					
-						gpio_pin_clr(SCL_PIN);
-        //break;去掉break变为一对多
-				}
-    } 
-			sts_lsp_store();
-			
-			break;
-		//失败或者接受被高发射机打断都会再次开启接收
-			//flag_temp1=uwb_rx(0, 0, range_timeout_us);
-	}
-		delay_us(1);
-		sts_lsp_store_stop();
-		uwb_rx_force_off(1);
-
-//		if(!flag_recsuccess)
-//		{
-//			//sleep_timer_start(__MS_TO_32K_CNT(UWB_DELAY_TIME_US-3));//测试
-//        //LOG_INFO(TRACE_MODULE_APP,"测距失败,计数:%d\r\n",recev_error_num);
-//        if(recev_error_num++>5)
-//        {
-//            recev_error_num=0;
-//            UWB_work_state=SEARCH_DEV;
-//            uwb_searchcount = 0;
-//            search_open_flag = 1;
-//        }
-			//}
-
-   
-			
-			return 0;
-}
 void Uwb_init(void)
 {
 		uwb_open();
@@ -894,219 +794,5 @@
 		phy_rx_sts_switch_mode_set(config.phy_cfg.sts_pkt_cfg, STS_SWITCH_EVERY_4SYM, 0, 0);
 		#endif
 		mac_register_process_handler(tx_int_callback, rx_int_callback);//初始化回调
-}
-//主函数绑定接受逻辑
-int UwbSearch(void)
-{
-    uint8_t i;
-    uint16_t tempid;
-    // The following peripherals will be initialized in the uwb_open function
-    // phy/mac/aes/lsp/phy timers initialized
-    uwb_open();
-	#ifdef STS_MODE
-  // Set STS key and IV
-    phy_sts_key_configure(&sts_iv_key);
-	
-	// which RX ports will be used for AoA/PDoA
-    phy_rx_ant_mode_set(RX_ANT_PORTS_COMBINATION);
-	#endif
-    // Set calibration parameters
-    uwb_calibration_params_set(config.phy_cfg.ch_num);
-
-	#ifndef STS_MODE
-   // set advanced parameters
-    struct PHY_ADV_CONFIG_T adv_config = {
-        .thres_fap_detect = 40,
-        .nth_scale_factor = 4,
-        .ranging_performance_mode = 0,
-        .skip_weakest_port_en = 0,
-    };
-		#else
-		  // set advanced parameters
-    struct PHY_ADV_CONFIG_T adv_config = {
-        .thres_fap_detect = 40,
-        .nth_scale_factor = 4,
-        .ranging_performance_mode = 3,
-        .skip_weakest_port_en = 0,
-    };
-		#endif
-    phy_adv_params_configure(&adv_config);
-
-    // uwb configure
-    uwb_configure(config.phy_work_mode, board_param.tx_power_fcc[CALIB_CH(config.phy_cfg.ch_num)], &config.phy_cfg);
-		
-		#ifdef STS_MODE
-		ranging_lib_init();
-		#endif
-    ranging_frame_type_set(config.phy_cfg.sts_pkt_cfg);
-		
-		#ifdef STS_MODE
-		aoa_aux_info_set(AOA_AUX_ANT_IQ_RSSI_PDOA_AOA_FOM);
-    aoa_steering_vector_set((const float *)((uint32_t)((config.phy_cfg.ch_num == 9) ? svec_ch9_ptr : svec_ch5_ptr) | SRAM_BASE));
-
-    aoa_param_config();
-		
-		phy_rx_sts_switch_mode_set(config.phy_cfg.sts_pkt_cfg, STS_SWITCH_EVERY_4SYM, 0, 0);
-		#endif
-    // Register rx interrupt callback function
-    mac_register_process_handler(tx_int_callback, rx_int_callback);
-		
-    receive_flag = 0;
-    temp_count3=phy_timer_count_get();
-    gpio_pin_set(SCL_PIN);
-		sts_lsp_store();
-    flag_temp2=uwb_rx(0, 0, RX_SYNC_WIN_US_TEMP);//开启接收
-    start_receive_count=phy_timer_count_get();
-    poll_timeout=US_TO_PHY_TIMER_COUNT(2000000);//多一个多0.4ms默认0.4ms计算为0.125*4*100000,默认开启1mss
-    end_receive_count=start_receive_count+poll_timeout;
-    if(end_receive_count>=UINT32_MAX)
-    {
-        end_receive_count-=UINT32_MAX;
-    }
-    current_count=phy_timer_count_get();
-    while(current_count<end_receive_count||current_count>end_receive_count+HALF_SECOND_TIME)//循环接受包体,若为124.8K则是+62400000
-    {
-        while(mac_is_busy())
-        {
-            IdleTask();
-            current_count=phy_timer_count_get();
-            if(current_count>end_receive_count&&current_count<end_receive_count+HALF_SECOND_TIME)
-            {
-                    break;
-            }
-        }
-				sts_lsp_store_stop();
-				
-				
-        temp_count2=phy_timer_count_get();
-        if(receive_flag==1)//成功接收
-        {
-//            if(group_id==rx_buf[GROUP_ID_IDX]&&rx_buf[MESSAGE_TYPE_IDX] == MBX_POLL&&!memcmp(&rx_buf[TAG_ID_IDX],&g_com_map[BIND_DEV_ID],2))//判断是否是和自己是同一组通讯的且为poll包
-            if(group_id==rx_buf[GROUP_ID_IDX]&&rx_buf[MESSAGE_TYPE_IDX] == MBX_POLL)//判断是否是和自己是同一组通讯的且为poll包
-						{   
-							  sleep_timer_start(__MS_TO_32K_CNT(UWB_DELAY_TIME_US-13));//测试
-								range_timeout_us=20000;//将下次range开启后超时时间设为20ms之后再range里恢复
-								temp_count2=phy_timer_count_get();
-                frame_seq_nb2 = rx_buf[SEQUENCE_IDX];//获取包序
-                battary = rx_buf[BATTARY_IDX];
-                rec_nearbase_num=rx_buf[FZ_NEARBASENUM_INDEX];  //标签传过来的他与基站交互的基站id数目
-                memcpy(&tag_id_recv,&rx_buf[TAG_ID_IDX],2);
-                memcpy(rec_ancidlist,&rx_buf[FZ_NEARBASEID_INDEX],2*rec_nearbase_num);
-                memcpy(rec_ancdistlist,&rx_buf[FZ_NEARBASEID_INDEX+2*rec_nearbase_num],2*rec_nearbase_num);
-                memcpy(&rec_antdelay,&rx_buf[FZ_NEARBASEID_INDEX+rec_nearbase_num*4],2);
-                for(i=0; i<rec_nearbase_num; i++)
-                {
-                    if(rec_ancidlist[i] == dev_id)
-                    {
-												temp_recdist_before_offset=rec_ancdistlist[i];
-												rec_ancdistlist[i]+=(int16_t)g_com_map[DIST_OFFSET];
-                        PushAnchorDataArray(tag_id_recv,rec_ancdistlist[i],battary);
-                    }
-                }
-                for(i=0; i<rec_nearbase_num; i++)
-                {
-                    memcpy(&tempid,&rx_buf[FZ_NEARBASEID_INDEX+i*2],2);
-                    if(tempid==dev_id)//也是比id如果有就更新没有就抢占
-                    {
-                        seize_anchor=0;  //非抢占。已存在列表中
-                        Anchor_RecNearPoll(i);
-                        break;
-                    }
-                }
-
-                if(i==rec_nearbase_num)
-                {
-                    seize_anchor=1;   //抢占anchor
-                    Anchor_RecNearPoll(i);
-                }
-                
-                gpio_pin_clr(SCL_PIN);//测试
-								LOG_INFO(TRACE_MODULE_APP,"标签ID:%X,距离: %d 信号强度ANT0:%f,信号强度ANT2: %f\r\n",g_com_map[BIND_DEV_ID],distance,sts_rssi[0],sts_rssi[2]);
-                return 1;//返回发送成功标志
-            }
-
-        }
-				temp_count3=phy_timer_count_get();
-				sts_lsp_store();
-        flag_temp2=uwb_rx(0, 0, RX_SYNC_WIN_US_TEMP);//再次开启接收
-    }
-		delay_us(2);
-		sts_lsp_store_stop();
-		uwb_rx_force_off(1);
-    // LOG_INFO(TRACE_MODULE_APP,"超时定时器:%x,%x,%x\r\n",start_receive_count,end_receive_count,current_count);
-    gpio_pin_clr(SCL_PIN);//测试
-    return 0;//返回绑定失败标志
-}
-//}
-
-#define SEARCH_TIMESTEMP 20
-void UWBPoll(void)
-{
-    switch(UWB_work_state)
-    {
-    case LINK_SUCCESS:
-    {   //连接成功进行轮询测距
-
-        uwb_led_on();
-        UwbRange();
-        uwb_led_off();
-
-    }
-    break;
-    case SEARCH_DEV:
-    {   
-			UWB_work_state=LINK_SUCCESS;
-			Uwb_init();
-//			//接包不成功或者通讯失败进入搜索模式
-//        if(search_open_flag)
-//        {
-//            LOG_INFO(TRACE_MODULE_APP,"开启搜索\r\n");
-//            search_open_flag=0;
-//            uwb_led_on();
-//            link_success_flag=UwbSearch();//第一次开启接收2s绑定失败后则进行下面1分钟后重新开启2s绑定流程
-//            uwb_led_off();
-//            if(link_success_flag)
-//                UWB_work_state=LINK_SUCCESS;
-//        }else{
-//            LOG_INFO(TRACE_MODULE_APP,"等待进入搜索模式:%d\r\n",SEARCH_TIMESTEMP-uwb_searchcount);
-//        }
-
-    }
-    break;
-    case UN_BIND:
-    {
-        uwb_led_off();//关闭uwb指示灯
-    }
-    break;
-    }
-    if(UWB_work_state==LINK_SUCCESS)
-    {   //成功时清0错误计数
-        uwb_searchcount=0;
-    }
-    if(UWB_work_state==SEARCH_DEV)
-    {
-        if(!search_open_flag)
-        {
-            if(uwb_searchcount++>SEARCH_TIMESTEMP)
-            {
-                uwb_searchcount=0;
-                search_open_flag=1;
-            }
-        }
-        //link_error_count+=g_com_map[COM_INTERVAL];
-        //if(link_error_count>=g_com_map[4G_INTERNAL])
-        //link_error_count=0;
-       // update_led_power_state();//更新灯状态
-    }
-     //LOG_INFO(TRACE_MODULE_APP,"UWB状态:%d\r\n",UWB_work_state);
-}
-
-uint8_t GetUWBBindState(void)
-{
-    if(UWB_work_state == UN_BIND)
-    {
-        return 0;
-    }
-    return 1;
 }
 

--
Gitblit v1.9.3