找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 8216|回复: 4
打印 上一主题 下一主题
收起左侧

小四轴:IAP15W4K61S4+MPU6050+福斯迷你PPM接收机

[复制链接]
跳转到指定楼层
楼主
IAP15W4K61S4+MPU6050+福斯迷你PPM接收机
非得还算稳,但是抗干扰性不太行


单片机源程序如下:
  1. #include "sys.h"
  2. #include "lib.h"
  3. #include "myiic.h"
  4. #include "mpu6050.h"
  5. #include "ano.h"


  6. #include "config.h"
  7. #include "inertial_sensor.h"
  8. #include "ahrs_dcm.h"
  9. #include "ahrs_quat.h"
  10. #include "attitude_control.h"
  11. #include "rcin.h"
  12. #include "motor.h"




  13. //====================================================
  14. //PPM
  15. data uint16_t ppm_start[8];
  16. data uint16_t ppm_value_temp[8];
  17. data uint16_t ppm_value[8] = {2750,2750,1500,2750,1500,1500};
  18. data uint8_t ppm_counter = 0;
  19. bit ppm_ok = 0;
  20. //====================================================
  21. //
  22. inertial_sensor_t ins;
  23. ahrs_quat_t ahrs_quat;
  24. attitude_control_t atti_ctrl;
  25. rcin_t rcin_roll,rcin_pitch,rcin_thr,rcin_yaw,rcin_5,rcin_6;
  26. motor_t apmotor;
  27. //======================================================
  28. uint8_t t1,t2;


  29. void fast_loop(void);
  30. void arm_check_loop(void);
  31. void  rc_loop(void);


  32. //手动模式
  33. void test_run()
  34. {
  35.         atti_ctrl.rate_bf_target.x = rcin_roll.control_in;
  36.         atti_ctrl.rate_bf_target.y = rcin_pitch.control_in;
  37.         atti_ctrl.rate_bf_target.z = rcin_yaw.control_in*3;
  38.         apmotor.throttle_out = rcin_thr.control_in;
  39. }

  40. void setup()
  41. {
  42.         inertial_sensor_init();
  43.         ahrs_quat_init();
  44.         attitude_control_init();
  45.         rcin_init();
  46.         motor_init();

  47. }
  48.        

  49. void main()
  50. {
  51.         gpio_init();
  52.         uart_init(115200);
  53.         timer1_init();        //10ms无中断

  54.         IIC_Init();
  55.         mpu6050_init();
  56.                
  57.         pwm_init();
  58.         pca_init();       
  59.         timer0_init();        //2ms中断
  60.        
  61.        
  62.         setup();
  63.        
  64.         while(1)
  65.         {                       
  66.                 while(!TF1);TF1=0;                                                        //100Hz
  67.                
  68.                 fast_loop();
  69.                
  70.                 if(ppm_ok)                                                                                        //50Hz
  71.                 {
  72.                         rc_loop();                                                                                //217us                       
  73.                 }
  74.        
  75.                 if(++t1 == 10)                                                                        //10Hz
  76.                 {
  77.                         t1 = 0;
  78.                         arm_check_loop();                                                        //解锁检测
  79.                 }
  80. //        ANO_DT_Send_Sensor(ahrs_quat.omega.z*100,apmotor.yaw_out,ahrs_quat.omega.x*100,apmotor.roll_pwm,0,0,0,0,0);
  81. //        ANO_DT_Send_Status(rcin_roll.control_in,rcin_pitch.control_in,rcin_yaw.control_in,rcin_thr.control_in,0,0);                       
  82. //        ANO_DT_Send_Status(ahrs_quat.roll_sensor,ahrs_quat.pitch_sensor,ahrs_quat.yaw_sensor,0,0,0);
  83. //        ANO_DT_Send_Sensor(acceladc[0],acceladc[1],acceladc[2],gyroadc[0],gyroadc[1],gyroadc[2],0,0,0);
  84. //        ANO_DT_Send_Sensor(rcin_thr.radio_in,rcin_thr.control_in,apmotor.throttle_pwm,0,0,0,0,0,0);
  85.         ANO_DT_Send_Sensor(ins.gyro.x*100,ins.gyro.y*100,ins.gyro.z*100,0,0,0,0,0,0);
  86. //        ANO_DT_Send_MotoPWM(apmotor.motor_out[0],apmotor.motor_out[1],apmotor.motor_out[2],apmotor.motor_out[3],0,0,0,0);

  87.         }
  88. }



  89. void fast_loop()
  90. {
  91.         ahrs_quat_update();                //更新姿态
  92.         rate_control_run();                //内环控制0.823ms->motor.roll_out,pitch_out,yaw_out
  93.         motor_output();                                //动力输出
  94.         stabilize_run();                        //外环控制
  95. }
  96. void  rc_loop()
  97. {
  98.         if(ppm_ok)
  99.         {
  100.                 rcin_set_control(&rcin_roll,ppm_value[0]);        // -> radio_in  -> control_in
  101.                 rcin_set_control(&rcin_pitch,ppm_value[1]);
  102.                 rcin_set_control(&rcin_thr,ppm_value[2]);
  103.                 rcin_set_control(&rcin_yaw,ppm_value[3]);
  104.                 ppm_ok = 0;
  105.         }
  106. }

  107. void arm_check_loop()
  108. {
  109.         static int16_t arming_counter = 0;
  110.         int16_t tmp;
  111.        
  112.         if (rcin_thr.control_in > 0)                //油门非0,直接退出
  113.         {
  114.                 arming_counter = 0;
  115.                 return;
  116.         }
  117.        
  118.         tmp = rcin_yaw.control_in;        //方向通道值
  119.         if (tmp > 4000)                                                        //contol_in对radio_in做了映射,最大是4500
  120.         {
  121.                 if (arming_counter < ARM_DELAY)
  122.                 {
  123.                         arming_counter++;
  124.                 }

  125.                 if (arming_counter == ARM_DELAY && !apmotor.armed)        //检测到解锁动作2s
  126.                 {
  127.                        
  128.                         init_arm_motors();
  129.                         arming_counter = 0;        //解锁成功                       
  130.                 }
  131.         }
  132.         else if (tmp < -4000)//上锁
  133.         {
  134.                 if (arming_counter < DISARM_DELAY)
  135.                 {
  136.                         arming_counter++;
  137.                 }
  138.                
  139.                 if (arming_counter == DISARM_DELAY && apmotor.armed)
  140.                 {
  141.                         init_disarm_motors();//上锁
  142.                         arming_counter = 0;
  143.                 }
  144.         }
  145.         else//非解锁或上锁
  146.         {
  147.                 arming_counter = 0;
  148.         }
  149.        

  150. }




  151. #define CNT_PER_US                2.5
  152. #define CNT_600US                        600*CNT_PER_US                //1500
  153. #define CNT_1100US                1100*CNT_PER_US                //2750
  154. #define CNT_1500US                1600*CNT_PER_US                //4000
  155. #define CNT_2500US                2500*CNT_PER_US                //2000+500
  156. void PCA_isr() interrupt ISR_PCA using 1
  157. {
  158.     if (CCF1)
  159.     {
  160.                         CCF1 = 0;
  161.                         if(PPM_Pin)        //上升沿
  162.                         {
  163.                                 CH = CL = 0;
  164.                         }
  165.                         else                        //下降沿
  166.                         {               
  167.                                 uint16_t value;
  168.                                 value = (CCAP1H<<8) + CCAP1L;
  169.                                 if(value > CNT_2500US)
  170.                                 {
  171.                                         ppm_value[0] = ppm_value_temp[0];
  172.                                         ppm_value[1] = ppm_value_temp[1];
  173.                                         ppm_value[2] = ppm_value_temp[2];
  174.                                         ppm_value[3] = ppm_value_temp[3];
  175. ……………………

  176. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
quad51.zip (1.16 MB, 下载次数: 69)



评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏3 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:243748 发表于 2018-1-19 12:43 来自手机 | 只看该作者
好历害,我学了一段时间还不会写程序
回复

使用道具 举报

板凳
ID:486784 发表于 2019-3-8 12:51 | 只看该作者
感谢楼主
回复

使用道具 举报

地板
ID:318672 发表于 2019-3-9 00:41 来自手机 | 只看该作者
感谢分享
回复

使用道具 举报

5#
ID:13396 发表于 2022-9-6 12:39 | 只看该作者
学习无人机,谢谢你的分享.
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表