小车设计

利用STM32作为智能小车的主控制器来驱动智能小车的直流电机工作,电机驱动芯片采用L298N微型集成电路电机驱动芯片,配合STM32核心板使用实现四个直流电机运行和pwm软件调速,通过改变直流电机占空比的电压来改变平均电压的数值,从而改变电机的转速变化来驱动轮式机器人运行。轮式机器人行驶的状态有:前进、后退、左转、右转和停止。当轮式机器人在行驶过程中遇到障碍物,红外避障检测模块检测周围障碍物,轮式机器人自动停止或转向。通过WIFI无线信号作为传输媒介,以上位机或手机作为控制端来控制机器人的运动以及将摄像头所拍摄的视频信息在控制端界面中显示,这样便可观察轮式机器人周围的环境并对机器人进行实时监控。主要设计步骤有:

(1)根据提出方案的功能需求对智能小车进行结构设计。
(2)根据主控制器的基本结构和特点,设计总体硬件电路模块。总体硬件电路模块的设计包括电机驱动电路设计、红外避障电路设计、无线传输电路设计等。
(3)选择符合系统设计需求的系统软件,并在该软件的基础上编写驱动代码和应用软件代码。针对系统功能的具体要求,从系统信号稳定传输的角度出发,对电机驱动、调速、无线路由器系统的改造、视频信息的接受与发送、红外避障模块的改造和控制端界面的设计等进行详细的分析与设计,并完成代码的编写与调试。
(4)把硬件开发板和软件平台结合起来,对视频监控智能小车整个系统进行了整体测试。对测试中出现的问题进行相关的改进工作,进一步提高系统工作的可靠性和稳定性。

根据提出方案的功能需求,对轮式机器人的整体结构进行设计,采用双面覆铜加硬的PCB板料作为轮式机器人的底盘,其优点是:不易变形、不易折断、轻量化、不易造成短路;选用抗干扰TT马达,其加入压敏抗组的转子可抵抗电机突然启动产生的火花干扰,避免触发信号错误,可有效降低马达启动噪音,并在启动时可提供更大电流,使马力更强;使用航模级抗滑橡胶轮胎内带海绵表面平整不易变形,在避障行走时刹车不易撞上障碍物。马达用马达锁片固定到机器人底盘上,轮子通过轴与马达相连。
在这里插入图片描述在这里插入图片描述
其余硬件设备均固定到机器人底盘上,包括电池座、红外避障传感器、wifi模块、摄像头、STM32单片机主控模块和L298N电机驱动芯片。

具体设计细节请参考之前的博客,再次不做赘述

主程序代码

#include "sys.h"
#include "delay.h"    #define EN1 PAout(2)                          //L293D控制管脚定义
#define IN1 PAout(3)                          //L293D控制管脚定义
#define IN2 PAout(4)                          //L293D控制管脚定义
#define EN2 PAout(7)                          //L293D控制管脚定义
#define IN3 PAout(6)                          //L293D控制管脚定义
#define IN4 PAout(5)                          //L293D控制管脚定义#define BEEP PBout(5)                         //蜂鸣器控制管脚定义#define KEY1 PAin(8)                              //功能按键对应的管脚#define XJ_LEFT PAin(13)                      //左边循迹信号
#define XJ_RIGHT PAin(14)                     //右边循迹信号u8 pwmval_left  = 0;                          //左电机调速变量
u8 pwmval_right = 0;                          //右电机调速变量 u8 pwmval_left_init  = 6;                     //左电机速度值
u8 pwmval_right_init = 6;                     //右电机速度值 u8 right_pwm = 1;                              //左电机调速开关
u8 left_pwm  = 1;                                  //右电机调速开关      void Motor_Init(void);                        //电机接口初始化
void forward(void);                           //小车前进控制函数
void back(void);                                    //小车后退控制函数
void left_turn(void);                    //向右转
void stop(void);                                        //向左转
void right_turn(void);                            //停车
void circle_left(void);                         //原地向左转圈
void circle_right(void);                            //原地向右转圈
void left_moto(void);                         //左电机调速函数
void right_moto(void);                        //右电机调速函数
void Timerx_Init(u16 arr,u16 psc);            //定时器初始化函数
void Beep_Init(void);                         //蜂鸣器接口初始化
void Key_Init(void);                          //按键接口初始化函数
void Key_Scan(void);                          //按键1扫描函数
void Xj_Init(void);                           //循迹信号接口初始化函数
/***********************************************************实验功能
智能小车按键循迹实验,智能小车上电后,按下开发板启动按键(靠
近电源开关那个)小车开始循迹运动。要达到好的实验效果请仔细调
循迹灵敏度。接线说明:
电机驱动线:
开发板的PA2接小车底盘的M6
开发板的PA3接小车底盘的M5
开发板的PA4接小车底盘的M4
开发板的PA5接小车底盘的M3
开发板的PA6接小车底盘的M2
开发板的PA7接小车底盘的M1电源线:
开发板的5V接小车底盘的5V
开发板的GND接小车底盘的GND循迹信号线:
开发板的PA13接小车底盘的H1
开发板的PA14接小车底盘的H2
***********************************************************/
int main(void)
{Stm32_Clock_Init(9);                         //系统时钟设置delay_init(72);                               //延时初始化Motor_Init();                                    //初始化与电机连接的硬件接口Timerx_Init(9,7199);                         //10Khz的计数频率,计数到9为1ms Beep_Init();                                 //蜂鸣器接口初始化                                 Key_Init();Xj_Init();Key_Scan();                                  //按键扫描while(1)                                          {   if((XJ_LEFT==0)&&(XJ_RIGHT==0))             //两边都没有感应到黑线{forward();                                 //前进 }else if((XJ_LEFT==1)&&(XJ_RIGHT==1))        //两边都感应到黑线(这种情况基本不会出现,主要是容错处理){forward();                                 //前进}else{            if((XJ_LEFT==1)&&(XJ_RIGHT==0))             //右边感应到黑线  {delay_ms(3);if((XJ_LEFT==1)&&(XJ_RIGHT == 0)){left_turn();                                  //左转}      }                          if((XJ_RIGHT==1)&&(XJ_LEFT==0))            //左边感应到黑线  {delay_ms(3);if((XJ_RIGHT==1)&&(XJ_LEFT==0))              {         right_turn();                             //右转     }}}     }
}void Beep_Init(void)                    //蜂鸣器接口初始化
{RCC->APB2ENR|=1<<3;                    //使能PORTB时钟GPIOB->CRL&=0XFF0FFFFF;GPIOB->CRL|=0X00300000;                //PB5推挽输出GPIOB->ODR|=1<<5;                      //PB5输出高
}void Xj_Init(void)
{RCC->APB2ENR|=1<<2;               //使能PORTA时钟         GPIOA->CRH&=0XFF0FFFFF; GPIOA->CRH|=0X00800000;           //PA13上拉输入GPIOA->ODR|=1<<13;                //PA13上拉   GPIOA->CRH&=0XF0FFFFFF; GPIOA->CRH|=0X08000000;           //PA14上拉输入GPIOA->ODR|=1<<14;                //PA14上拉
}void Key_Init(void)
{RCC->APB2ENR|=1<<2;               //使能PORTA时钟         GPIOA->CRH&=0XFFFFFFF0; GPIOA->CRH|=0X00000008;           //PA8上拉输入GPIOA->ODR|=1<<8;                 //PA8上拉
} void Key_Scan(void)                //按键扫描函数
{LOOP:if(KEY1==0)                      //第一次判断按键是否按下{delay_ms(5);if(KEY1==0)                   //第二次判断按键是否按下{BEEP = 0;                    //蜂鸣器响while(KEY1 == 0);          //等待按键松开BEEP = 1;                     //蜂鸣器不响}else{goto LOOP;                 //如果第一次判断时按键没有按下则重新扫描}}else{ goto LOOP;                     //如果第二次判断时按键没有按下则重新扫描}
}void Motor_Init(void)
{RCC->APB2ENR|=1<<2;                    //使能PORTA接口时钟GPIOA->CRL&=0XFFFFF0FF;GPIOA->CRL|=0X00000300;                //PA2推挽输出GPIOA->ODR|=1<<2;                      //PA2输出高电平GPIOA->CRL&=0XFFFF0FFF;GPIOA->CRL|=0X00003000;                //PA3推挽输出GPIOA->ODR|=1<<3;                      //PA3输出高电平GPIOA->CRL&=0XFFF0FFFF;GPIOA->CRL|=0X00030000;                //PA4推挽输出GPIOA->ODR|=1<<4;                      //PA4输出高电平GPIOA->CRL&=0XFF0FFFFF;GPIOA->CRL|=0X00300000;                //PA5推挽输出GPIOA->ODR|=1<<5;                      //PA5输出高电平GPIOA->CRL&=0XF0FFFFFF;GPIOA->CRL|=0X03000000;                //PA6推挽输出GPIOA->ODR|=1<<6;                      //PA6输出高电平   GPIOA->CRL&=0X0FFFFFFF;GPIOA->CRL|=0X30000000;                //PA7推挽输出GPIOA->ODR|=1<<7;                      //PA7输出高电平
}void forward(void)                      //小车前进控制函数
{IN1 = 1;IN2 = 0;IN3 = 1;IN4 = 0;
}void back(void)                                //小车后退控制函数
{ IN1 = 0;IN2 = 1;IN3 = 0;IN4 = 1;
}void left_turn(void)                     //向左转
{  IN1 = 1;IN2 = 0; IN3 = 0;IN4 = 0;
}void right_turn(void)                      //向右转
{ IN1 = 0;IN2 = 0;IN3 = 1;IN4 = 0;
}void stop(void)                                //停车
{ IN1 = 0;IN2 = 0;   IN3 = 0;IN4 = 0;
}void circle_left(void)                   //原地向左转圈
{ IN1 = 1;IN2 = 0; IN3 = 0;IN4 = 1;
}void circle_right(void)                        //原地向右转圈
{IN1 = 0;IN2 = 1;    IN3 = 1;IN4 = 0;
}void left_moto(void)                    //左电机调速函数
{  if(left_pwm){if(pwmval_left <= pwmval_left_init){EN1 = 1; }else {EN1 = 0;}if(pwmval_left >= 20){pwmval_left = 0;}}else    {EN1 = 0;                      }
}void right_moto(void)                   //右电机调速函数
{ if(right_pwm){ if(pwmval_right <= pwmval_right_init)        {EN2 = 1;                               }else if(pwmval_right > pwmval_right_init){EN2 = 0;}if(pwmval_right >= 20){pwmval_right = 0;}}else    {EN2 = 0;                                            }
}//定时器3中断服务程序
void TIM3_IRQHandler(void)
{                                   if(TIM3->SR&0X0001)                          //溢出中断{pwmval_left  = pwmval_left  + 1;pwmval_right = pwmval_right + 1;left_moto();right_moto(); }                 TIM3->SR&=~(1<<0);                           //清除中断标志位
}//通用定时器中断初始化
//这里时钟选择为APB1的2倍,而APB1为36M
//arr:自动重装值。
//psc:时钟预分频数
//这里使用的是定时器3!
void Timerx_Init(u16 arr,u16 psc)
{RCC->APB1ENR|=1<<1;                    //TIM3时钟使能    TIM3->ARR=arr;                         //设定计数器自动重装值//刚好1ms    TIM3->PSC=psc;                         //预分频器7200,得到10Khz的计数时钟//这两个东东要同时设置才可以使用中断TIM3->DIER|=1<<0;                      //允许更新中断                  TIM3->CR1|=0x01;                       //使能定时器3MY_NVIC_Init(1,3,TIM3_IRQChannel,2);   //抢占1,子优先级3,组2
}

中断:

#include "sys.h"//设置向量表偏移地址
//NVIC_VectTab:基址
//Offset:偏移量
//CHECK OK
//091207
void MY_NVIC_SetVectorTable(u32 NVIC_VectTab, u32 Offset)
{ //检查参数合法性assert_param(IS_NVIC_VECTTAB(NVIC_VectTab));assert_param(IS_NVIC_OFFSET(Offset));     SCB->VTOR = NVIC_VectTab|(Offset & (u32)0x1FFFFF80);             //设置NVIC的向量表偏移寄存器//用于标识向量表是在CODE区还是在RAM区
}//设置NVIC分组
//NVIC_Group:NVIC分组 0~4 总共5组
//CHECK OK
//091209
void MY_NVIC_PriorityGroupConfig(u8 NVIC_Group)
{ u32 temp,temp1;     temp1=(~NVIC_Group)&0x07;                                       //取后三位temp1<<=8;temp=SCB->AIRCR;                                                //读取先前的设置temp&=0X0000F8FF;                                               //清空先前分组temp|=0X05FA0000;                                               //写入钥匙temp|=temp1;       SCB->AIRCR=temp;                                                //设置分组
}//设置NVIC
//NVIC_PreemptionPriority:抢占优先级
//NVIC_SubPriority       :响应优先级
//NVIC_Channel           :中断编号
//NVIC_Group             :中断分组 0~4
//注意优先级不能超过设定的组的范围!否则会有意想不到的错误
//组划分:
//组0:0位抢占优先级,4位响应优先级
//组1:1位抢占优先级,3位响应优先级
//组2:2位抢占优先级,2位响应优先级
//组3:3位抢占优先级,1位响应优先级
//组4:4位抢占优先级,0位响应优先级
//NVIC_SubPriority和NVIC_PreemptionPriority的原则是,数值越小,越优先
//CHECK OK
//100329
void MY_NVIC_Init(u8 NVIC_PreemptionPriority,u8 NVIC_SubPriority,u8 NVIC_Channel,u8 NVIC_Group)
{ u32 temp; u8 IPRADDR=NVIC_Channel/4;                                    //每组只能存4个,得到组地址 u8 IPROFFSET=NVIC_Channel%4;                                  //在组内的偏移IPROFFSET=IPROFFSET*8+4;                                      //得到偏移的确切位置MY_NVIC_PriorityGroupConfig(NVIC_Group);                      //设置分组temp=NVIC_PreemptionPriority<<(4-NVIC_Group);     temp|=NVIC_SubPriority&(0x0f>>NVIC_Group);temp&=0xf;                                                    //取低四位if(NVIC_Channel<32)NVIC->ISER[0]|=1<<NVIC_Channel;            //使能中断位(要清除的话,相反操作就OK)else NVIC->ISER[1]|=1<<(NVIC_Channel-32);    NVIC->IPR[IPRADDR]|=temp<<IPROFFSET;                         //设置响应优先级和抢断优先级
}//外部中断配置函数
//只针对GPIOA~G;不包括PVD,RTC和USB唤醒这三个
//参数:GPIOx:0~6,代表GPIOA~G;BITx:需要使能的位;TRIM:触发模式,1,下升沿;2,上降沿;3,任意电平触发
//该函数一次只能配置1个IO口,多个IO口,需多次调用
//该函数会自动开启对应中断,以及屏蔽线
//待测试...
void Ex_NVIC_Config(u8 GPIOx,u8 BITx,u8 TRIM)
{u8 EXTADDR;u8 EXTOFFSET;EXTADDR=BITx/4;                                              //得到中断寄存器组的编号EXTOFFSET=(BITx%4)*4;RCC->APB2ENR|=0x01;                                          //使能io复用时钟AFIO->EXTICR[EXTADDR]&=~(0x000F<<EXTOFFSET);                 //清除原来设置!!!AFIO->EXTICR[EXTADDR]|=GPIOx<<EXTOFFSET;                     //EXTI.BITx映射到GPIOx.BITx//自动设置EXTI->IMR|=1<<BITx;                                          //开启line BITx上的中断if(TRIM&0x01)EXTI->FTSR|=1<<BITx;                            //line BITx上事件下降沿触发if(TRIM&0x02)EXTI->RTSR|=1<<BITx;                            //line BITx上事件上升降沿触发
} //不能在这里执行所有外设复位!否则至少引起串口不工作.
//把所有时钟寄存器复位
//CHECK OK
//091209
void MYRCC_DeInit(void)
{                                                              RCC->APB1RSTR = 0x00000000;//复位结束             RCC->APB2RSTR = 0x00000000; RCC->AHBENR = 0x00000014;  //睡眠模式闪存和SRAM时钟使能.其他关闭.   RCC->APB2ENR = 0x00000000; //外设时钟关闭.             RCC->APB1ENR = 0x00000000;   RCC->CR |= 0x00000001;     //使能内部高速时钟HSION                                                               RCC->CFGR &= 0xF8FF0000;   //复位SW[1:0],HPRE[3:0],PPRE1[2:0],PPRE2[2:0],ADCPRE[1:0],MCO[2:0]                     RCC->CR &= 0xFEF6FFFF;     //复位HSEON,CSSON,PLLONRCC->CR &= 0xFFFBFFFF;     //复位HSEBYP        RCC->CFGR &= 0xFF80FFFF;   //复位PLLSRC, PLLXTPRE, PLLMUL[3:0] and USBPRE RCC->CIR = 0x00000000;     //关闭所有中断//配置向量表                  #ifdef  VECT_TAB_RAMMY_NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);#else   MY_NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);#endif
}//THUMB指令不支持汇编内联
//采用如下方法实现执行汇编指令WFI
//CHECK OK
//091209
__asm void WFI_SET(void)
{WFI;
}//进入待机模式
//check ok
//091202
void Sys_Standby(void)
{SCB->SCR|=1<<2;                 //使能SLEEPDEEP位 (SYS->CTRL)       RCC->APB1ENR|=1<<28;            //使能电源时钟       PWR->CSR|=1<<8;                 //设置WKUP用于唤醒PWR->CR|=1<<2;                  //清除Wake-up 标志PWR->CR|=1<<1;                  //PDDS置位          WFI_SET();                               //执行WFI指令
}     //系统软复位
//CHECK OK
//091209
void Sys_Soft_Reset(void)
{   SCB->AIRCR =0X05FA0000|(u32)0x04;
} //JTAG模式设置,用于设置JTAG的模式
//mode:jtag,swd模式设置;00,全使能;01,使能SWD;10,全关闭;
//CHECK OK
//100818
void JTAG_Set(u8 mode)
{u32 temp;temp=mode;temp<<=25;RCC->APB2ENR|=1<<0;              //开启辅助时钟      AFIO->MAPR&=0XF8FFFFFF;          //清除MAPR的[26:24]AFIO->MAPR|=temp;                //设置jtag模式
} //系统时钟初始化函数
//pll:选择的倍频数,从2开始,最大值为16
//CHECK OK
//091209
void Stm32_Clock_Init(u8 PLL)
{unsigned char temp=0;   MYRCC_DeInit();                     //复位并配置向量表RCC->CR|=0x00010000;             //外部高速时钟使能HSEONwhile(!(RCC->CR>>17));           //等待外部时钟就绪RCC->CFGR=0X00000400;            //APB1=DIV2;APB2=DIV1;AHB=DIV1;PLL-=2;//抵消2个单位RCC->CFGR|=PLL<<18;              //设置PLL值 2~16RCC->CFGR|=1<<16;                //PLLSRC ON FLASH->ACR|=0x32;               //FLASH 2个延时周期RCC->CR|=0x01000000;             //PLLONwhile(!(RCC->CR>>25));           //等待PLL锁定RCC->CFGR|=0x00000002;           //PLL作为系统时钟  while(temp!=0x02)                //等待PLL作为系统时钟设置成功{   temp=RCC->CFGR>>2;temp&=0x03;}
}           

IO口设置:

#ifndef __SYS_H
#define __SYS_H
#include <stm32f10x_map.h>
#include <stm32f10x_nvic.h>#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
#define MEM_ADDR(addr)  *((volatile unsigned long  *)(addr))
#define BIT_ADDR(addr, bitnum)   MEM_ADDR(BITBAND(addr, bitnum))
//IO口地址映射
#define GPIOA_ODR_Addr    (GPIOA_BASE+12) //0x4001080C
#define GPIOB_ODR_Addr    (GPIOB_BASE+12) //0x40010C0C
#define GPIOC_ODR_Addr    (GPIOC_BASE+12) //0x4001100C
#define GPIOD_ODR_Addr    (GPIOD_BASE+12) //0x4001140C
#define GPIOE_ODR_Addr    (GPIOE_BASE+12) //0x4001180C
#define GPIOF_ODR_Addr    (GPIOF_BASE+12) //0x40011A0C
#define GPIOG_ODR_Addr    (GPIOG_BASE+12) //0x40011E0C    #define GPIOA_IDR_Addr    (GPIOA_BASE+8)  //0x40010808
#define GPIOB_IDR_Addr    (GPIOB_BASE+8)  //0x40010C08
#define GPIOC_IDR_Addr    (GPIOC_BASE+8)  //0x40011008
#define GPIOD_IDR_Addr    (GPIOD_BASE+8)  //0x40011408
#define GPIOE_IDR_Addr    (GPIOE_BASE+8)  //0x40011808
#define GPIOF_IDR_Addr    (GPIOF_BASE+8)  //0x40011A08
#define GPIOG_IDR_Addr    (GPIOG_BASE+8)  //0x40011E08 //IO口操作,只对单一的IO口
#define PAout(n)   BIT_ADDR(GPIOA_ODR_Addr,n)  //输出
#define PAin(n)    BIT_ADDR(GPIOA_IDR_Addr,n)  //输入 #define PBout(n)   BIT_ADDR(GPIOB_ODR_Addr,n)  //输出
#define PBin(n)    BIT_ADDR(GPIOB_IDR_Addr,n)  //输入 #define PCout(n)   BIT_ADDR(GPIOC_ODR_Addr,n)  //输出
#define PCin(n)    BIT_ADDR(GPIOC_IDR_Addr,n)  //输入 #define PDout(n)   BIT_ADDR(GPIOD_ODR_Addr,n)  //输出
#define PDin(n)    BIT_ADDR(GPIOD_IDR_Addr,n)  //输入 #define PEout(n)   BIT_ADDR(GPIOE_ODR_Addr,n)  //输出
#define PEin(n)    BIT_ADDR(GPIOE_IDR_Addr,n)  //输入#define PFout(n)   BIT_ADDR(GPIOF_ODR_Addr,n)  //输出
#define PFin(n)    BIT_ADDR(GPIOF_IDR_Addr,n)  //输入#define PGout(n)   BIT_ADDR(GPIOG_ODR_Addr,n)  //输出
#define PGin(n)    BIT_ADDR(GPIOG_IDR_Addr,n)  //输入
/
//Ex_NVIC_Config专用定义
#define GPIO_A 0
#define GPIO_B 1
#define GPIO_C 2
#define GPIO_D 3
#define GPIO_E 4
#define GPIO_F 5
#define GPIO_G 6
#define FTIR   1                               //下降沿触发
#define RTIR   2                               //上升沿触发
/
//JTAG模式设置定义
#define JTAG_SWD_DISABLE   0X02
#define SWD_ENABLE         0X01
#define JTAG_SWD_ENABLE    0X00
/
void Stm32_Clock_Init(u8 PLL);                            //时钟初始化
void Sys_Soft_Reset(void);                                //系统软复位
void Sys_Standby(void);                                   //待机模式
void MY_NVIC_SetVectorTable(u32 NVIC_VectTab, u32 Offset);//设置偏移地址
void MY_NVIC_PriorityGroupConfig(u8 NVIC_Group);          //设置NVIC分组
void MY_NVIC_Init(u8 NVIC_PreemptionPriority,u8 NVIC_SubPriority,u8 NVIC_Channel,u8 NVIC_Group);//设置中断
void Ex_NVIC_Config(u8 GPIOx,u8 BITx,u8 TRIM);            //外部中断配置函数(只对GPIOA~G)
void JTAG_Set(u8 mode);
#endif

基于STM32F103智能小车黑线寻迹运动实验(有代码)相关推荐

  1. 51智能小车黑线寻迹(防出线)

    此实验需要pwm的知识,实验用到的传感器主要就是RPR220传感器:实验原理就是左右两个传感器通过对红外光进行判断,如果是黑线的话输出0,否则输出1 实验之前需要调节左右两个电位器,用一根宽度为2.6 ...

  2. 基于51单片机的智能小车(寻迹功能)

    题目:基于C52的智能小车设计与制作 1设计目的 通过构建智能小车,培养设计并实现自动控制系统的能力,在实践过程中,熟悉以单片机为核心控制芯片,设计小车的检测,驱动和显示等外围电路,采用智能控制算法实 ...

  3. ZYAR20A 亚克力2驱 蓝牙 298寻迹避障机器人 —— 小车黑线循迹实验 四驱

    在下载到开发板之前要选择好板和端口,具体参见: ZYAR20A 亚克力2驱 蓝牙 298寻迹避障机器人 -- Arduino相关设置 代码 // 智能小车黑线循迹实验 //============== ...

  4. 智能小车红外循迹原理

    循迹电路 循迹电路由收发一体的红外收发管P1,P2:电位器R18,R29:发光二极管D6,D7和芯片LM324等组成.一共有两路,对应的红外电位器用于调节灵敏度.LM234用于信号的比较,并产生比较结 ...

  5. ZYAR20A 亚克力2驱 蓝牙 298寻迹避障机器人 —— 小车黑线循迹、避障、遥控实验综合程序

    在下载到开发板之前要选择好板和端口,具体参见: ZYAR20A 亚克力2驱 蓝牙 298寻迹避障机器人 -- Arduino相关设置 注意 红外遥控程序注意将IRremote 复制到ARDuino安装 ...

  6. 中鸣循迹机器人_基于智能i5的寻迹机器人的设计

    基于智能 i5 的寻迹机器人的设计 江旭 贾婷 杨超 张婷婷 沈阳工学院信息与控制学院 [摘 要] 摘要:本文论述了基于单片机的智能循迹小车的控制过程.智能循迹 是基于自动引导机器人系统,用以实现小车 ...

  7. 基于STM32的麦克纳姆轮小车的寻迹实现

    个人博客:http://www.chenjianqu.com/ 原文链接:http://www.chenjianqu.com/show-27.html 本项目用STM32F407,麦克纳姆轮小车,八路 ...

  8. 用matlab结合STM32作上位机,基于stm32智能小车视觉控制导航的设计参考.pdf

    第 25 卷 第 9 期 电子设计工程 2017 年 5 月 Vol.25 No.9 Electronic Design Engineering May. 2017 基于STM32 智能小车视觉控制导 ...

  9. 基于stm32f103智能风扇,可以手动开关也可温控感应和红外感应。 有程序及原理图

    基于stm32f103智能风扇,可以手动开关也可温控感应和红外感应. 有程序及原理图,有论文参考. 带有k5,proteus8等软件安装教程. ID:6915648239069102LSAMX

最新文章

  1. 微信公众平台对所有公众号开放自定义菜单
  2. Elasticsearch如何做到亿级数据查询毫秒级返回?
  3. java 图形化库_java图形界面之图形化按钮
  4. 几款不同颜色LED的伏安特性
  5. linux新建samba账户,ubuntu上创建账户和samba用户
  6. web.xml配置文件详解
  7. ADO+MFC数据库编程常用语句
  8. gcc/g++版本切换与降级
  9. 计算机二级考试office 教程,全国计算机等级考试一级office教程
  10. Java EE产生的背景
  11. 试用版SQL Server 2008提示评估期已过 解决办法
  12. 多继承下的super()指向的不一定是直接父类
  13. c4d计算机丢失api-ms,遭遇 mssvc.exe svcUpdate.exe IESeven.dll DBSeven.dll病毒第2/3页
  14. tensorflow手动实现算法之一线性回归
  15. 计算机说课稿模板小学数学,【小学数学说课稿范文模板+范文(精编20篇)】 说课稿模板小学数学...
  16. 计算机应用的论文模版,完整版计算机应用技术毕业论文
  17. 29、NeRV: Neural Reflectance and Visibility Fields for Relighting and View Synthesis
  18. ftp.proxy 代理服务器搭建
  19. 手机连无线显示服务器超时,手机登录melogin.cn连接超时解决步骤
  20. php获取千千音乐的sign,关于QQ音乐sign参数的获取

热门文章

  1. java部分基础知识 (二):计算机组成原理 原码 补码 反码 按位符 移位符 按位与 按位或 按位抑或 非 分析hashMap的put方法原理
  2. 表白墙网站php源码,自适应响应式表白墙网站PHP源码 带后台管理
  3. python3 ACM模式的输入输出例子教学
  4. Javascript——高级进阶
  5. fest3d_AssertJ Fest Hamcrest
  6. 美妆个护市场真的相信“小鲜肉”吗?
  7. linux的mount bind命令
  8. 511遇见易语言计次循环首九九乘法表
  9. 网络游戏(联网进行的多人电子游戏)
  10. java回顾:MyBatis参数、sql片段、动态sql、高级查询