ºúÄ­:ÉϺ£µÄ·¢Õ¹Òª¹Ø×¢¶«·½È˲Å

在近期的市市长国际企业座谈会上,提出人才是竞争时的表现,并强调上合的发展要关注东方人才,建议通过海外引进来培养本市本土人才。
¶«·½Íø¼ÇÕß½¯¼Ñ¼Ñ11ÔÂ2ÈÕ±¨µÀ£ºÔÚ½ñÌì¾ÙÐеĵÚ20´ÎÉϺ£ÊÐÊг¤¹ú¼ÊÆóÒµ¼Ò×Éѯ»áÒéÉÏ£¬ÈðÊ¿ÂÞÊϼ¯ÍŶ­Ê³¤¼æÊ×ϯִÐйٺúÄ­ÉÏÌáµ½È˲žºÕùʱ±íʾ£¬ÉϺ£µÄ·¢Õ¹Òª¹Ø×¢¶«·½È˲ţ¬Ëû½¨Òéͨ¹ýº£ÍâÅàѵÀ´ÅàÑøÉϺ£±¾ ...
#include "sys.h" #include "delay.h" #include "usart.h" #include "includes.h" #include "led.h" /************************************************ ALIENTEK ¾«Ó¢°æSTM32¿ª·¢°åUCOSʵÑé Àý6-1 UCOSIII ÈÎÎñ´´½¨ÓÚɾ³ý ¼¼ÊõÖ§³Ö£ºwww.openedv.com ÌÔ±¦µêÆÌ£ºhttp://eboard.taobao.com ¹Ø×¢Î¢ÐŹ«ÖÚÆ½Ì¨Î¢Ðźţº"ÕýµãÔ­×Ó"£¬Ãâ·Ñ»ñÈ¡STM32×ÊÁÏ¡£ ¹ãÖÝÊÐÐÇÒíµç×ӿƼ¼ÓÐÏÞ¹«Ë¾ ×÷ÕߣºÕýµãÔ­×Ó @ALIENTEK ************************************************/ //UCOSIIIÖÐÒÔÏÂÓÅÏȼ¶Óû§³ÌÐò²»ÄÜʹÓã¬ALIENTEK //½«ÕâЩÓÅÏȼ¶·ÖÅ䏸ÁËUCOSIIIµÄ5¸öϵͳÄÚ²¿ÈÎÎñ //ÓÅÏȼ¶0£ºÖжϷþÎñ·þÎñ¹ÜÀíÈÎÎñ OS_IntQTask() //ÓÅÏȼ¶1£ºÊ±ÖÓ½ÚÅÄÈÎÎñ OS_TickTask() //ÓÅÏȼ¶2£º¶¨Ê±ÈÎÎñ OS_TmrTask() //ÓÅÏȼ¶OS_CFG_PRIO_MAX-2£ºÍ³¼ÆÈÎÎñ OS_StatTask() //ÓÅÏȼ¶OS_CFG_PRIO_MAX-1£º¿ÕÏÐÈÎÎñ OS_IdleTask() /* ΪÁËʵÏÖÁÙ½çÇøµÄ±£»¤£¬UCOSIIIÌṩÁËÁ½¸öºê£ºOS_CRITICAL_ENTER() ºÍOS_CRITICAL_EXIT()¡£ µ±Ò»¸öÈÎÎñ»òÖжϽøÈëÁÙ½çÇøÊ±£¬Ëü±ØÐëµ÷ÓÃOS_CRITICAL_ENTER()ºêÒÔ»ñµÃÁÙ½çÇøµÄ±£»¤¡£ Õâ¸öºê½«½ûÓÃÖжϣ¬ÒÔÈ·±£Ö´ÐÐÁÙ½çÇøµÄ´úÂë²»»á±»ÖжϻòÇÀÕ¼£¬´Ó¶ø±£Ö¤ÁËÁÙ½çÇøµÄÔ­×ÓÐÔ¡£ µ±´úÂëÖ´ÐÐÍê±Ïʱ£¬ÈÎÎñ»òÖжϱØÐëµ÷ÓÃOS_CRITICAL_EXIT()ºêÀ´»Ö¸´Öжϣ¬ÒÔ±ãÆäËûÈÎÎñºÍÖжϿÉÒÔ·ÃÎʹ²Ïí×ÊÔ´²¢Ö´ÐÐËüÃǵĴúÂë¡£ ʹÓÃOS_CRITICAL_ENTER()ºÍOS_CRITICAL_EXIT()ºêÀ´±£»¤ÁÙ½çÇø£¬ ÄÇôÔÚÈÎÎñT1Ö´ÐеÄÕû¸öʱ¼äÄÚ£¬ÖжϽ«±»½ûÓ㬠ÆäËûÈÎÎñ½«²»ÄÜ·ÃÎʹ²Ïí×ÊÔ´²¢ÇÒÁÙ½çÇøµÄ´úÂ뽫ÒÔÔ­×Ó·½Ê½Ö´ÐÐÍê±Ï¡£ ÕâÑù¿ÉÒÔÈ·±£ÁÙ½çÇø´úÂëµÄÕýÈ·ÐÔ£¬±ÜÃ⾺ÕùÌõ¼þºÍÆäËûͬ²½ÎÊÌâ¡£ */ /* ÔÚUCOS IIIÖУ¬ÈÎÎñµÄÖ´ÐÐ˳ÐòÊÇ»ùÓÚÓÅÏȼ¶µ÷¶ÈËã·¨¡£ ÿ¸öÈÎÎñ¶¼ÓÐÒ»¸öÓÅÏȼ¶£¨0µ½255£©£¬¾ßÓиü¸ßÓÅÏȼ¶µÄÈÎÎñ±ÈµÍÓÅÏȼ¶µÄÈÎÎñ¸ü¿ÉÄܵõ½µ÷¶È¡£ UCOS IIIʹÓÃÇÀռʽµ÷¶È£¬ÕâÒâζ×ŵ±ÓÐÒ»¸ö¸ßÓÅÏȼ¶µÄÈÎÎñ¾ÍÐ÷ʱ£¬µ±Ç°ÕýÔÚÖ´ÐеÄÈÎÎñ½«±»Öжϲ¢ÇÒ¸ßÓÅÏȼ¶ÈÎÎñ½«±»Ö´ÐС£ ÕâÈ·±£Á˾ßÓиü¸ßÓÅÏȼ¶µÄÈÎÎñ¿ÉÒÔ¼°Ê±»ñµÃÖ´ÐУ¬±ÜÃⳤʱ¼ä±»µÍÓÅÏȼ¶ÈÎÎñÕ¼Óô¦ÀíÆ÷µÄÇé¿ö·¢Éú¡£ UCOS IIIÈÎÎñµÄÖ´ÐÐÊÇͨ¹ýÉÏÏÂÎÄÇл»ÊµÏֵġ£ ÉÏÏÂÎÄÇл»ÊÇÖ¸½«´¦ÀíÆ÷µÄ״̬´ÓÒ»¸öÈÎÎñ±£´æµ½Äڴ棬Ȼºó½«ÁíÒ»¸öÈÎÎñµÄ×´Ì¬×°ÔØµ½´¦ÀíÆ÷ÖУ¬ÒÔÔÚ²»¼ä¶ÏµÄÇé¿öÏÂת»»ÈÎÎñÖ´ÐС£ µ±Ò»¸öÈÎÎñÐèÒª±»ÖÐֹʱ£¬¼´Ö´ÐÐOS_TaskSuspend()º¯Êýʱ£¬UCOS III´¦ÀíÆ÷»áÖ´ÐÐÒ»¸öÈÎÎñÇл»Öжϲ¢½«¿ØÖÆÈ¨×ªÒƵ½ÁíÒ»¸öÈÎÎñ¡£ ÈÎÎñÇл»Í¨³£·¢ÉúÔÚÒÔÏÂÇé¿öÏ£º µ±ÈÎÎñÖ÷¶¯µ÷ÓÃÁËÈÎÎñ¿ØÖƺ¯Êý£¨ÀýÈ磬OS_Delay()¡¢OS_EventWait()¡¢OS_TaskSuspend()µÈ£©²¢ÍËÈÃCPUʱ£» µ±Ä³¸öÖжϷþÎñ³ÌÐò(ISR)ÔڹؼüÈÎÎñÖ´ÐÐÆÚ¼äÖ´ÐУ¨¼´ÖжÏÓÅÏȼ¶¸ßÓڹؼüÈÎÎñµÄÓÅÏȼ¶£©¡£ */ //¿ªÊ¼ÈÎÎñ£¬´´½¨ÍêÈÎÎñ¶þºÍÈÎÎñÈý¾Íɾ³ý×Ô¼º //ÈÎÎñÓÅÏȼ¶ #define START_TASK_PRIO 3 //ÈÎÎñ¶ÑÕ»´óС #define START_STK_SIZE 128 //ÈÎÎñ¿ØÖÆ¿é OS_TCB StartTaskTCB; //ÈÎÎñ¶ÑÕ» CPU_STK START_TASK_STK[START_STK_SIZE]; //ÈÎÎñº¯Êý void start_task(void *p_arg); ///ÈÎÎñ¶þÁÁµÆ£¬²¢´òÓ¡³öÐÅÏ¢ //ÈÎÎñÓÅÏȼ¶ #define TASK1_TASK_PRIO 4 //ÈÎÎñ¶ÑÕ»´óС #define TASK1_STK_SIZE 128 //ÈÎÎñ¿ØÖÆ¿é OS_TCB Task1_TaskTCB; //ÈÎÎñ¶ÑÕ» CPU_STK TASK1_TASK_STK[TASK1_STK_SIZE]; void task1_task(void *p_arg); ///ÈÎÎñÈý£¬´òÓ¡ÈÎÎñÈýÖ´ÐÐÐÅÏ¢ //ÈÎÎñÓÅÏȼ¶ #define TASK2_TASK_PRIO 5 //ÈÎÎñ¶ÑÕ»´óС #define TASK2_STK_SIZE 128 //ÈÎÎñ¿ØÖÆ¿é OS_TCB Task2_TaskTCB; //ÈÎÎñ¶ÑÕ» CPU_STK TASK2_TASK_STK[TASK2_STK_SIZE]; //ÈÎÎñº¯Êý void task2_task(void *p_arg); volatile u8 key_pressed = 0; volatile u8 current_task = 1; void KEY_Init(void) { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; // ???? GPIO_Init(GPIOA, &GPIO_InitStructure); } void Key_Scan(void) { static u8 key_up = 1; if (key_up && GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_0)) { delay_ms(20); // ?? if (GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_0)) { key_up = 0; key_pressed = 1; // ?????? } } else if (!GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_0)) { key_up = 1; } } //Ö÷º¯Êý int main(void) { OS_ERR err; CPU_SR_ALLOC(); SystemInit();//ÓÉÓÚ±¾¹¤³ÌÊÇÓÉstm32f103zet6ÒÆÖ²ËùÀ´£¬Òò´ËÕâÀïÒò¼ÓÈë±¾º¯ÊýÈ·±£delayº¯ÊýÕý³£Ê¹Óà delay_init(); //ʱÖÓ³õʼ»¯ NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//ÖжϷÖ×éÅäÖà uart_init(115200); //´®¿Ú³õʼ»¯ LED_Init(); KEY_Init(); // ??????? OSInit(&err); //³õʼ»¯UCOSIII OS_CRITICAL_ENTER(); //½øÈëÁÙ½çÇø //´´½¨¿ªÊ¼ÈÎÎñ OSTaskCreate((OS_TCB * )&StartTaskTCB, //ÈÎÎñ¿ØÖÆ¿é (CPU_CHAR * )"start task", //ÈÎÎñÃû×Ö (OS_TASK_PTR )start_task, //ÈÎÎñº¯Êý (void * )0, //´«µÝ¸øÈÎÎñº¯ÊýµÄ²ÎÊý (OS_PRIO )START_TASK_PRIO, //ÈÎÎñÓÅÏȼ¶ (CPU_STK * )&START_TASK_STK[0], //ÈÎÎñ¶ÑÕ»»ùµØÖ· (CPU_STK_SIZE)START_STK_SIZE/10, //ÈÎÎñ¶ÑÕ»Éî¶ÈÏÞλ (CPU_STK_SIZE)START_STK_SIZE, //ÈÎÎñ¶ÑÕ»´óС (OS_MSG_QTY )0, //ÈÎÎñÄÚ²¿ÏûÏ¢¶ÓÁÐÄܹ»½ÓÊÕµÄ×î´óÏûÏ¢ÊýÄ¿,Ϊ0ʱ½ûÖ¹½ÓÊÕÏûÏ¢ (OS_TICK )0, //µ±Ê¹ÄÜʱ¼äƬÂÖתʱµÄʱ¼äƬ³¤¶È£¬Îª0ʱΪĬÈϳ¤¶È£¬ (void * )0, //Óû§²¹³äµÄ´æ´¢Çø (OS_OPT )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR, //ÈÎÎñÑ¡Ïî (OS_ERR * )&err); //´æ·Å¸Ãº¯Êý´íÎóʱµÄ·µ»ØÖµ OS_CRITICAL_EXIT(); //Í˳öÁÙ½çÇø OSStart(&err); //¿ªÆôUCOSIII } //¿ªÊ¼ÈÎÎñÈÎÎñº¯Êý void start_task(void *p_arg) { OS_ERR err; CPU_SR_ALLOC(); p_arg = p_arg; CPU_Init(); #if OS_CFG_STAT_TASK_EN > 0u OSStatTaskCPUUsageInit(&err); //ͳ¼ÆÈÎÎñ #endif #ifdef CPU_CFG_INT_DIS_MEAS_EN //Èç¹ûʹÄÜÁ˲âÁ¿ÖжϹرÕʱ¼ä CPU_IntDisMeasMaxCurReset(); #endif #if OS_CFG_SCHED_ROUND_ROBIN_EN //µ±Ê¹ÓÃʱ¼äƬÂÖתµÄʱºò //ʹÄÜʱ¼äƬÂÖתµ÷¶È¹¦ÄÜ,ʱ¼äƬ³¤¶ÈΪ1¸öϵͳʱÖÓ½ÚÅÄ£¬¼È1*5=5ms OSSchedRoundRobinCfg(DEF_ENABLED,1,&err); #endif OS_CRITICAL_ENTER(); //½øÈëÁÙ½çÇø //´´½¨TASK1ÈÎÎñ OSTaskCreate((OS_TCB * )&Task1_TaskTCB, (CPU_CHAR * )"Task1 task", (OS_TASK_PTR )task1_task, (void * )0, (OS_PRIO )TASK1_TASK_PRIO, (CPU_STK * )&TASK1_TASK_STK[0], (CPU_STK_SIZE)TASK1_STK_SIZE/10, (CPU_STK_SIZE)TASK1_STK_SIZE, (OS_MSG_QTY )0, (OS_TICK )0, (void * )0, (OS_OPT )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR, (OS_ERR * )&err); //´´½¨TASK2ÈÎÎñ OSTaskCreate((OS_TCB * )&Task2_TaskTCB, (CPU_CHAR * )"task2 task", (OS_TASK_PTR )task2_task, (void * )0, (OS_PRIO )TASK2_TASK_PRIO, (CPU_STK * )&TASK2_TASK_STK[0], (CPU_STK_SIZE)TASK2_STK_SIZE/10, (CPU_STK_SIZE)TASK2_STK_SIZE, (OS_MSG_QTY )0, (OS_TICK )0, (void * )0, (OS_OPT )OS_OPT_TASK_STK_CHK|OS_OPT_TASK_STK_CLR, (OS_ERR * )&err); OS_CRITICAL_EXIT(); //Í˳öÁÙ½çÇø OSTaskDel((OS_TCB*)0,&err); //ɾ³ýstart_taskÈÎÎñ×ÔÉí } // ??1:??PB0(LED0) void task1_task(void *p_arg) { OS_ERR err; while (1) { Key_Scan(); if (key_pressed) { current_task = 2; // ?????2 key_pressed = 0; printf("Switch to Task2\n"); } else { // LED0?? GPIO_SetBits(GPIOB, GPIO_Pin_0); // LED0? OSTimeDlyHMSM(0, 0, 0, 5000, OS_OPT_TIME_HMSM_STRICT, &err); // 500ms GPIO_ResetBits(GPIOB, GPIO_Pin_0); // LED0? OSTimeDlyHMSM(0, 0, 0, 5000, OS_OPT_TIME_HMSM_STRICT, &err); // 500ms } } } void task2_task(void *p_arg) { OS_ERR err; while (1) { Key_Scan(); if (key_pressed) { current_task = 1; // ?????1 key_pressed = 0; printf("Switch back to Task1\n"); } else { // ????2??? // ??:LED1?? GPIO_SetBits(GPIOB, GPIO_Pin_1); // LED1? OSTimeDlyHMSM(0, 0, 0, 5000, OS_OPT_TIME_HMSM_STRICT, &err); // 500ms GPIO_ResetBits(GPIOB, GPIO_Pin_1); // LED1? OSTimeDlyHMSM(0, 0, 0, 5000, OS_OPT_TIME_HMSM_STRICT, &err); // 500ms } } }我现在需要刚开始时B0(任务一)LED闪烁,当按下按键后(A0)给予信息量,使得代码进入(任务二),再次摁下按键,两个任务均不执行
06-06
根据增量式PID算法原理,完成main.c文件IncPIDInit()函数pid的初始化和 int32_t BLDC_SpdPIDCalc(int32_t NextPoint)函数的编写。条件:当误差小于等于正负3时,视为无误差。 #include "main.h" #include "math.h" #include "stm32f4xx_hal.h" #include "bldc/bsp_bldc.h" #include "key/bsp_key.h" #include "beep/bsp_beep.h" #include "HMI/bsp_usartx_HMI.h" /* Ë&frac12;ÓÐÀàÐͶ¨Òå --------------------------------------------------------------*/ typedef struct { __IO int32_t SetPoint; //É趨Ŀ±ê Desired Value __IO long SumError; //Îó&sup2;îÀÛ&frac14;Æ __IO float Proportion; //±ÈÀý³£Êý Proportional Const __IO float Integral; //»ý·Ö³£Êý Integral Const __IO float Derivative; //΢·Ö³£Êý Derivative Const __IO int LastError; //Error[-1] }PID_Typedef; /* Ë&frac12;Óк궨Òå ----------------------------------------------------------------*/ //&frac12;«¸¡µãÊýxËÄÉáÎåÈëΪint32_t #define ROUND_TO_INT32(x) ((int32_t)(x)+0.5f)>=(x)? ((int32_t)(x)):((int32_t)(x)+1) #define WIN 8 #define P_DATA 0.035f // P&sup2;ÎÊý #define I_DATA 0.10f // I&sup2;ÎÊý #define D_DATA 0.0f // D&sup2;ÎÊý #define TARGET_SPEED 500 /* Ë&frac12;ÓбäÁ¿ ------------------------------------------------------------------*/ __IO int32_t flag = 0; // µÃµ&frac12;WIN´ÎËÙ¶ÈÖµµÄ±êÖ¾ __IO int32_t start_flag = 0; // Æô¶¯±êÖ¾ __IO int32_t Avg_cnt = 0; // Æ&frac12;¾ùÖµ&frac14;ÆÊý __IO float Avg_Speed[WIN]= {0};// ǰWIN´ÎµÄËÙ¶ÈÖµ static __IO int32_t BLDC_CaptureNumber = 0; // ÊäÈë&sup2;¶»ñÊý __IO PID_Typedef PID_BLDC; // BLDC PID¿ØÖÆ&frac12;á&sup1;&sup1;Ìå int32_t BLDC_SPEED_MAX = (3000); // µç»ú×î´óËÙ¶È//ĬÈÏ3000 int32_t BLDC_SPEED_MIN = (-3000); // µç»ú×î´óËÙ¶È//ĬÈÏ3000 uint32_t Time_CNT = 0; /* À©Õ&sup1;±äÁ¿ ------------------------------------------------------------------*/ /* Ë&frac12;Óк¯ÊýÔ­ÐÎ --------------------------------------------------------------*/ static void IncPIDInit(void) ; static float Avg_speed(float Speed); int32_t BLDC_SpdPIDCalc(int32_t NextPoint); void UpdateHMI_SM_PID_feedback(int32_t CaptureNumber,int32_t RPM); static void UpdateHMI_SM_PID_Param(PID_Typedef Param_Pos); void BLDC_SetTargetSpd(int32_t Spd); /* º¯ÊýÌå --------------------------------------------------------------------*/ /** * º¯Êý&sup1;¦ÄÜ: ϵͳʱÖÓÅäÖà * ÊäÈë&sup2;ÎÊý: ÎÞ * ·µ »Ø Öµ: ÎÞ * ˵ Ã÷: ÎÞ */ void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct; RCC_ClkInitTypeDef RCC_ClkInitStruct; __HAL_RCC_PWR_CLK_ENABLE(); // Ê&sup1;ÄÜPWRʱÖÓ __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);// ÉèÖõ÷Ñ&sup1;Æ÷Êä³öµçÑ&sup1;&frac14;¶±ð1 RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;// Íâ&sup2;¿¾§Õñ£¬8MHz RCC_OscInitStruct.HSEState = RCC_HSE_ON; // ´ò¿ªHSE RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; // ´ò¿ªPLL RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;// PLLʱÖÓÔ´Ñ¡ÔñHSE RCC_OscInitStruct.PLL.PLLM = 8; // 8·ÖƵMHz RCC_OscInitStruct.PLL.PLLN = 336; // 336±¶Æµ RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2; // 2·ÖƵ£¬µÃµ&frac12;168MHzÖ÷ʱÖÓ RCC_OscInitStruct.PLL.PLLQ = 7; // USB/SDIO/Ëæ»úÊý&sup2;úÉúÆ÷µÈµÄÖ÷PLL·ÖƵϵÊý HAL_RCC_OscConfig(&RCC_OscInitStruct); RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; // ϵͳʱÖÓ£º168MHz RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; // AHBʱÖÓ£º 168MHz RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4; // APB1ʱÖÓ£º42MHz RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2; // APB2ʱÖÓ£º84MHz HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_5); HAL_RCC_EnableCSS(); // Ê&sup1;ÄÜCSS&sup1;¦ÄÜ£¬ÓÅÏÈÊ&sup1;ÓÃÍâ&sup2;¿¾§Õñ£¬ÄÚ&sup2;¿Ê±ÖÓԴΪ±¸Óà // HAL_RCC_GetHCLKFreq()/1000 1msÖжÏÒ»´Î // HAL_RCC_GetHCLKFreq()/100000 10usÖжÏÒ»´Î // HAL_RCC_GetHCLKFreq()/1000000 1usÖжÏÒ»´Î HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000); // ÅäÖÃ&sup2;¢Æô¶¯ÏµÍ³µÎ´ð¶¨Ê±Æ÷ /* ϵͳµÎ´ð¶¨Ê±Æ÷ʱÖÓÔ´ */ HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK); /* ϵͳµÎ´ð¶¨Ê±Æ÷ÖжÏÓÅÏÈ&frac14;¶ÅäÖà */ HAL_NVIC_SetPriority(SysTick_IRQn, 0, 0); } /** * º¯Êý&sup1;¦ÄÜ: Ö÷º¯Êý. * ÊäÈë&sup2;ÎÊý: ÎÞ * ·µ »Ø Öµ: ÎÞ * ˵ Ã÷: ÎÞ */ int main(void) { /* ¸´Î»ËùÓÐÍâÉ裬³õÊ&frac14;»¯Flash&frac12;Ó¿ÚºÍϵͳµÎ´ð¶¨Ê±Æ÷ */ HAL_Init(); /* ÅäÖÃϵͳʱÖÓ */ SystemClock_Config(); /* ³õÊ&frac14;»¯°´&frac14;üÅäÖà */ KEY_GPIO_Init(); /* ³õÊ&frac14;»¯´®¿ÚÅäÖà */ HMI_USARTx_Init(); /* ³õÊ&frac14;»¯»ô¶û´«¸ÐÆ÷&frac12;Ó¿Ú */ HALL_TIMx_Init(); /* ³õÊ&frac14;»¯¶¨Ê±Æ÷¸÷ͨµÀÊä³ö */ BLDCMOTOR_TIMx_Init(); /* Æô¶¯¶¨Ê±Æ÷ */ HAL_TIM_Base_Start(&htimx_BLDC); /* ³õÊ&frac14;»¯PID&sup2;ÎÊý*/ IncPIDInit(); // UpdateHMI_SM_PID_Param(BLDC_sPID); /* ÔÚ·ÂÕæµÄʱºò&frac12;ûÖ&sup1;¶¨Ê±Æ÷Êä³ö */ __HAL_DBGMCU_FREEZE_TIM8(); while (1) { if(Frame.PageID == PAGE_EX_PID) { switch(Frame.ObjID ) { /* ÉèÖÃÄ¿±êÖµ */ case EX_PID_NUM_POSTAR: BLDC_SetTargetSpd( Frame.Param.Init/10 ); Frame.ObjID = NONEOBJ; break; /* ÉèÖÃPID&sup2;ÎÊýP */ case EX_PID_NUM_POSP: PID_BLDC.Proportion = Frame.Param.Init/ 1000.0f; Frame.ObjID = NONEOBJ; break; /* ÉèÖÃPID&sup2;ÎÊýI */ case EX_PID_NUM_POSI: PID_BLDC.Integral = Frame.Param.Init/ 1000.0f; Frame.ObjID = NONEOBJ; break; /* ÉèÖÃPID&sup2;ÎÊýD */ case EX_PID_NUM_POSD: PID_BLDC.Derivative = Frame.Param.Init/ 1000.0f; Frame.ObjID = NONEOBJ; break; /* È·¶¨°´Å¥£¬Æô¶¯µç»ú */ case EX_PID_BTN_CONFIG: Enable_BLDC(); start_flag = 1; Frame.ObjID = NONEOBJ; break; /* Í£Ö&sup1;°´Å¥£¬Í£Ö&sup1;µç»ú */ case EX_PID_BTN_PAUSE: Disable_BLDC(); start_flag = 0; PID_BLDC.LastError = 0;// Error[-1] PID_BLDC.SumError = 0; Frame.ObjID = NONEOBJ; break; case EX_PID_BTN_UDATE:// ¶¨Ê±ÈÎÎñ£¬ÓÉ´®¿ÚÆÁ¾ö¶¨Ê±&frac14;ä&frac14;ä¸ô UpdateHMI_SM_PID_feedback(0,BLDC_CaptureNumber); UpdateHMI_SM_PID_Param(PID_BLDC); Frame.ObjID = NONEOBJ; break; } } /* Ê&sup1;Äܵç»ú */ if(KEY1_StateRead() == KEY_DOWN) { Enable_BLDC(); start_flag = 1; } /* µç»úÍ£Ö&sup1; */ if(KEY2_StateRead() == KEY_DOWN) { Disable_BLDC(); start_flag = 0; } } } /** * º¯Êý&sup1;¦ÄÜ: PID&sup2;ÎÊý³õÊ&frac14;»¯ * ÊäÈë&sup2;ÎÊý: ÎÞ * ·µ »Ø Öµ: ÎÞ * ˵ Ã÷: ÎÞ */ void IncPIDInit(void) { PID_BLDC.LastError = 0; // Error[-1] PID_BLDC.Proportion = P_DATA; // ±ÈÀý³£Êý Proportional Const PID_BLDC.Integral = I_DATA; // »ý·Ö³£Êý Integral Const PID_BLDC.Derivative = D_DATA; // ΢·Ö³£Êý Derivative Const PID_BLDC.SetPoint = TARGET_SPEED;// É趨Ŀ±êDesired Value } /****************************** ÐÅÏ¢·´À¡º¯Êý **********************************/ ///** // * º¯Êý&sup1;¦ÄÜ£º¸üд®¿ÚÆÁ&frac12;çÃæµÄPID&sup2;ÎÊýºÍÄ¿±êÖµ // * ÊäÈë&sup2;ÎÊý£ºParam_Pos,ËÙ¶È»·µÄPID&frac12;á&sup1;&sup1;ÌåÖ¸Õë // * ·µ »Ø Öµ£ºÎÞ // * ˵ Ã÷£º¸üеÄÊÇĬÈϵÄPID&sup2;ÎÊýºÍÄ¿±êÖµ // */ static void UpdateHMI_SM_PID_Param(PID_Typedef Param_Pos) { float tmp = 0; // /* ¸üд®¿ÚÆÁµÄPID&sup2;ÎÊý,PID&sup2;ÎÊý¶&frac14;ÊÇ·Å´ó1000±¶ */ tmp = ( (float)Param_Pos.Proportion * 1000.0f ); HMI_value_setting("numPosP.val",tmp); tmp = ( (float)Param_Pos.Integral * 1000.0f ); HMI_value_setting("numPosI.val",tmp); tmp = ( (float)Param_Pos.Derivative * 1000.0f ); HMI_value_setting("numPosD.val",tmp); tmp = ( (float)Param_Pos.SetPoint ); HMI_string_setting("numPosTar.txt",tmp); } /** * º¯Êý&sup1;¦ÄÜ£º¸üд®¿ÚÆÁ&frac12;çÃæµÄÊý¾Ý * ÊäÈë&sup2;ÎÊý£ºÎÞ * ·µ »Ø Öµ£ºÎÞ * ˵ Ã÷£º¸üÐÂλÖÃÖµºÍËÙ¶ÈÖµ */ void UpdateHMI_SM_PID_feedback(int32_t CaptureNumber,int32_t RPM) { HMI_string_setting("txtPosition.txt",0); HMI_string_setting("txtSpeed.txt",RPM); /* ·¢ËÍ·´À¡Öµ */ HMI_value_setting("vatmpReal.val",RPM/10); HMI_value_setting("vatmpTarget.val",ROUND_TO_INT32(PID_BLDC.SetPoint/10)); } /******************** Ëٶȱջ· PID ¿ØÖÆÉè&frac14;Æ ***********************************/ /** * º¯Êý&sup1;¦ÄÜ: »¬¶¯ÂË&sup2;¨º¯Êý * ÊäÈë&sup2;ÎÊý: ËÙ¶ÈÖµ(r/min) * ·µ »Ø Öµ: ÂË&sup2;¨ºóµÄËÙ¶ÈÖµ(r/min) * ˵ Ã÷: ¶ÔËÙ¶ÈÖµ&frac12;øÐ묶¯ÂË&sup2;¨´¦Àí,´ó¸ÅÁ÷³Ì: * ¶ÔǰWIN´Î&sup2;ÉÑùµÄËÙ¶ÈֵȡÆ&frac12;¾ùÖµ */ float Avg_speed(float Speed) { int32_t i = 0; float Sum = 0; Avg_Speed[Avg_cnt] =Speed; Avg_cnt++; if(Avg_cnt == WIN) { Avg_cnt = 0; flag = 1; } /* ÔÚ&sup2;ÉÑù´ÎÊýÉÙÓÚn´ÎµÄÇé¿öÏÂ&frac14;ÆËã¾ùÖµ */ if(flag == 0) { for(i = 0; i<Avg_cnt;i++) { Sum += Avg_Speed[i]; } Sum /= (i+1); } /* ÇóµÃǰn´ÎµÄÆ&frac12;¾ùÖµ */ else { for(i = 0; i<WIN;i++) { Sum += Avg_Speed[i]; } Sum /= WIN; } return Sum; } /** * º¯Êý&sup1;¦ÄÜ: ϵͳµÎ´ð¶¨Ê±Æ÷Öжϻص÷º¯Êý * ÊäÈë&sup2;ÎÊý: ÎÞ * ·µ »Ø Öµ: ÎÞ * ˵ Ã÷: ÿ·¢ÉúÒ»´ÎµÎ´ð¶¨Ê±Æ÷ÖжÏ&frac12;øÈë¸Ã»Øµ÷º¯ÊýÒ»´Î */ void HAL_SYSTICK_Callback() { float speed_rpm = 0; int32_t PID_Result = 0; Time_CNT++; /* 100ms &sup2;ÉÑùÖÜÆÚ,¿ØÖÆÖÜÆÚ */ if(Time_CNT >= 100) { Time_CNT = 0; /* »ñÈ¡ËÙ¶ÈÖµ:ÓÉ&sup2;¶»ñµ&frac12;µÄÂö³åÊý³ýÒÔ×ܵÄʱ&frac14;ä Pul/t */ /* BLDCMotorÊÇ4¶Ô&frac14;«,ÐýתһȦÓÐ4¸öÂö³åÐźÅ,3ÏàUVWÐźÅÏß,&sup1;&sup2;12¸öÂö³åÐźÅ, * ÿ¸öÂö³å±ßÑØ&frac14;ÆÊýÒ»´Î,ËùÒÔBLDCMÐýתһȦ,¿ÉÒÔ&sup2;¶»ñµ&frac12;µÄ»ô¶ûÐźÅÊÇ24, * &frac14;ÆÊýÖµ¿ÉÒÔ&frac14;ÆÊýµ&frac12;24.ÿ¸öÐźűßÑØ¶&frac14;»á&sup2;¶»ñµ&frac12;&frac12;Ó¿Ú¶¨Ê±Æ÷µÄCCR1, * ÿ100ms¶ÁÈ¡&sup2;¶»ñµ&frac12;µÄʱ&frac14;äºÍÂö³åÊý,¾Í¿ÉÒԵõ&frac12;µç»úµÄËÙ¶ÈÖµ. */ if(BLDCMotor.Hall_Period == 0)//±ÜÃâ³ýÊýΪ0 { speed_rpm = 0; } else /*Ëٶȵ¥Î»:RPM*/ speed_rpm = (((float)BLDCMotor.Hall_PulNum*60*HALL_TIM_FREQ) / ((float)BLDCMotor.Hall_Period*24)); //¶ÔËÙ¶ÈÖµ×ö»¬¶¯ÂË&sup2;¨´¦Àí BLDC_CaptureNumber = (int32_t)Avg_speed(speed_rpm); BLDCMotor.Hall_Period = 0; BLDCMotor.Hall_PulNum = 0; if(start_flag == 1) { if(MotorDirction == MOTOR_DIR_CCW) BLDC_CaptureNumber = -BLDC_CaptureNumber; /* PID¿ØÖÆ&frac14;ÆËã */ PID_Result = BLDC_SpdPIDCalc(BLDC_CaptureNumber); /* ·&frac12;ÏòÅж¨ */ if(PID_Result<0) { BLDCMotor.Dir = MOTOR_DIR_CCW; BLDCMotor.PWM_Duty = -PID_Result; } else { BLDCMotor.Dir = MOTOR_DIR_CW; BLDCMotor.PWM_Duty = PID_Result; } /* Õ&frac14;¿Õ±ÈÏÞ¶¨ */ if(BLDCMotor.PWM_Duty >=(int32_t)(BLDCMOTOR_TIM_PERIOD - 100)) BLDCMotor.PWM_Duty = (int32_t)(BLDCMOTOR_TIM_PERIOD - 100); /* ¸ù¾Ýµ±Ç°Ô˶¯·&frac12;Ïò,Á¢&frac14;´ÐÞ¸ÄÕ&frac14;¿Õ±È */ BLDCMotor.uwStep = HallSensor_GetPinState(); if(MotorDirction == MOTOR_DIR_CW) { // ¸ù¾Ý˳Ðò±íµÄ&sup1;æÂÉ CW = 7 - CCW; BLDCMotor.uwStep = (uint32_t)7 - BLDCMotor.uwStep; } /* ¸ù¾Ý·&frac12;ÏòÉ趨¶ÔӦͨµÀµÄÕ&frac14;¿Õ±È */ switch(BLDCMotor.uwStep) { case 2: // AÏà case 6: __HAL_TIM_SET_COMPARE(&htimx_BLDC,TIM_CHANNEL_1,BLDCMotor.PWM_Duty); break; case 4: // BÏà case 5: __HAL_TIM_SET_COMPARE(&htimx_BLDC,TIM_CHANNEL_2,BLDCMotor.PWM_Duty); break; case 1: // CÏà case 3: __HAL_TIM_SET_COMPARE(&htimx_BLDC,TIM_CHANNEL_3,BLDCMotor.PWM_Duty); break; } /* µ±»»ÏòµÄʱºò£¬µç»ú¿ÉÄÜ»áÆô¶¯Ê§°Ü£¬ÕâÀïÖØÐÂÆô¶¯Ò»´Î */ if(MotorDirction != BLDCMotor.Dir) { Disable_BLDC(); Enable_BLDC(); } else if(speed_rpm == 0) { Disable_BLDC(); Enable_BLDC(); } } } } /** * º¯ÊýÃû³Æ£ºËٶȱջ·PID¿ØÖÆÉè&frac14;Æ * ÊäÈë&sup2;ÎÊý£ºµ±Ç°¿ØÖÆÁ¿ * ·µ »Ø Öµ£ºÄ¿±ê¿ØÖÆÁ¿ * ˵ Ã÷£ºÎÞ */ int32_t BLDC_SpdPIDCalc(int32_t NextPoint) { } /** * º¯Êý&sup1;¦ÄÜ: ÉèÖÃBLDCÄ¿±êËÙ¶È * ÊäÈë&sup2;ÎÊý: ÎÞ * ·µ »Ø Öµ: ÎÞ * ˵ Ã÷: ÏÞÖÆËÙ¶ÈÔÚãÐÖµ·¶Î§ÄÚ */ void BLDC_SetTargetSpd(int32_t Spd) { if(Spd >= BLDC_SPEED_MAX) Spd = BLDC_SPEED_MAX; if(Spd <= BLDC_SPEED_MIN) Spd = BLDC_SPEED_MIN; PID_BLDC.SetPoint = Spd; }
06-21
c51模拟IIC总线实现EEPROM存取数据//ÈÎÎñ17 ±£´æÉ趨Êý¾Ý #include <reg51.h> // #include <intrins.h> // #define DCOUNT 6 // ¶¨ÒåÊýÂë&sup1;ܵĸöÊýΪ6¸ö #define portled_s P1 // ÊýÂë&sup1;ܵĶÎÑ¡¿ÚΪP1¿Ú #define portled_b P2 // ÊýÂë&sup1;ܵÄλѡ¿ÚΪP2¿Ú #define uchar unsigned char // sbit SDA=P3^0; // ´®ÐÐÊý¾ÝÏß sbit SCL=P3^1; // ´®ÐÐʱÖÓÏß uchar idata disdat[6]; // ÊýÂë&sup1;ܵÄÏÔʾÊý×é uchar data wcnt; // ÊýÂë&sup1;ÜɨÃèλÖÃ&frac14;ÆÊýÆ÷ uchar code led[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}; // uchar code ledctrl[]={0x0fe,0x0fd,0x0fb,0x0f7,0x0ef,0x0df}; // void display(void); // void Delay5000ms(); // void Delay5us(); // void start(void); // void stop(void); // void rdack(void); // void wrack(void); // void wrnoack(void); // void sdbyte(uchar); // uchar rcvbyte(void); // void rdnb(uchar,uchar,uchar idata *); // void wrnb(uchar,uchar,uchar idata *); // //-------------mainº¯Êý------------- void main(void) // { uchar idata rdwrdat[6]; // rdwrdat[6]£º±£´æAT24C02µÄ¶ÁдÊý¾Ý uchar i; // SP=0x5f; // wcnt=0; // for(i=0;i<6;i++)disdat[i]=i; // ÏÔʾÊý¾Ý¸³³õÖµ TMOD=0x10; // TL1=(65536-2764)%256; // T1¸³&frac14;ÆÊý³õÖµ£º3ms TH1=(65536-2764)/256; // ET1=1; // EA=1; // TR1=1; // for(i=0;i<6;i++)rdwrdat[i]=disdat[i]+1; // ¸÷ÏÔʾÊý¾Ý&frac14;Ó1 wrnb(0x00,0x06,rdwrdat); // rdwrdatÖеÄ6¸öÊý±£´æÔÚAT24C02µÄ0x00¡«0x05µ¥ÔªÖÐ Delay5000ms(); rdnb(0x00,0x06,disdat); // &frac12;«AT24C02µÄ0x00--0x05µ¥ÔªÖеÄÊý¶ÁÖÁdisdatÊý×éÖÐ while(1) {PCON=PCON|0x01;} // } // //-------------¶¨Ê±ÖжÏT1·þÎñ³ÌÐò------------- void tim1() interrupt 3 using 1 // { TL1=(65536-2764)%256; // T1¸³&frac14;ÆÊý³õÖµ£º3ms TH1=(65536-2764)/256; // display(); // } // //-------------дÈën¸ö×Ö&frac12;ÚÊý¾Ý------------- //subadd£ºAT24C02×ÓµØÖ· //n£ºÐ´Èë×Ö&frac12;ÚÊý //dp£ºidataÇø´ýдÈëÊý¾ÝµÄÊ×µØÖ· void wrnb(uchar subadd,uchar n,uchar idata *dp) // { uchar i; // ¶¨Òå¾Ö&sup2;¿±äÁ¿i(Ñ­»·&frac14;ÆÊýÆ÷) start(); // &sup2;úÉúÆô¶¯ÐźŠsdbyte(0x0a0); // ·¢ËÍдѰַ×Ö&frac12;Ú rdack(); // ¶ÁAT24C02µÄÓ¦´ðÐźŠsdbyte(subadd); // ·¢ËÍ×ÓµØÖ· rdack(); // ¶ÁAT24C02µÄÓ¦´ðÐźŠfor(i=0;i<n;i++) // Ñ­»·n´Î { sdbyte(*dp); // дһ¸ö×Ö&frac12;Ú rdack(); // ¶ÁAT24C02µÄÓ¦´ðÐźŠdp++; // ÒÆ¶¯Ö¸Õë } // Ñ­»·Ìå&frac12;áÊø stop(); // &sup2;úÉúÍ£Ö&sup1;ÐźŠ} // º¯Êý&frac12;áÊø //-------------¶ÁÈ¡n¸ö×Ö&frac12;Ú------------- //subadd£ºAT24C02µÄ×ÓµØÖ· //n£º¶Á³ö×Ö&frac12;ÚÊý //dp£ºidataÇøÊ×µØÖ· void rdnb(uchar subadd,uchar n,uchar idata *dp) // { uchar i; // ¶¨Òå¾Ö&sup2;¿±äÁ¿i(Ñ­»·&frac14;ÆÊýÆ÷) start(); // &sup2;úÉúÆô¶¯ÐźŠsdbyte(0x0a0); // ·¢ËÍдѰַ×Ö&frac12;Ú rdack(); // ¶ÁAT24C02µÄÓ¦´ð sdbyte(subadd); // ·¢ËÍ×ÓµØÖ· rdack(); // ¶ÁAT24C02µÄÓ¦´ð start(); // &sup2;úÉúÆô¶¯ÐźŠsdbyte(0x0a1); // ·¢ËͶÁѰַ×Ö&frac12;Ú rdack(); // ¶ÁAT24C02µÄÓ¦´ð for(i=0;i<n;i++) // Ñ­»·n´Î { *dp=rcvbyte(); // ¶ÁÒ»¸ö×Ö&frac12;Ú£¬&sup2;¢´æÈëdpËùÖ¸Ïòµ¥Ôª dp++; // dpÖ¸ÏòÏÂÒ»&frac12;ÓÊÕµ¥Ôª if(i<n-1) wrack(); // Èô&sup2;»ÊǶÁ×îºóÒ»¸ö×Ö&frac12;Ú£¬Ôò&sup2;úÉúÓ¦´ðÐźŠelse wrnoack(); // ÊǶÁ×îºóÒ»¸ö×Ö&frac12;Ú£¬Ôò&sup2;úÉú·ÇÓ¦´ðÐźŠ} // Ñ­»·Ìå&frac12;áÊø stop(); // &sup2;úÉúÍ£Ö&sup1;ÐźŠ} // º¯Êý&frac12;áÊø //-------------·¢ËÍÆô¶¯ÐźÅ------------- void start(void) // { SDA=1; // Êý¾ÝÏßÖøߵçÆ&frac12; SCL=1; // ʱÖÓÊýÖøߵçÆ&frac12; SDA=0; // &sup2;úÉúSDAÏÂ&frac12;µÑØ Delay5us(); // ÑÓʱ5?s SCL=0; // &sup2;úÉúSCLÏÂ&frac12;µÑØ£¬×&frac14;±¸´«ÊäÊý¾Ý } // º¯Êý&frac12;áÊø //-------------·¢ËÍÍ£Ö&sup1;ÐźÅ------------- void stop() // { SDA=0; // Êý¾ÝÏßÇå0 SCL=1; // &sup2;úÉúSCLÉÏÉýÑØ Delay5us(); // ÑÓʱ5?s SDA=1; // &sup2;úÉúSDAÉÏÉýÑØ } // º¯Êý&frac12;áÊø //-------------¶ÁÓ¦´ðÐźÅ------------- void rdack(void) // { SDA=1; // Êý¾ÝÖÃ1£¬ÊÍ·ÅÊý¾ÝÏߣ¬×&frac14;±¸¶ÁSDAÏß¡£ SCL=1; // &sup2;úÉúSCLÉÏÉýÑØ Delay5us(); // ÑÓʱ5?s(¶ÔӦʱÖӵĸߵçÆ&frac12;ÆÚ) SCL=0; // &sup2;úÉúSCLÏÂ&frac12;µÑØ } // º¯Êý&frac12;áÊø //-------------дӦ´ðÐźÅ------------- void wrack(void) // { SDA=0; // &sup2;úÉúSDAÏÂ&frac12;µÑØ SCL=1; // &sup2;úÉúSCLÉÏÉýÑØ Delay5us(); // ÑÓʱ5?s(¶ÔӦʱÖӵĸߵçÆ&frac12;ÆÚ) SCL=0; // &sup2;úÉúSCLÏÂ&frac12;µÑØ } // º¯Êý&frac12;áÊø //-------------д·ÇÓ¦´ðÐźÅ------------- void wrnoack(void) // { SDA=1; // &sup2;úÉúSDAÉÏÉýÑØ SCL=1; // &sup2;úÉúSCLÉÏÉýÑØ Delay5us(); //112 ʱÖӸߵçÆ&frac12;ÆÚ5?s SCL=0; // &sup2;úÉúSCLÏÂ&frac12;µÑØ } // º¯Êý&frac12;áÊø //-------------·¢ËÍÒ»¸ö×Ö&frac12;Ú------------- void sdbyte(uchar sdat) // { uchar i; // ¶¨Òå¾Ö&sup2;¿±äÁ¿i(Ñ­»·´ÎÊý) for(i=0;i<8;i++) // Ñ­»·8´Î { if(sdat&0x80) SDA=1; // Èô×î¸ßλΪ1£¬ÔòÏòSDAÏßд1 else SDA=0; // ×î¸ßλΪ0£¬ÔòÏòSDAÏßд0 SCL=1; // &sup2;úÉúSCLÉÏÉýÑØ Delay5us(); // ÑÓʱ5?s(¶ÔӦʱÖӵĸߵçÆ&frac12;ÆÚ) SCL=0; // &sup2;úÉúSCLÏÂ&frac12;µÑØ Delay5us(); // ÑÓʱ5?s(¶ÔӦʱÖӵĵ͵çÆ&frac12;ÆÚ) sdat=sdat<<1; // ´ý·¢ËÍÊý¾Ý×óÒÆ1λ(´«ËÍ·&frac12;ÏòΪ¸ßλÔÚÏÈ) } // Ñ­»·Ìå&frac12;áÊø } // º¯Êý&frac12;áÊø //-------------&frac12;ÓÊÕÒ»¸ö×Ö&frac12;Ú------------- uchar rcvbyte(void) // { uchar i,m=0; // ¶¨Òå¾Ö&sup2;¿±äÁ¿i(Ñ­»·´ÎÊý)¡¢m(&frac12;ÓÊÕÊý¾Ý) for(i=0;i<8;i++) // Ñ­»·8´Î { SDA=1; // Êý¾ÝÏßÖÃ1£¬×&frac14;±¸¶ÁÊý¾ÝÏß SCL=1; // &sup2;úÉúSCLÉÏÉýÑØ m=m<<1; // Ô¤&frac12;ÓÊÕ0 if(SDA) m=m|1; // ÈôÊý¾ÝÏßÉÏΪ0£¬Ô¤&frac12;ÓÊÕλ¸ÄΪ1 Delay5us(); // ÑÓʱ5?s(¶ÔӦʱÖӵĸߵçÆ&frac12;ÆÚ) SCL=0; // &sup2;úÉúSCLÏÂ&frac12;µÑØ Delay5us(); // ÑÓʱ5?s(¶ÔӦʱÖӵĵ͵çÆ&frac12;ÆÚ) } // Ñ­»·Ìå&frac12;áÊø return m; // ·µ»Ø&frac12;ÓÊÕÖµ } // º¯Êý&frac12;áÊø //-------------ÏÔʾ×Ó³ÌÐò------------- void display(void) { portled_s=0; // ¶ÎÑ¡¿ÚÏûÒþÊä³ö portled_b=ledctrl[wcnt]; portled_s=led[disdat[wcnt]]; wcnt++; wcnt=wcnt%DCOUNT; } /************************************************ STC-ISP&sup2;úÉúµÄÑÓʱ³ÌÐò Ö¸Áî&frac14;¯:STC-Y1 ϵͳƵÂÊ:11.0592MHz ************************************************/ /************************************************ void Delay5us() &sup1;¦ÄÜ:5usÑÓʱ ************************************************/ void Delay5us() //@11.0592MHz { } /************************************************ void Delay5000ms() &sup1;¦ÄÜ:5sÑÓʱ ************************************************/ void Delay5000ms() //@11.0592MHz { unsigned char i, j, k; _nop_(); i = 36; j = 5; k = 211; do { do { while (--k); } while (--j); } while (--i); } 解释代码
09-27
#include <reg52.h> //------------------------- Òý&frac12;Ŷ¨Òå --------------------------// sbit BEEP = P2^0; //·äÃùÆ÷¿ØÖÆÒý&frac12;Å£¬?µçÆ&frac12;ÓÐЧ sbit LED1 = P2^3; //LED1£¬¿ØÖÆÒý&frac12;Å£¬µÍµçÆ&frac12;ÓÐЧ sbit LED2 = P2^2; //LED2£¬¿ØÖÆÒý&frac12;Å£¬µÍµçÆ&frac12;ÓÐЧ sbit LED3 = P2^1; //LED3£¬¿ØÖÆÒý&frac12;Å£¬µÍµçÆ&frac12;ÓÐЧ //ÊýÂë&sup1;ÜÒý&frac12;Ŷ¨Òå #define duanPore P0 //ÊýÂë&sup1;ܶοØÖƶ˿ڣ¬¸ßµçÆ&frac12;ÓÐЧ sbit DIG1 = P2^4; //ÊýÂë&sup1;ܵÚ1λλѡ¿ØÖƶ˿ڣ¬µÍµçÆ&frac12;ÓÐЧ sbit DIG2 = P2^5; //ÊýÂë&sup1;ܵÚ2λλѡ¿ØÖƶ˿ڣ¬µÍµçÆ&frac12;ÓÐЧ sbit DIG3 = P2^6; //ÊýÂë&sup1;ܵÚ3λλѡ¿ØÖƶ˿ڣ¬µÍµçÆ&frac12;ÓÐЧ sbit DIG4 = P2^7; //ÊýÂë&sup1;ܵÚ4λλѡ¿ØÖƶ˿ڣ¬µÍµçÆ&frac12;ÓÐЧ //°´&frac14;üÒý&frac12;Ŷ¨Òå sbit KEY1 = P1^0; //1ºÅÑ¡ÊÖ sbit KEY2 = P1^1; //2ºÅÑ¡ÊÖ sbit KEY3 = P1^2; //3ºÅÑ¡ÊÖ sbit KEY4 = P1^3; //4ºÅÑ¡ÊÖ sbit KEY5 = P1^4; //5ºÅÑ¡ÊÖ sbit KEY6 = P1^5; //6ºÅÑ¡ÊÖ sbit KEY7 = P3^2; //Ö÷³ÖÈË&frac14;ü sbit KEY8 = P3^3; //ÉèÖÃ&frac14;ü //---------------------- È«¾Ö±äÁ¿¶¨Òå --------------------// //ÊýÂë&sup1;ܶÎÂë±í£¬ÊÊÓÃÓÚ&sup1;&sup2;ÒõÊýÂë&sup1;Ü unsigned char code tab_duan[19] = { 0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f, //0~9 0x77,0x7c,0x39,0x5e,0x79,0x71, //A~F 0x40,0x00,0x48 //'-'£¬&sup1;رÕÏÔʾ£¬'=' }; unsigned char dat_buf[4] = {17, 17, 0, 5}; //ÏÔʾÊý¾Ý»º´æÇø£¬Ä¬ÈÏÉϵçÏÔʾ" 05" int time = 5, time1 = 5, time2 = 20; //µ&sup1;&frac14;ÆÊ±Ê±&frac14;䣬time1£ºÇÀ´ðµ&sup1;&frac14;ÆÊ±Ê±&frac14;䣬time2£º»Ø´ðµ&sup1;&frac14;ÆÊ±Ê±&frac14;ä unsigned char i = 0; unsigned int count = 0; //&frac14;ÆÊý»º´æ±äÁ¿ bit flag_lock = 1; //&frac14;üÅÌËø¶¨±êÖ¾£¬1£º&sup2;»Ëø¶¨£¬0£ºËø¶¨ //------------------------------- º¯ÊýÉùÃ÷ ------------------------------------// void DelayMs(unsigned int ms); //ÑÓʱº¯Êý£¬µ¥Î»£ºms void dig_scan(unsigned char *dat); unsigned char KeyScan(void); //¶ÀÁ¢°´&frac14;üɨÃè void InitTimer0(void); //¶¨Ê±Æ÷0³õÊ&frac14;»¯ void alarm(void); //±¨¾¯º¯Êý void AnswerTask(void); //ÇÀ´ðÈÎÎñ void SetTime(void); //ÉèÖõ&sup1;&frac14;ÆÊ±Ê±&frac14;ä /* Ö÷º¯Êý */ void main(void) { BEEP = 0; //ÉϵçĬÈÏ&sup1;رշäÃùÆ÷ LED1 = 1; InitTimer0(); //¶¨Ê±Æ÷0³õÊ&frac14;»¯ time = time1; //ÉϵçĬÈÏÇÀ´ðµ&sup1;&frac14;ÆÊ± while(1) { if(KeyScan() == 7) //Èç&sup1;ûÖ÷³ÖÈË&frac14;ü°´Ï£¬Ôò&frac12;øÐÐÇÀ´ð { alarm(); //·äÃùÆ÷ÏìÒ»Éù AnswerTask(); //&frac12;øÐÐÇÀ´ðÈÎÎñ } if(KeyScan() == 8) //Èç&sup1;ûÉèÖÃ&frac14;ü°´Ï£¬&frac12;øÈëÉèÖõ&sup1;&frac14;ÆÊ±Ê±&frac14;ä { alarm(); //·äÃùÆ÷ÏìÒ»Éù SetTime(); //&frac12;øÈëÉè&frac14;Ƶ&sup1;&frac14;ÆÊ±Ê±&frac14;ä } dat_buf[0] = 17; dat_buf[1] = 17; dat_buf[2] = time / 10; //È¡³öµ&sup1;&frac14;ÆÊ±µÄʮλÊý dat_buf[3] = time % 10; //È¡³öµ&sup1;&frac14;ÆÊ±µÄ¸öλÊý dig_scan(dat_buf); //&sup2;âÊÔÊýÂë&sup1;ÜÏÔʾ } } /* ÑÓʱº¯Êý£¬µ¥Î»£ºms */ void DelayMs(unsigned int ms) { unsigned char a,b,c; while(--ms) { for(c=1;c>0;c--) for(b=142;b>0;b--) for(a=2;a>0;a--); } } /* ÊýÂë&sup1;ÜÏÔʾɨÃè */ void dig_scan(unsigned char *dat) { /* ¶¯Ì¬É¨Ãè´¦Àí */ switch(i) { case 0: { duanPore = tab_duan[dat[0]]; //ÏÔʾµÚ1λÊýÂë&sup1;ÜÄÚÈÝ DIG1 = 0; break; } case 1: { duanPore = tab_duan[dat[1]]; //ÏÔʾµÚ2λÊýÂë&sup1;ÜÄÚÈÝ DIG2 = 0; //ѡͨµÚ2λÊýÂë&sup1;Ü break; } case 2: { duanPore = tab_duan[dat[2]]; //ÏÔʾµÚ3λÊýÂë&sup1;ÜÄÚÈÝ DIG3 = 0; //ѡͨµÚ3λÊýÂë&sup1;Ü break; } case 3: { duanPore = tab_duan[dat[3]]; //ÏÔʾµÚ4λÊýÂë&sup1;ÜÄÚÈÝ DIG4 = 0; //ѡͨµÚ4λÊýÂë&sup1;Ü break; } default: break; } DelayMs(5); //ɨÃèÑÓʱ10ms£¬¸ù¾Ýʵ&frac14;ÊÇé¿öÊʵ±Ð޸ĸÄÑÓʱʱ&frac14;ä DIG1 = 1; //ÏûÒþ DIG2 = 1; DIG3 = 1; DIG4 = 1; ++i; //ɨÃè±äÁ¿Ñ­»· if(i > 3) i = 0; } /* ¶ÀÁ¢°´&frac14;üɨÃè */ unsigned char KeyScan(void) { if(KEY1 == 0) //Èç&sup1;û°´&frac14;ü1°´Ï { DelayMs(10); //ÑÓʱ10msÈ¥³ý°´&frac14;ü¶¶¶¯ if(KEY1 == 0) //ÔÙÈ·ÈÏÒ»´Î°´&frac14;ü°´Ï£¬±íʾµ&frac12;Õâ°´&frac14;üÒѾ­Îȶ¨ÁË return 1; //Êä³ö°´&frac14;üÖµ1 } if(KEY2 == 0) //Èç&sup1;û°´&frac14;ü2°´Ï { DelayMs(10); //ÑÓʱ10msÈ¥³ý°´&frac14;ü¶¶¶¯ if(KEY2 == 0) //ÔÙÈ·ÈÏÒ»´Î°´&frac14;ü°´Ï£¬±íʾµ&frac12;Õâ°´&frac14;üÒѾ­Îȶ¨ÁË return 2; //Êä³ö°´&frac14;üÖµ2 } if(KEY3 == 0) //Èç&sup1;û°´&frac14;ü3°´Ï { DelayMs(10); //ÑÓʱ10msÈ¥³ý°´&frac14;ü¶¶¶¯ if(KEY3 == 0) //ÔÙÈ·ÈÏÒ»´Î°´&frac14;ü°´Ï£¬±íʾµ&frac12;Õâ°´&frac14;üÒѾ­Îȶ¨ÁË return 3; //Êä³ö°´&frac14;üÖµ3 } if(KEY4 == 0) //Èç&sup1;û°´&frac14;ü4°´Ï { DelayMs(10); //ÑÓʱ10msÈ¥³ý°´&frac14;ü¶¶¶¯ if(KEY4 == 0) //ÔÙÈ·ÈÏÒ»´Î°´&frac14;ü°´Ï£¬±íʾµ&frac12;Õâ°´&frac14;üÒѾ­Îȶ¨ÁË return 4; //Êä³ö°´&frac14;üÖµ4 } if(KEY5 == 0) //Èç&sup1;û°´&frac14;ü5°´Ï { DelayMs(10); //ÑÓʱ10msÈ¥³ý°´&frac14;ü¶¶¶¯ if(KEY5 == 0) //ÔÙÈ·ÈÏÒ»´Î°´&frac14;ü°´Ï£¬±íʾµ&frac12;Õâ°´&frac14;üÒѾ­Îȶ¨ÁË return 5; //Êä³ö°´&frac14;üÖµ5 } if(KEY6 == 0) //Èç&sup1;û°´&frac14;ü6°´Ï { DelayMs(10); //ÑÓʱ10msÈ¥³ý°´&frac14;ü¶¶¶¯ if(KEY6 == 0) //ÔÙÈ·ÈÏÒ»´Î°´&frac14;ü°´Ï£¬±íʾµ&frac12;Õâ°´&frac14;üÒѾ­Îȶ¨ÁË return 6; //Êä³ö°´&frac14;üÖµ6 } if(KEY7 == 0) //Èç&sup1;û°´&frac14;ü7°´Ï { DelayMs(10); //ÑÓʱ10msÈ¥³ý°´&frac14;ü¶¶¶¯ if(KEY7 == 0) //ÔÙÈ·ÈÏÒ»´Î°´&frac14;ü°´Ï£¬±íʾµ&frac12;Õâ°´&frac14;üÒѾ­Îȶ¨ÁË return 7; //Êä³ö°´&frac14;üÖµ7 } if(KEY8 == 0) //Èç&sup1;û°´&frac14;ü8°´Ï { DelayMs(10); //ÑÓʱ10msÈ¥³ý°´&frac14;ü¶¶¶¯ if(KEY8 == 0) //ÔÙÈ·ÈÏÒ»´Î°´&frac14;ü°´Ï£¬±íʾµ&frac12;Õâ°´&frac14;üÒѾ­Îȶ¨ÁË return 8; //Êä³ö°´&frac14;üÖµ8 } return 0; //ÎÞ°´&frac14;ü°´ÏÂÊä³ö0 } /* ¶¨Ê±Æ÷0³õÊ&frac14;»¯ */ void InitTimer0(void) { TMOD = 0x01; //ÅäÖö¨Ê±Æ÷0Ϊ&sup1;¤×÷Ä£Ê&frac12;1£¬16λ¶¨Ê±Æ÷ TH0 = (65536 - 10000) / 256; //¶¨Ê±10ms TL0 = (65536 - 10000) % 256; EA = 1; //´ò¿ª×ÜÖÐ¶Ï ET0 = 1; //´ò¿ª¶¨Ê±Æ÷0ÖÐ¶Ï TR0 = 0; //ÉϵçĬÈÏ&sup1;رն¨Ê±Æ÷0 } /* ¶¨Ê±Æ÷0ÖжϷþÎñº¯Êý£¬10ms&frac12;øÒ»´ÎÖÐ¶Ï */ void Timer0Interrupt(void) interrupt 1 { TH0 = (65536 - 10000) / 256; //¶¨Ê±10ms£¬ÖØÐÂ×°ÔØ&frac14;ÆÊýÖµ TL0 = (65536 - 10000) % 256; ++count; if(count > 100) //1sʱ&frac14;ä&frac14;ÆË㣺10ms * 100 = 1s { count = 0; //&frac14;ÆÊýÖµÇåÁã --time; //µ&sup1;&frac14;ÆÊ±Ê±&frac14;ä&frac14;õÒ»´Î if(time <= 0) //Èç&sup1;ûµ&sup1;&frac14;ÆÊ±&frac12;áÊø£¬Ôò&sup1;رն¨Ê±Æ÷0£¬Í£Ö&sup1;µ&sup1;&frac14;ÆÊ±£¬&sup2;¢Éù&sup1;ⱨ¾¯ºÍËø¶¨&frac14;üÅÌ { TR0 = 0; //&sup1;رն¨Ê±Æ÷0 BEEP = 1; //Éù&sup1;ⱨ¾¯ LED1 = 0; flag_lock = 0; //Ëø¶¨&frac14;üÅÌ } } } /* ±¨¾¯º¯Êý */ void alarm(void) { BEEP = 1; //·äÃùÆ÷ÏìһϠDelayMs(300); //ÑÓʱ300ms BEEP = 0; } /* ʵÏÖÇÀ´ðÈÎÎñ */ void AnswerTask(void) { unsigned char key_val; //°´&frac14;üÖµ»º´æ TR0 = 1; //Æô¶¯¶¨Ê±Æ÷0£¬¿ªÊ&frac14;µ&sup1;&frac14;ÆÊ± while(1) { if(flag_lock == 1) { key_val = KeyScan(); //»ñÈ¡°´&frac14;üÖµ switch(key_val) { case 1: { dat_buf[0] = key_val; //µÚ1λÊýÂë&sup1;ÜÏÔʾ1ºÅ dat_buf[1] = 16; //ÏÔʾ'-' time = time2; //»Ø´ðµ&sup1;&frac14;ÆÊ±£¬Ñ¡Êֻشðʱ&frac14;ä alarm(); //·äÃùÆ÷ÏìһϠflag_lock = 0; //Ëø¶¨&frac14;üÅÌ break; } case 2: { dat_buf[0] = key_val; //µÚ2λÊýÂë&sup1;ÜÏÔʾ2ºÅ dat_buf[1] = 16; //ÏÔʾ'-' time = time2; //»Ø´ðµ&sup1;&frac14;ÆÊ±£¬Ñ¡Êֻشðʱ&frac14;ä alarm(); //·äÃùÆ÷ÏìһϠflag_lock = 0; break; } case 3: { dat_buf[0] = key_val; //µÚ3λÊýÂë&sup1;ÜÏÔʾ3ºÅ dat_buf[1] = 16; //ÏÔʾ'-' time = time2; alarm(); //·äÃùÆ÷ÏìһϠflag_lock = 0; break; } case 4: { dat_buf[0] = key_val; //µÚ4λÊýÂë&sup1;ÜÏÔʾ4ºÅ dat_buf[1] = 16; //ÏÔʾ'-' time = time2; alarm(); //·äÃùÆ÷ÏìһϠflag_lock = 0; break; } case 5: { dat_buf[0] = key_val; //µÚ5λÊýÂë&sup1;ÜÏÔʾ5ºÅ dat_buf[1] = 16; //ÏÔʾ'-' time = time2; alarm(); //·äÃùÆ÷ÏìһϠflag_lock = 0; break; } case 6: { dat_buf[0] = key_val; //µÚ6λÊýÂë&sup1;ÜÏÔʾ6ºÅ dat_buf[1] = 16; //ÏÔʾ'-' time = time2; alarm(); //·äÃùÆ÷ÏìһϠflag_lock = 0; break; } default: break; } } dat_buf[2] = time / 10; //È¡³öµ&sup1;&frac14;ÆÊ±µÄʮλÊý dat_buf[3] = time % 10; //È¡³öµ&sup1;&frac14;ÆÊ±µÄ¸öλÊý dig_scan(dat_buf); //ÊýÂë&sup1;ÜÏÔʾÄÚÈÝ } } /* ÉèÖõ&sup1;&frac14;ÆÊ±Ê±&frac14;ä */ void SetTime(void) { unsigned char mode = 0; //0£ºµ÷&frac12;ÚÇÀ´ðµ&sup1;&frac14;ÆÊ±£¬1£ºµ÷&frac12;ڻشðµ&sup1;&frac14;ÆÊ±£¬2£ºÍ˳ö while(1) { if(KeyScan() == 8) //Èç&sup1;ûÔٴΰ´ÏÂÉèÖÃ&frac14;ü£¬ÔòÍ˳öÉèÖÃ&sup1;¦ÄÜ { alarm(); //·äÃùÆ÷ÏìÒ»Éù ++mode; if(mode >= 2) break; //Ìø³öµ±Ç°ËÀÑ­»· } if(KeyScan() == 7) //Èç&sup1;û°´ÏÂ&frac14;Ó&frac14;ü£¬&frac12;øÐе÷ʱ { alarm(); //·äÃùÆ÷ÏìÒ»Éù if(mode == 0) //µ÷&frac12;ÚÇÀ´ðµ&sup1;&frac14;ÆÊ± { ++time1; //µ&sup1;&frac14;ÆÊ±Ê±&frac14;ä&frac14;ÓÒ»´Î if(time1 > 30) //µ÷ʱ·¶Î§£º5s~30s time1 = 5; } if(mode == 1) //µ÷&frac12;ڻشðµ&sup1;&frac14;ÆÊ± { ++time2; //µ&sup1;&frac14;ÆÊ±Ê±&frac14;ä&frac14;ÓÒ»´Î if(time2 > 30) //µ÷ʱ·¶Î§£º5s~30s time2 = 5; } } /* µ÷ʱÏÔʾ´¦Àí */ if(mode == 0) { dat_buf[0] = 16; //ÏÔʾ'-' dat_buf[1] = time1 / 10; //È¡³öµ&sup1;&frac14;ÆÊ±µÄʮλÊý dat_buf[2] = time1 % 10; //È¡³öµ&sup1;&frac14;ÆÊ±µÄ¸öλÊý dat_buf[3] = 16; //ÏÔʾ'-' } if(mode == 1) { dat_buf[0] = 18; //ÏÔʾ'=' dat_buf[1] = time2 / 10; //È¡³öµ&sup1;&frac14;ÆÊ±µÄʮλÊý dat_buf[2] = time2 % 10; //È¡³öµ&sup1;&frac14;ÆÊ±µÄ¸öλÊý dat_buf[3] = 18; //ÏÔʾ'=' } dig_scan(dat_buf); //ÊýÂë&sup1;ÜÏÔʾÄÚÈÝ } time = time1; //»Øµ&frac12;Ö÷&frac12;çÃæÏÔʾÇÀ´ðµ&sup1;&frac14;ÆÊ± }写出一个这样的代码,主持人是1.0,时间调节是1.1,选手1.2-1.7,蜂鸣器是3.3,LED是3.4,数码管1234是2.0-2.3
09-19
【无人机】基于改进粒子群算法的无人机路径规划研究[和遗传算法、粒子群算法进行比较](Matlab代码实现)内容概要:本文围绕基于改进粒子群算法的无人机路径规划展开研究,重点探讨了在复杂环境中利用改进粒子群算法(PSO)实现无人机三维路径规划的方法,并将其与遗传算法(GA)、标准粒子群算法等传统优化算法进行对比分析。研究内容涵盖路径规划的多目标优化、避障策略、航路点约束以及算法收敛性和寻优能力的评估,所有实验均通过Matlab代码实现,提供了完整的仿真验证流程。文章还提到了多种智能优化算法在无人机路径规划中的应用比较,突出了改进PSO在收敛速度和全局寻优方面的优势。; 适合人群:具备一定Matlab编程基础和优化算法知识的研究生、科研人员及从事无人机路径规划、智能优化算法研究的相关技术人员。; 使用场景及目标:①用于无人机在复杂地形或动态环境下的三维路径规划仿真研究;②比较不同智能优化算法(如PSO、GA、蚁群算法、RRT等)在路径规划中的性能差异;③为多目标优化问题提供算法选型和改进思路。; 阅读建议:建议读者结合文中提供的Matlab代码进行实践操作,重点关注算法的参数设置、适应度函数设计及路径约束处理方式,同时可参考文中提到的多种算法对比思路,拓展到其他智能优化算法的研究与改进中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值