RobocupSSLのメイン基板白mbedのプログラム

Dependencies:   mbed

Rootsロボット mainプログラム

~ Robocup SSL(小型車輪リーグ)ロボット ~


Robocup SSLとは


●試合構成
Robocup小型ロボットリーグ(Small Size League)は,直径180[mm],高さ150[mm]以内のサイズのロボット6台が1チームとなり,オレンジ色のゴルフボールを使ってサッカー競技を行う自立型ロボットコンテストである. フィールドの上には2台のWebカメラが設置され,フィールド上のロボットとボールを撮影する.Visionサーバは,フィールドの画像データよりロボットとボールの座標データを算出し,LANを用い各チームのAI用PCに送信する.Webカメラの撮影速度は,60[fps]である.レフリーボックスは,ファウルやフリーキック,スローインなどの審判の判定を入力し,LANを通じて各チームのAI用PCに送信する.それぞれのチームのAI用PCは,ロボットとボールの座標,審判の判定を元にロボットの移動,キックなどの作戦を決定し,無線によってロボットに指令を送信する. 700


ロボット機能紹介


●オムニホイールによる方向転換不要の全方位移動

オムニホイールは,自由に回転可能なローラをホイールの外周上に配置した車輪である.ローラの回転により,車輪の回転と垂直の方向に駆動力を発することはできないが移動は可能となる.各車輪の角速度を調整することによって全方向への移動を可能にする.
400

●ドリブルバーのバックスピンによるボール保持

●電磁力を利用したキッカー

●キッカーの電磁力エネルギーを充電する充電回路

●ロボット情報が一目でわかるLCD

Revision:
24:37a074e767c8
Parent:
23:0bb032ef1880
Child:
25:15f75825fc36
diff -r 0bb032ef1880 -r 37a074e767c8 main.cpp
--- a/main.cpp	Sat Apr 28 07:18:22 2018 +0000
+++ b/main.cpp	Sat Apr 28 19:47:31 2018 +0000
@@ -3,6 +3,13 @@
 #include "interface_manager.h"
 #include "status_manager.h"
 #include "parameter_manager.h"
+#include "fail_safe.h"
+#include "filter.h"
+#include "pid.h"
+
+Timer t;
+LPF DribMot_Current(0.8);
+PID DribMot_PID(1.0,0.1,0.0,40.0,0.0);
 
 int main() {
     init_interface();
@@ -22,6 +29,8 @@
     ParameterManager::machine_data.angle_degree = 0;
     ParameterManager::machine_data.vw_mrad_per_sec = 0; 
     
+    InterfaceManager::i2c.readIDMsg();
+    
     while(1) {
         if(StatusManager::dribbleIC_fault == 1)
         {
@@ -31,6 +40,24 @@
         {
             InterfaceManager::LED  =  0;
         }
+        t.start();
         actmode.run();
+        
+        StatusManager::DriveTime = (short)t.read_us();
+        StatusManager::dribbleMotor_current = DribMot_Current.getLPF_Out( InterfaceManager::dribbleMotor_current.read() * (float)3.3 * (float)9.091 );
+        StatusManager::req_dribbleMotor_PID = DribMot_PID.getPID_Out( StatusManager::req_dribbleMotor_current , StatusManager::dribbleMotor_current);
+        if( StatusManager::dribbleMotor_current > (float)JDG_TH_OVERCUR_DIRBMOT )
+        {
+            StatusManager::dribbleMot_OvrCur = 1;
+            InterfaceManager::dribbleMotor.write((float)1.0 );
+        }
+        else
+        {
+           StatusManager::dribbleMot_OvrCur = 0;
+           InterfaceManager::dribbleMotor.write((float)1.0 - StatusManager::req_dribbleMotor_PID  * (float)0.01 );
+        }
+        t.stop();
+        t.reset();
+        
     }
 }