电子发烧友App

硬声App

0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示
电子发烧友网>电子资料下载>电子资料>自平衡机器人的构建

自平衡机器人的构建

2023-02-09 | zip | 0.73 MB | 次下载 | 免费

资料介绍

描述

我们构建了这个自稳定机器人作为基础设置,以展示机器人如何根据不同的传感器类型与其周围环境进行交互。

在此示例中,您可以看到配备了 24GHz 雷达和超声波传感器的机器人:

 

XMC4700 提供了几个未使用的通信接口,可以将不同类型的传感器添加到您的项目中。

有兴趣建造自己的机器人吗?在此处查找如何构建它的说明。

1) 力学

使用“ Top Plate XMC4700 ”或“ Top Plate XMC4700 电线”开始构建电线版本为电致发光线提供了一个环绕的凹口。

poYBAGPjPIWAa8BWAABpk2EtmBE422.png
顶板 XMC4700 电线
 

该部件适合从 12V 电池电压到 5V 的 DCDC 电压转换器 (WE 173010578),用于我们的控制器和可能的电致发光逆变器此外,它可以将您的电缆固定到位并固定机器人的主开关。

poYBAGPjPIiAF6CjAABglakK-EM458.png
顶板 XMC4700 电线组装
 

将 XMC4700 Relax Kit 拧在上面,并将 Motorshield 堆叠在微控制器顶部。Motorshield 提供了一个开放区域,非常适合在顶部焊接 IMU(惯性测量单元)传感器。

poYBAGPjPJ-APOm8AARpAzFYf8c81.jpeg
控制器、传感器和电源
 

继续打印和组装下部——底盘它装有两个电机以及可选的电致发光逆变器。

poYBAGPjPKGAKEoaAAAp3d7Qxeg689.png
机壳
 
poYBAGPjPKSATNLeAAAyTOuFHYw867.png
底盘安装
 

使用与电池高度相匹配的 M3 垫片将顶板安装到底盘上。

poYBAGPjPKmAAwhBAAAZIOTljF8267.png
 

为了将车轮连接到电机,我们使用了 M5 垫片,我们钻出并添加了一个螺纹以将轮轴固定到电机轴上。

pYYBAGPjPKuAKza4AAAKTVsHp58833.png
轮轴
 

为了将车轮连接到轮轴,我们打印了另一个适配器:

pYYBAGPjPK2AQNaTAAAL7xFHEto545.png
车轮适配器
 

就是这样 - 这些都是组装自稳定机器人所需的所有部件

pYYBAGPjPLSAHLgQAAMVXj60ISY36.jpeg
完整组装
 

2) 电子产品

本节简要介绍所使用的电子元件。如需更详细的信息,请查看供应商网页。

步进电机(Nema17) 当您需要设置精确位置时,步进电机很重要。对于这种不是必须的机器人,但我们用它们来驱动机器人回到它的“原位”,这是你推开它后的起点。

_b9oY0pYKSd.blob?auto=compress%2Cformat&w=740&h=555&fit=max
步进电机 Nema17
 

Arduino v2 的 Adafruit Motor/Stepper/Servo Shield这是驱动电机的功率级。它使用 TB6612 MOSFET 驱动器,每个通道具有 1.2A 的电流能力,并带有一个方便的 Arduino 库来驱动步进电机。

_76XT5noQvi.blob?auto=compress%2Cformat&w=740&h=555&fit=max
Adafruit 电机控制扩展板
 

El线我们使用电致发光 (EL) 线来显示机器人的模式。这是一根用大约 100V 和 2500Hz 的交流电压供电的电线。这将使它在整个表面发光。

_ZyG7HqH8l6.blob?auto=compress%2Cformat&w=740&h=555&fit=max
EL线
 

EL逆变器 要为我们的 EL 线产生交流电压,需要一个 EL 逆变器:输入 5V DC -> 输出 100V AC

_MM6mfFi351.blob?auto=compress%2Cformat&w=740&h=555&fit=max
EL逆变器
 

IMU BNO055该传感器将帮助我们了解机器人的位置以及它是否即将倒向一侧。为此,我们使用:绝对方向(欧拉矢量,100Hz)基于 360° 球体的三轴方向数据和角速度矢量(100Hz)三轴“旋转速度”,单位为 rad/s。

_4zkc9vvbYe.blob?auto=compress%2Cformat&w=740&h=555&fit=max
BNO055 分线板
 

XMC4700 Relax Kit是主控制器,因此也是我们机器人的大脑。它具有 Arduino Uno 引出线,可以在 Arduino IDE 中使用:

_MCYYrTPk4k.blob?auto=compress%2Cformat&w=740&h=555&fit=max
XMC 4700 Relax Kit lite
 

3)电机控制

您可以在四种模式下运行电机:Microstep (1/8)、Interleave、Single 和 Double

Microstep (1/8)执行从分离器的一个线圈到另一个线圈的平滑切换。这是最流畅但也是最慢的模式:

grafik_znM3905Tem.png?auto=compress%2Cformat&w=740&h=555&fit=max
微步进
 

在从一个线圈切换到另一个线圈期间,Interleave仅引入半步(1:2) 。这种模式比微步更快,但不是那么平滑。

grafik_9sO4cArGqW.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

双步和单(1:1)正在完成一个完整的步骤。“单”模式仅使用一个线圈作为有源线圈,而“双”模式使用两个有源线圈,因此具有更大的扭矩。这些是最快的模式,但在低速时也有点粗糙。

grafik_L4kCzAc2BJ.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

在此图中可以更好地看出不同的速度范围:

grafik_dxVVrYqckc.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

为了充分利用步进器在不同模式下的功能,我们通过从一个模式移交给另一个模式来使用所有这些功能:

grafik_yhQmY4X01S.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

不幸的是,对于任何后续控制算法来说,这都是一场噩梦,因为对于控制信号(x 轴)的不同变化,您会看到速度值(y 轴)的不同增加。这就是为什么我们将电机控制线性化,以获得控制信号与速度增加的线性关系:

grafik_PaKKGuhvIY.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

在 Arduino 中,我们可以使用这个映射函数来做到这一点:

if(Regelausgang_Lage >= -160 && Regelausgang_Lage <= 160){
        Schrittart=1; // Microschritt (beide Richtungen)
        Speed = map (Regelausgang_Lage, -160,160, -400,400);
      }
      else if (Regelausgang_Lage >=161 && Regelausgang_Lage <= 650)  {
        Schrittart=2; //Interleave (positiv)
        Speed = map (Regelausgang_Lage, 161,650, 90,400);
      }
        else if ( Regelausgang_Lage >= -650 && Regelausgang_Lage <=-161) {
        Schrittart=2; //Interleave (negativ)
        Speed = map (Regelausgang_Lage, -161,-650, -90,-400); 
       }
      if (Regelausgang_Lage >=651)  {
        Schrittart=3; //Double  (positiv)
        Speed = map (Regelausgang_Lage, 651,1300, 200,400);
       }                    
       if ( Regelausgang_Lage <= -651) {
        Schrittart=3; //Double (negativ)
        Speed = map (Regelausgang_Lage, -651,-1300, -200,-400); 
       }                    
    }

4) 控制算法

级联控制用于控制系统这意味着我们使用四个从属控制回路。这种拓扑结构的优点是可以使用多个子系统来简化复杂系统。每个子系统都由特定的控制器调节。作用于内部子系统的干扰会在影响外部控制回路之前进行调整。由于每个子系统都需要一定的时间来执行操纵变量,因此更高级别的控制系统必须慢 4 倍。该系统可分为四个子系统:

  • Lageregelung调整机器人的角度并防止机器人跌倒。为此,我们使用 PID 控制器来控制轮速。
  • Geschwindigkeitsregelung控制机器人的速度。为此,我们使用另一个 PID 控制器来控制机器人的角度。
  • Positionsregelung控制机器人相对于其起点的位置。我们使用 P 控制器来操纵机器人的速度。
  • Orientierungsregelung控制机器人移动的方向。我们为此使用另一个 P 控制器,它作用于轮速。
grafik_c6WUBw8KXL.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

由于运行这些控制算法的时间至关重要,因此它们由定时器中断触发

grafik_4ytAVqC5xR.png?auto=compress%2Cformat&w=740&h=555&fit=max
 
// Interrupt Setup
//------------------------------------------------------------------------------------------------
// Setup Postition Interrupt
//------------------------------------------------------------------------------------------------
  XMC_CCU4_SLICE_COMPARE_CONFIG_t pwm_config = {0};
            pwm_config.passive_level = XMC_CCU4_SLICE_OUTPUT_PASSIVE_LEVEL_HIGH;
            pwm_config.prescaler_initval = XMC_CCU4_SLICE_PRESCALER_32768;
            XMC_CCU4_Init(CCU41, XMC_CCU4_SLICE_MCMS_ACTION_TRANSFER_PR_CR);
            XMC_CCU4_SLICE_CompareInit(CCU41_CC43, &pwm_config);
            XMC_CCU4_EnableClock(CCU41, 3);
            XMC_CCU4_SLICE_SetTimerPeriodMatch(CCU41_CC43, 704); // Adjust last Value or Prescaler
 /* Enable compare match and period match events */
  XMC_CCU4_SLICE_EnableEvent(CCU41_CC43, XMC_CCU4_SLICE_IRQ_ID_PERIOD_MATCH);
/* Connect period match event to SR0 */
  XMC_CCU4_SLICE_SetInterruptNode(CCU41_CC43, XMC_CCU4_SLICE_IRQ_ID_PERIOD_MATCH, XMC_CCU4_SLICE_SR_ID_0);
  /* Configure NVIC */
  /* Set priority */
  NVIC_SetPriority(CCU41_0_IRQn, 10U);
  /* Enable IRQ */
  NVIC_EnableIRQ(CCU41_0_IRQn); 
        XMC_CCU4_EnableShadowTransfer(CCU41, (CCU4_GCSS_S0SE_Msk << (4 * 3)));
        XMC_CCU4_SLICE_StartTimer(CCU41_CC43);

//------------------------------------------------------------------------------------------------
// Setup Geschwindigkeit Interrupt
//------------------------------------------------------------------------------------------------
XMC_CCU4_Init(CCU42, XMC_CCU4_SLICE_MCMS_ACTION_TRANSFER_PR_CR);
            XMC_CCU4_SLICE_CompareInit(CCU42_CC43, &pwm_config);
            XMC_CCU4_EnableClock(CCU42, 3);
            XMC_CCU4_SLICE_SetTimerPeriodMatch(CCU42_CC43, 176); // Adjust last Value or Prescaler 176->25Hz 220->20Hz
 /* Enable compare match and period match events */
  XMC_CCU4_SLICE_EnableEvent(CCU42_CC43, XMC_CCU4_SLICE_IRQ_ID_PERIOD_MATCH);
/* Connect period match event to SR0 */
  XMC_CCU4_SLICE_SetInterruptNode(CCU42_CC43, XMC_CCU4_SLICE_IRQ_ID_PERIOD_MATCH, XMC_CCU4_SLICE_SR_ID_0);
  /* Configure NVIC */
  /* Set priority */
  NVIC_SetPriority(CCU42_0_IRQn, 10U);
  /* Enable IRQ */
  NVIC_EnableIRQ(CCU42_0_IRQn); 
        XMC_CCU4_EnableShadowTransfer(CCU42, (CCU4_GCSS_S0SE_Msk << (4 * 3)));
        XMC_CCU4_SLICE_StartTimer(CCU42_CC43);
        
//------------------------------------------------------------------------------------------------
// Setup Sensor Interrupt
//------------------------------------------------------------------------------------------------
XMC_CCU4_Init(CCU43, XMC_CCU4_SLICE_MCMS_ACTION_TRANSFER_PR_CR);
            XMC_CCU4_SLICE_CompareInit(CCU43_CC43, &pwm_config);
            XMC_CCU4_EnableClock(CCU43, 3);
            XMC_CCU4_SLICE_SetTimerPeriodMatch(CCU43_CC43, 43); // Adjust last Value or Prescaler 
 /* Enable compare match and period match events */
  XMC_CCU4_SLICE_EnableEvent(CCU43_CC43, XMC_CCU4_SLICE_IRQ_ID_PERIOD_MATCH);
/* Connect period match event to SR0 */
  XMC_CCU4_SLICE_SetInterruptNode(CCU43_CC43, XMC_CCU4_SLICE_IRQ_ID_PERIOD_MATCH, XMC_CCU4_SLICE_SR_ID_0);
  /* Configure NVIC */
  /* Set priority */
  NVIC_SetPriority(CCU43_0_IRQn, 10U);
  /* Enable IRQ */
  NVIC_EnableIRQ(CCU43_0_IRQn); 
       XMC_CCU4_EnableShadowTransfer(CCU43, (CCU4_GCSS_S0SE_Msk << (4 * 3)));
       XMC_CCU4_SLICE_StartTimer(CCU43_CC43

4.1 位置控制 - “Lageregelung”

请记住 - 我们调整机器人的角度并防止机器人跌倒。为了设置一定的角度,电机轴以低于重心(机器人站立)或通过加速力矩(机器人移动)建立力矩平衡的方式移动。位置控制回路通过 100 Hz 的定时器中断调用。可以描述如下:

grafik_AT8jPTavpi.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

PID控制器:

grafik_WXVemnwG4g.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

P - 比例份额是将我们的角度偏移量乘以一个常数因子“Kp”你可以把它想象成一个杠杆的长度来推动偏移量

I - 积分部分术语“Ki”不仅增加了与错误相关的动作,而且还增加了错误持续的时间。我们只需将当前偏移量添加到“积分器”值。

D-微分项“Kd”不考虑误差,而是误差的变化率。幸运的是,我们的传感器已经通过测量角速度矢量来测量这一点。D 部分对系统起到阻尼器的作用。

//------------------------------------------------------------------------------------------------
// PID Lageregler 
//------------------------------------------------------------------------------------------------
    Winkelabweichung  = (double(euler.z())-sollWinkel);  
    integrator_Lage   = constrain (integrator_Lage + Winkelabweichung,-integrator_LageMAX, integrator_LageMAX); // I Anteil der Lageregelung wird begrenzt
    Regelausgang_Lage = constrain (KP_Lage*Winkelabweichung\
                                 + KI_Lage * integrator_Lage\
                                 + KD_Lage*double(gyroscope.x()),-1300, 1300);                                  // Begrenzung auf Schrittmotorkennlinie

4.1.1 调整位置控制器

我们通过调整 PID 控制算法的参数 Kp、Ki、Kd 来调整控制器。使用的方法称为“齐格勒-尼科尔斯调谐法”。保持 Ki 和 Kd 为 0,同时增加 Kp,直到系统达到稳定极限,从而进入谐波振荡。通过这种方式在 out case 中找到的值被称为 Kp_krit=200 并显示了 300ms 的周期。

grafik_uGo9WT1WKF.png?auto=compress%2Cformat&w=740&h=555&fit=max
谐波振荡
 

使用下表计算 Kd = Kp*Tv 和 Ki = Kp/Tn

grafik_UNZDHijMcM.png?auto=compress%2Cformat&w=740&h=555&fit=max
齐格勒-尼科尔斯表
 

注意:在我们的例子中 Ki 为 800,但是当我们每秒增加 100 次时,我们将它降低到 8。

4.2 速度控制 - “Geschwindigkeitsregelung”

速度控制器控制机器人的速度。为此,我们使用另一个 PID 控制器来控制机器人的角度。位置控制回路通过 25Hz 的定时器中断调用。可以描述如下:

grafik_Wg0SvSiOiA.png?auto=compress%2Cformat&w=740&h=555&fit=max
速度控制
 

机器人的轮速由我们的“Lageregelung”控制回路给出。我们还使用低通滤波器对该值进行了平滑处理。然后我们还通过获取实际速度值和上次速度值以及测量它们之间的 40ms (25Hz) 时间差来计算加速度。

PID控制器:

grafik_NrbrHOM6do.png?auto=compress%2Cformat&w=740&h=555&fit=max
PID速度控制
 
void get_sollsollWinkel() {
//--------------------------------------------------------------------------------------------------------------------------------------------------------------
// Tiefpassfilter
//--------------------------------------------------------------------------------------------------------------------------------------------------------------
      Regelausgang_Lage_5 = Regelausgang_Lage_4;
      Regelausgang_Lage_4 = Regelausgang_Lage_3;
      Regelausgang_Lage_3 = Regelausgang_Lage_2;
      Regelausgang_Lage_2 = Regelausgang_Lage_1;
      Regelausgang_Lage_1 = Regelausgang_Lage;

      Regelausgang_Lage_filter = (Regelausgang_Lage_1 \
                                + Regelausgang_Lage_2 \
                                + Regelausgang_Lage_3 \
                                + Regelausgang_Lage_4 \
                                + Regelausgang_Lage_5)/5;   
        
//--------------------------------------------------------------------------------------------------------------------------------------------------------------
// Bilden der Geschwindigkeitsableitung
//--------------------------------------------------------------------------------------------------------------------------------------------------------------
    
      d_Geschwindigkeit = (Regelausgang_Lage_filter - Regelausgang_Lage_filter_alt)\
                          /Ta_Geschwindigkeitsregler;
      Regelausgang_Lage_filter_alt = Regelausgang_Lage_filter;
        
//--------------------------------------------------------------------------------------------------------------------------------------------------------------
// Geschwindigkeitsregler -> Ausgang sollWinkel
//--------------------------------------------------------------------------------------------------------------------------------------------------------------

     Geschwindigkeitsabweichung = sollGeschwindigkeit - Regelausgang_Lage_filter;

     if (abs(Positionsabweichung) <= 15 ) {  //Regelparameter bei geringer Positionsabweichung
           KP_geschw = 0.0045;               // Proportionalanteil des Geschwindigkeitsreglers
           KI_geschw = 0.0009;               // Integralanteil des Geschwindigkeitsreglers  
           KD_geschw = 0.000;                // Differentianteil des Geschwindigkeitsreglers  
     }     
     else{                                   //Regelparameter bei größerer Positionsabweichung
           KP_geschw = 0.0090;               // Proportionalanteil des Geschwindigkeitsreglers
           KI_geschw = 0.0007;               // Integralanteil des Geschwindigkeitsreglers  
           KD_geschw = 0.0002;               // Differentianteil des Geschwindigkeitsreglers  
     }
           
           integrator_geschw = constrain(integrator_geschw + Geschwindigkeitsabweichung,\
                               -sollWinkelMAX/KI_geschw, sollWinkelMAX/KI_geschw);   //I Anteil wird begrenzt
           sollWinkel        = constrain(KP_geschw * Geschwindigkeitsabweichung \   
                                       + KI_geschw * integrator_geschw \                           
                                       + KD_geschw * d_Geschwindigkeit,\                                  
                                       -sollWinkelMAX, sollWinkelMAX);               //Winkelbegrenzung
  }

4.2.1 调整速度控制器

速度控制器的调整与位置控制器相同。使用 PID,我们仍然会看到低速偏移的振荡。切换到用于低速偏移的 PI 控制器解决了这个问题。在此我们降低了 Kp 并稍微增加了 Ki。这是一个尝试 ;)

4.3 位置控制——“Positionsregelung”

该控制器控制机器人相对于其初始位置的位置。通过计算步进器的旋转步数可以知道该位置。作用于机器人速度的简单 P 控制器就足够了:

grafik_ab63kPbryO.png?auto=compress%2Cformat&w=740&h=555&fit=max
 

我们尝试了不同的 Kp 值。在 Kp=4 时,显示了最佳的控制器性能。

grafik_ng1ruKVoul.png?auto=compress%2Cformat&w=740&h=555&fit=max
 
void get_sollGeschwindigkeit() {
//--------------------------------------------------------------------------------------------------------------------------------------------------------------
// Positionsregler -> Ausgang sollGeschwindigkeit
//--------------------------------------------------------------------------------------------------------------------------------------------------------------      
 Positionsabweichung  = (sollPosition - pos_aktuell);
 
   //+++Ausweichen+++    
       if (Distanz_X1 <= 15 && Distanz_X1 > 0) {      //Einschaltschwelle "Hand folgen"
        KP_dist_X1 = 75;
        KP_pos = 0;
        EL_threshold = 1;                             //EL-Wire leuchtet
       }                                              
   //+++Positionsregler+++                            
       else if (Distanz_X1 > 30 || Distanz_X1 == 0) { //Ausschaltschwelle "Hand folgen"
         KP_dist_X1 = 0;
         KP_pos = 4;
         EL_threshold = constrain(abs(Positionsabweichung),0,300)* -0.15 + 50;
                                                     //EL-Wire blinkt(2-10Hz)              
       }
       else {/*Hysterese*/}

        sollGeschwindigkeit  =  constrain (KP_pos*Positionsabweichung  \
                                         + KP_dist_X1*(-15+Distanz_X1),\
                                -GeschwindigkeitMAX, GeschwindigkeitMAX);      

}

下载该资料的人也在下载 下载该资料的人还在阅读
更多 >

评论

查看更多

下载排行

本周

  1. 1山景DSP芯片AP8248A2数据手册
  2. 1.06 MB  |  532次下载  |  免费
  3. 2RK3399完整板原理图(支持平板,盒子VR)
  4. 3.28 MB  |  339次下载  |  免费
  5. 3TC358743XBG评估板参考手册
  6. 1.36 MB  |  330次下载  |  免费
  7. 4DFM软件使用教程
  8. 0.84 MB  |  295次下载  |  免费
  9. 5元宇宙深度解析—未来的未来-风口还是泡沫
  10. 6.40 MB  |  227次下载  |  免费
  11. 6迪文DGUS开发指南
  12. 31.67 MB  |  194次下载  |  免费
  13. 7元宇宙底层硬件系列报告
  14. 13.42 MB  |  182次下载  |  免费
  15. 8FP5207XR-G1中文应用手册
  16. 1.09 MB  |  178次下载  |  免费

本月

  1. 1OrCAD10.5下载OrCAD10.5中文版软件
  2. 0.00 MB  |  234315次下载  |  免费
  3. 2555集成电路应用800例(新编版)
  4. 0.00 MB  |  33566次下载  |  免费
  5. 3接口电路图大全
  6. 未知  |  30323次下载  |  免费
  7. 4开关电源设计实例指南
  8. 未知  |  21549次下载  |  免费
  9. 5电气工程师手册免费下载(新编第二版pdf电子书)
  10. 0.00 MB  |  15349次下载  |  免费
  11. 6数字电路基础pdf(下载)
  12. 未知  |  13750次下载  |  免费
  13. 7电子制作实例集锦 下载
  14. 未知  |  8113次下载  |  免费
  15. 8《LED驱动电路设计》 温德尔著
  16. 0.00 MB  |  6656次下载  |  免费

总榜

  1. 1matlab软件下载入口
  2. 未知  |  935054次下载  |  免费
  3. 2protel99se软件下载(可英文版转中文版)
  4. 78.1 MB  |  537798次下载  |  免费
  5. 3MATLAB 7.1 下载 (含软件介绍)
  6. 未知  |  420027次下载  |  免费
  7. 4OrCAD10.5下载OrCAD10.5中文版软件
  8. 0.00 MB  |  234315次下载  |  免费
  9. 5Altium DXP2002下载入口
  10. 未知  |  233046次下载  |  免费
  11. 6电路仿真软件multisim 10.0免费下载
  12. 340992  |  191187次下载  |  免费
  13. 7十天学会AVR单片机与C语言视频教程 下载
  14. 158M  |  183279次下载  |  免费
  15. 8proe5.0野火版下载(中文版免费下载)
  16. 未知  |  138040次下载  |  免费