RobocupSSLのメイン基板白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は,ロボットとボールの座標,審判の判定を元にロボットの移動,キックなどの作戦を決定し,無線によってロボットに指令を送信する.
ロボット機能紹介
●オムニホイールによる方向転換不要の全方位移動
オムニホイールは,自由に回転可能なローラをホイールの外周上に配置した車輪である.ローラの回転により,車輪の回転と垂直の方向に駆動力を発することはできないが移動は可能となる.各車輪の角速度を調整することによって全方向への移動を可能にする.
●ドリブルバーのバックスピンによるボール保持
●電磁力を利用したキッカー
●キッカーの電磁力エネルギーを充電する充電回路
●ロボット情報が一目でわかるLCD
Diff: actuator/wheel.h
- Revision:
- 7:1f1bdb4e4f33
- Child:
- 17:e5e7b19dd707
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/actuator/wheel.h Wed Apr 26 18:35:23 2017 +0000 @@ -0,0 +1,66 @@ +#ifndef WHEEL_ROOTS_H +#define WHEEL_ROOTS_H + +/* **Include** */ +#include "mbed.h" +#include "comm.h" +#include "typedef.h" +#include "interface_manager.h" +#include "status_manager.h" + +/* **Define** */ +#define DEG2RAD 0.01745329251 // π/180 = 0.01745329251 +#define RAD2DEG 57.2957795130 // 180/π = 57.2957795130 + +/* **変数定義** */ +const double CONST_MACHINE_RADIUS_ = 0.07; +const double CONST_WHEEL_RADIUS_ = 26; +const double CONST_GEER_RATIO_ = 2.83; + +const double CONST_V0_COEFFICIENT_VX_ = -0.5, CONST_V0_COEFFICIENT_VY_ = 0.8660254; +const double CONST_V1_COEFFICIENT_VX_ = -0.5, CONST_V1_COEFFICIENT_VY_ = -0.8660254; +const double CONST_V2_COEFFICIENT_VX_ = 1, CONST_V2_COEFFICIENT_VY_ = 0; +const double CONST_V3_COEFFICIENT_VX_ = 2.0000015, CONST_V3_COEFFICIENT_VY_ = 1.15470024; +/* **グルーバル関数** */ + +/* **クラス** */ +class InterfaceManager; +class StatusManager; + +class Wheel{ + public: + Wheel(); + void setVelocity(short V_value, short V_angle, short V_omega); + short getVel_Mot0(void){return order.Mot0Order.Vel_short;} + short getVel_Mot1(void){return order.Mot1Order.Vel_short;} + short getVel_Mot2(void){return order.Mot2Order.Vel_short;} + short getVel_Mot3(void){return order.Mot3Order.Vel_short;} + + private: + OrderMotVel order; + short Vel_Value; + short Vel_Angle; + short Vel_Omega; + + double Vel_X; + double Vel_Y; + double Vel_OMEGA; + + double Vel_Mot0_double; + double Vel_Mot1_double; + double Vel_Mot2_double; + double Vel_Mot3_double; + + void calcWheelVelocity(void); + void convertPhasorToVector(void); + void resolveVector(void); + double operationV0(double vx,double vy, double vw); + double operationV1(double vx,double vy, double vw); + double operationV2(double vx,double vy, double vw); + double operationV3(double vx,double vy, double vw); + + +}; + + +#endif \ No newline at end of file