ライブラリ化を行った後

Dependencies:   QEI accelerator bit_test cyclic_io cyclic_var cylinder event_var limit mbed mecanum motor_drive pid pid_encoder rs422_put sbdbt servo

Fork of 17robo_Practice1 by kusano kiyoshige

Committer:
echo_piyo
Date:
Sat Sep 23 10:10:58 2017 +0000
Revision:
64:41dcec6c20bc
Parent:
59:68a73b9d27f5
Child:
65:5e4c2e5494ae
(?)????????????????????????????????????????????????????

Who changed what in which revision?

UserRevisionLine numberNew contents of line
echo_piyo 56:a7bd860b85b6 1 //index_include
echo_piyo 0:bf96e953cdb8 2 #include "mbed.h"
echo_piyo 4:a6cc2f03e69b 3 #include "math.h"
echo_piyo 0:bf96e953cdb8 4 #include "bit_test.h"
echo_piyo 0:bf96e953cdb8 5 #include "RS422_put.h"
echo_piyo 0:bf96e953cdb8 6 #include "sbdbt.h"
echo_piyo 0:bf96e953cdb8 7 #include "mecanum.h"
echo_piyo 0:bf96e953cdb8 8 #include "bno055_lib.h"
echo_piyo 0:bf96e953cdb8 9 #include "bno055_use.h"
echo_piyo 0:bf96e953cdb8 10 #include "pid.h"
echo_piyo 0:bf96e953cdb8 11 #include "limit.h"
echo_piyo 4:a6cc2f03e69b 12 #include "accelerator.h"
echo_piyo 10:04f2a82cfd89 13 #include "encorder.h"
echo_piyo 14:aac2f18f6779 14 #include "cyclic.h"
echo_piyo 14:aac2f18f6779 15 #include "cyclic_IO.h"
echo_piyo 15:0fdf483769bf 16 #include "cylinder.h"
echo_piyo 50:e4e1f38d1bd5 17 #include "varEvent.h"
echo_piyo 0:bf96e953cdb8 18
echo_piyo 56:a7bd860b85b6 19 //index_define
echo_piyo 0:bf96e953cdb8 20 #define pc_baud 460800
echo_piyo 0:bf96e953cdb8 21 #define sbdbt_tx p13
echo_piyo 0:bf96e953cdb8 22 #define sbdbt_rx p14
echo_piyo 0:bf96e953cdb8 23 #define sbdbt_baud 115200
echo_piyo 0:bf96e953cdb8 24 #define rs422_tx p28
echo_piyo 0:bf96e953cdb8 25 #define rs422_rx p27
echo_piyo 0:bf96e953cdb8 26 #define rs422_baud 115200
echo_piyo 3:9ef929639c4a 27 #define output_period 0.015
echo_piyo 28:72b9af7e1700 28 #define nucleo_num 6
echo_piyo 0:bf96e953cdb8 29 #define pi 3.141592
echo_piyo 0:bf96e953cdb8 30 #define n1_id 3
echo_piyo 0:bf96e953cdb8 31 #define n2_id 4
echo_piyo 10:04f2a82cfd89 32 #define n3_id 5
echo_piyo 14:aac2f18f6779 33 #define n4_id 6
echo_piyo 14:aac2f18f6779 34 #define n5_id 7
echo_piyo 28:72b9af7e1700 35 #define n6_id 8
echo_piyo 5:6efda58ff71b 36 #define yaw_Kp 0.01
echo_piyo 5:6efda58ff71b 37 #define yaw_Ki 0.01
echo_piyo 5:6efda58ff71b 38 #define yaw_Kd 0.01
echo_piyo 54:a88208d9bc1d 39 #define acceleration 15 //25
echo_piyo 59:68a73b9d27f5 40 #define pin_cylinder_on p18
echo_piyo 59:68a73b9d27f5 41 #define pin_cylinder_off p17
echo_piyo 64:41dcec6c20bc 42 #define pin_interrupt_cylinder_min p29
echo_piyo 64:41dcec6c20bc 43 #define encoder_A p21
echo_piyo 64:41dcec6c20bc 44 #define encoder_B p22
echo_piyo 40:2d6888448ab2 45 #define enc_Kp 0.0400
echo_piyo 33:64fd1bd83bac 46 #define enc_Ki 0.0001
echo_piyo 33:64fd1bd83bac 47 #define enc_Kd 0.0003
echo_piyo 34:02d605c68bf3 48 #define mecanum_power 1.0
echo_piyo 52:f5ae47e683fa 49 #define sword_power 1.0
echo_piyo 52:f5ae47e683fa 50 #define sholder_power 1.0
echo_piyo 47:6ea046767494 51 #define pin_interrupt_sholderright_max p19 //p21
echo_piyo 47:6ea046767494 52 #define pin_interrupt_sholderright_min p20 //p22
echo_piyo 33:64fd1bd83bac 53 #define pin_interrupt_sholderleft_max p7
echo_piyo 33:64fd1bd83bac 54 #define pin_interrupt_sholderleft_min p8
echo_piyo 64:41dcec6c20bc 55 //#define pin_servo p21
echo_piyo 35:5e1ad00f26fb 56 #define servo_reload_time 1.0
echo_piyo 43:605e5b0b9106 57 #define pin_cylinder_reload p15
echo_piyo 45:a32e8091901b 58 #define pin_sbdbt_pairing p12
echo_piyo 45:a32e8091901b 59 #define pin_sbdbt_indicator p11
echo_piyo 56:a7bd860b85b6 60 #define cylinder_pos_max 6
echo_piyo 0:bf96e953cdb8 61
echo_piyo 57:68df771fd8a1 62
echo_piyo 56:a7bd860b85b6 63 //index_setupPin
echo_piyo 45:a32e8091901b 64 DigitalOut led1(LED1);
echo_piyo 48:96b5f5ebdfb0 65 DigitalOut led2(LED2);
echo_piyo 48:96b5f5ebdfb0 66 DigitalOut led3(LED3);
echo_piyo 48:96b5f5ebdfb0 67 DigitalOut led4(LED4);
echo_piyo 31:285c9898da03 68 DigitalIn interrupt_cylinder_min(pin_interrupt_cylinder_min);
echo_piyo 0:bf96e953cdb8 69 Serial pc(USBTX,USBRX);
echo_piyo 0:bf96e953cdb8 70 RS422 rs422(rs422_tx, rs422_rx);
echo_piyo 45:a32e8091901b 71 Sbdbt sbdbt(sbdbt_tx, sbdbt_rx, pin_sbdbt_pairing);
echo_piyo 0:bf96e953cdb8 72 Ticker output_timer;
echo_piyo 0:bf96e953cdb8 73 Mecanum mecanum;
echo_piyo 0:bf96e953cdb8 74 Bno055 bno055;
echo_piyo 2:d5b8f8e62923 75 Position_pid yaw_pid;
echo_piyo 4:a6cc2f03e69b 76 Accel v1;
echo_piyo 4:a6cc2f03e69b 77 Accel v2;
echo_piyo 4:a6cc2f03e69b 78 Accel v3;
echo_piyo 4:a6cc2f03e69b 79 Accel v4;
echo_piyo 58:6cd46488f59b 80 DigitalOut cylinder_on(pin_cylinder_on);
echo_piyo 58:6cd46488f59b 81 DigitalOut cylinder_off(pin_cylinder_off);
echo_piyo 26:3280d0300b04 82 Cyclic sword;
echo_piyo 31:285c9898da03 83 Cyclic cyclic_cylinder_position;
echo_piyo 31:285c9898da03 84 DigitalIn interrupt_sholderright_min(pin_interrupt_sholderright_min);
echo_piyo 31:285c9898da03 85 DigitalIn interrupt_sholderright_max(pin_interrupt_sholderright_max);
echo_piyo 31:285c9898da03 86 DigitalIn interrupt_sholderleft_min(pin_interrupt_sholderleft_min);
echo_piyo 31:285c9898da03 87 DigitalIn interrupt_sholderleft_max(pin_interrupt_sholderleft_max);
echo_piyo 35:5e1ad00f26fb 88 Encoder enc_cylinder(encoder_A,encoder_B);
echo_piyo 38:b071512af5ca 89 Cyclic cyclic_servo;
echo_piyo 42:63aedf71f4d1 90 Cyclic_IO cylinder_reload(pin_cylinder_reload);
echo_piyo 64:41dcec6c20bc 91 //PwmOut servo(pin_servo);
echo_piyo 45:a32e8091901b 92 DigitalOut sbdbt_indigator(pin_sbdbt_indicator);
echo_piyo 51:70d45b959d6b 93 varEvent cylinder_event;
echo_piyo 9:6486f4b3ac50 94
echo_piyo 56:a7bd860b85b6 95 //index_setupFunction
echo_piyo 0:bf96e953cdb8 96 void setup();
echo_piyo 0:bf96e953cdb8 97 void output();
echo_piyo 15:0fdf483769bf 98 void motor_cal();
echo_piyo 16:e49df474e4c6 99 void cylinder_cal();
echo_piyo 10:04f2a82cfd89 100 void boost();
echo_piyo 12:1fec80ae8a2c 101 void cylinder_origin();
echo_piyo 53:701dc7886fff 102 void firstmotion();
echo_piyo 26:3280d0300b04 103 void sword_cal();
echo_piyo 35:5e1ad00f26fb 104 void servo_origin();
echo_piyo 31:285c9898da03 105 float shoulder_right_cal();
echo_piyo 31:285c9898da03 106 float shoulder_left_cal();
echo_piyo 42:63aedf71f4d1 107
echo_piyo 56:a7bd860b85b6 108 //index_setupVariable
echo_piyo 39:6735743ac0f1 109 //output
echo_piyo 2:d5b8f8e62923 110 float yaw, target_yaw;
echo_piyo 39:6735743ac0f1 111 //cylinder_origin
echo_piyo 38:b071512af5ca 112 int cylinder_origin_flag = 0;
echo_piyo 39:6735743ac0f1 113 //cylinder
echo_piyo 39:6735743ac0f1 114 float cylinder_pwm;
echo_piyo 39:6735743ac0f1 115 int cylinder_pos_num = 0;
echo_piyo 56:a7bd860b85b6 116 float cylinder_pos[cylinder_pos_max] = {0.0,90.0,325.0,450.0,580.0,700.0};
echo_piyo 0:bf96e953cdb8 117
echo_piyo 0:bf96e953cdb8 118 int main()
echo_piyo 0:bf96e953cdb8 119 {
echo_piyo 0:bf96e953cdb8 120 setup();
echo_piyo 2:d5b8f8e62923 121 while(1) {
echo_piyo 48:96b5f5ebdfb0 122 led1 = interrupt_sholderleft_max;
echo_piyo 48:96b5f5ebdfb0 123 led2 = interrupt_sholderleft_min;
echo_piyo 48:96b5f5ebdfb0 124 led3 = interrupt_sholderright_max;
echo_piyo 48:96b5f5ebdfb0 125 led4 = interrupt_sholderright_min;
echo_piyo 50:e4e1f38d1bd5 126
echo_piyo 64:41dcec6c20bc 127 //pc.printf("cylinder pos : %f\r\n",enc_cylinder.deg());
echo_piyo 55:2dd2f161ebaf 128 //pc.printf("riseState %d : fallState %d\r\n",event.getRise(),event.getFall());
echo_piyo 0:bf96e953cdb8 129 }
echo_piyo 0:bf96e953cdb8 130 }
echo_piyo 0:bf96e953cdb8 131
echo_piyo 0:bf96e953cdb8 132 void setup()
echo_piyo 0:bf96e953cdb8 133 {
echo_piyo 40:2d6888448ab2 134 wait(2.0);
echo_piyo 64:41dcec6c20bc 135 //bno055.begin();
echo_piyo 40:2d6888448ab2 136 wait(1.0);
echo_piyo 64:41dcec6c20bc 137 //bno055.firstRead();
echo_piyo 0:bf96e953cdb8 138 pc.baud(pc_baud);
echo_piyo 0:bf96e953cdb8 139 sbdbt.begin(sbdbt_baud);
echo_piyo 0:bf96e953cdb8 140 rs422.begin(rs422_baud);
echo_piyo 53:701dc7886fff 141 firstmotion();
echo_piyo 49:b041c815c063 142 cylinder_pos_num = 2; //セットアップタイムでの初期装填のため
echo_piyo 0:bf96e953cdb8 143 output_timer.attach(&output, output_period);
echo_piyo 2:d5b8f8e62923 144 yaw_pid.setup(yaw_Kp, yaw_Ki, yaw_Kd);
echo_piyo 39:6735743ac0f1 145 mecanum.setupdeg(bno055.getYawRad()); //基盤が前後逆の場合+180
echo_piyo 4:a6cc2f03e69b 146 v1.setup(acceleration,output_period);
echo_piyo 4:a6cc2f03e69b 147 v2.setup(acceleration,output_period);
echo_piyo 4:a6cc2f03e69b 148 v3.setup(acceleration,output_period);
echo_piyo 4:a6cc2f03e69b 149 v4.setup(acceleration,output_period);
echo_piyo 31:285c9898da03 150 enc_cylinder.setup(100);
echo_piyo 13:dfae731e239f 151 enc_cylinder.set_parameter(enc_Kp,enc_Ki,enc_Kd);
echo_piyo 64:41dcec6c20bc 152 //servo.period(0.020);
echo_piyo 12:1fec80ae8a2c 153 }
echo_piyo 12:1fec80ae8a2c 154
echo_piyo 36:dca1081c19b3 155 //Sword
echo_piyo 35:5e1ad00f26fb 156 float shoulder_right_cal()
echo_piyo 15:0fdf483769bf 157 {
echo_piyo 40:2d6888448ab2 158 if(interrupt_sholderright_max==0&&sbdbt.sankaku==1) {
echo_piyo 31:285c9898da03 159 return 0.0;
echo_piyo 31:285c9898da03 160 }
echo_piyo 40:2d6888448ab2 161 if(interrupt_sholderright_min==0&&sbdbt.batu==1) {
echo_piyo 33:64fd1bd83bac 162 return 0.0;
echo_piyo 31:285c9898da03 163 }
echo_piyo 31:285c9898da03 164 return (-sbdbt.sankaku*0.8+sbdbt.batu*0.8);
echo_piyo 31:285c9898da03 165 }
echo_piyo 31:285c9898da03 166
echo_piyo 35:5e1ad00f26fb 167 float shoulder_left_cal()
echo_piyo 35:5e1ad00f26fb 168 {
echo_piyo 40:2d6888448ab2 169 if(interrupt_sholderleft_max==0&&sbdbt.sankaku==1) {
echo_piyo 31:285c9898da03 170 return 0.0;
echo_piyo 31:285c9898da03 171 }
echo_piyo 40:2d6888448ab2 172 if(interrupt_sholderleft_min==0&&sbdbt.batu==1) {
echo_piyo 35:5e1ad00f26fb 173 return 0.0;
echo_piyo 31:285c9898da03 174 }
echo_piyo 40:2d6888448ab2 175 return (-sbdbt.sankaku*0.8+sbdbt.batu*0.8);
echo_piyo 31:285c9898da03 176 }
echo_piyo 31:285c9898da03 177 void sword_cal()
echo_piyo 31:285c9898da03 178 {
echo_piyo 26:3280d0300b04 179 sword.cyclic(sbdbt.maru);
echo_piyo 17:5c4718c603dc 180 }
echo_piyo 15:0fdf483769bf 181
echo_piyo 36:dca1081c19b3 182 //cylinder
echo_piyo 53:701dc7886fff 183 void firstmotion()
echo_piyo 31:285c9898da03 184 {
echo_piyo 53:701dc7886fff 185 while(interrupt_cylinder_min == 1 || interrupt_sholderleft_max == 1 || interrupt_sholderright_max == 1){
echo_piyo 53:701dc7886fff 186 float cylinder = 0.0;
echo_piyo 53:701dc7886fff 187 float sholderL = 0.0;
echo_piyo 53:701dc7886fff 188 float sholderR = 0.0;
echo_piyo 64:41dcec6c20bc 189 led1 = interrupt_sholderleft_max;
echo_piyo 64:41dcec6c20bc 190 led2 = interrupt_sholderleft_min;
echo_piyo 64:41dcec6c20bc 191 led3 = interrupt_sholderright_max;
echo_piyo 64:41dcec6c20bc 192 led4 = interrupt_sholderright_min;
echo_piyo 53:701dc7886fff 193 if(interrupt_cylinder_min == 1){
echo_piyo 53:701dc7886fff 194 cylinder = 2.0;
echo_piyo 53:701dc7886fff 195 }else{
echo_piyo 53:701dc7886fff 196 cylinder = 0.0;
echo_piyo 53:701dc7886fff 197 }
echo_piyo 53:701dc7886fff 198 if(interrupt_sholderright_max == 1){
echo_piyo 53:701dc7886fff 199 sholderR = -2.0;
echo_piyo 53:701dc7886fff 200 }else{
echo_piyo 53:701dc7886fff 201 sholderR = 0.0;
echo_piyo 53:701dc7886fff 202 }
echo_piyo 53:701dc7886fff 203 if(interrupt_sholderleft_max == 1){
echo_piyo 53:701dc7886fff 204 sholderL = 2.0;
echo_piyo 53:701dc7886fff 205 }else{
echo_piyo 53:701dc7886fff 206 sholderL = 0.0;
echo_piyo 53:701dc7886fff 207 }
echo_piyo 53:701dc7886fff 208 rs422.put(5, cylinder, 0.0);
echo_piyo 53:701dc7886fff 209 rs422.put(6, sholderR, sholderL);
echo_piyo 12:1fec80ae8a2c 210 }
echo_piyo 31:285c9898da03 211 enc_cylinder.origin();
echo_piyo 0:bf96e953cdb8 212 }
echo_piyo 38:b071512af5ca 213
echo_piyo 42:63aedf71f4d1 214 //cylinder_origin_flagを1にすることで動作する
echo_piyo 38:b071512af5ca 215 void cylinder_origin()
echo_piyo 38:b071512af5ca 216 {
echo_piyo 45:a32e8091901b 217 if(interrupt_cylinder_min == 0&&cylinder_origin_flag == 1) {
echo_piyo 39:6735743ac0f1 218 cylinder_origin_flag = 0;
echo_piyo 39:6735743ac0f1 219 enc_cylinder.origin();
echo_piyo 39:6735743ac0f1 220 cylinder_pos_num = 0;
echo_piyo 45:a32e8091901b 221 } else if(cylinder_origin_flag == 1) {
echo_piyo 42:63aedf71f4d1 222 rs422.put(5, -0.8, 0.0);
echo_piyo 38:b071512af5ca 223 }
echo_piyo 38:b071512af5ca 224 }
echo_piyo 19:76a387e4bcf6 225 void cylinder_cal()
echo_piyo 31:285c9898da03 226 {
echo_piyo 58:6cd46488f59b 227 //cylinder ON/OFF
echo_piyo 58:6cd46488f59b 228 if(sbdbt.shikaku){
echo_piyo 58:6cd46488f59b 229 cylinder_on = 1;
echo_piyo 58:6cd46488f59b 230 cylinder_off = 0;
echo_piyo 58:6cd46488f59b 231 }else{
echo_piyo 58:6cd46488f59b 232 cylinder_on = 0;
echo_piyo 58:6cd46488f59b 233 cylinder_off = 1;
echo_piyo 58:6cd46488f59b 234 }
echo_piyo 51:70d45b959d6b 235
echo_piyo 51:70d45b959d6b 236 cylinder_event.input(sbdbt.right);
echo_piyo 51:70d45b959d6b 237 if(cylinder_event.getRise()) { //cylinder degset
echo_piyo 31:285c9898da03 238 cylinder_pos_num++;
echo_piyo 55:2dd2f161ebaf 239 if(cylinder_pos_num >= cylinder_pos_max) {
echo_piyo 42:63aedf71f4d1 240 //cylinder_pos_num = 0;
echo_piyo 42:63aedf71f4d1 241 cylinder_origin_flag=1;
echo_piyo 31:285c9898da03 242 }
echo_piyo 31:285c9898da03 243 }
echo_piyo 50:e4e1f38d1bd5 244 enc_cylinder.cal((float)cylinder_pos[cylinder_pos_num],output_period); //set cylinder_tergetPos
echo_piyo 35:5e1ad00f26fb 245
echo_piyo 64:41dcec6c20bc 246 pc.printf("terget\t%f\tnow_deg\t%f\tnow_pulse\t%d\tpwm\t%f\r\n",cylinder_pos[cylinder_pos_num],enc_cylinder.deg(),enc_cylinder.pulse(),enc_cylinder.duty());
echo_piyo 19:76a387e4bcf6 247 }
echo_piyo 38:b071512af5ca 248
echo_piyo 64:41dcec6c20bc 249 //function
echo_piyo 64:41dcec6c20bc 250 /*void servo_max()
echo_piyo 45:a32e8091901b 251 {
echo_piyo 45:a32e8091901b 252 servo.pulsewidth(0.0022);
echo_piyo 35:5e1ad00f26fb 253 }
echo_piyo 38:b071512af5ca 254 void servo_min()
echo_piyo 35:5e1ad00f26fb 255 {
echo_piyo 35:5e1ad00f26fb 256 servo.pulsewidth(0.0010);
echo_piyo 38:b071512af5ca 257 }
echo_piyo 45:a32e8091901b 258 void servo_out()
echo_piyo 45:a32e8091901b 259 {
echo_piyo 39:6735743ac0f1 260 cyclic_servo.cyclic(sbdbt.down); //setServoControl
echo_piyo 45:a32e8091901b 261 if(cyclic_servo.getState()==0) {
echo_piyo 39:6735743ac0f1 262 servo_min();
echo_piyo 45:a32e8091901b 263 } else if(cyclic_servo.getState()==1) {
echo_piyo 39:6735743ac0f1 264 servo_max();
echo_piyo 38:b071512af5ca 265 }
echo_piyo 64:41dcec6c20bc 266 }*/
echo_piyo 35:5e1ad00f26fb 267
echo_piyo 36:dca1081c19b3 268
echo_piyo 64:41dcec6c20bc 269 //functionBoost
echo_piyo 31:285c9898da03 270 void boost()
echo_piyo 31:285c9898da03 271 {
echo_piyo 31:285c9898da03 272 if(sbdbt.r2) {
echo_piyo 10:04f2a82cfd89 273 mecanum.boost_forward();
echo_piyo 10:04f2a82cfd89 274 }
echo_piyo 31:285c9898da03 275 if(sbdbt.l2) {
echo_piyo 10:04f2a82cfd89 276 mecanum.boost_back();
echo_piyo 10:04f2a82cfd89 277 }
echo_piyo 26:3280d0300b04 278 /*
echo_piyo 10:04f2a82cfd89 279 if(sbdbt.shikaku) {
echo_piyo 10:04f2a82cfd89 280 mecanum.boost_left();
echo_piyo 10:04f2a82cfd89 281 }
echo_piyo 10:04f2a82cfd89 282 if(sbdbt.maru) {
echo_piyo 10:04f2a82cfd89 283 mecanum.boost_right();
echo_piyo 10:04f2a82cfd89 284 }
echo_piyo 26:3280d0300b04 285 */
echo_piyo 10:04f2a82cfd89 286 }
echo_piyo 10:04f2a82cfd89 287
echo_piyo 64:41dcec6c20bc 288 //functionMecanum
echo_piyo 15:0fdf483769bf 289 void motor_cal()
echo_piyo 5:6efda58ff71b 290 {
echo_piyo 56:a7bd860b85b6 291 static float out_right_x;
echo_piyo 4:a6cc2f03e69b 292 yaw = bno055.getYawRad();
echo_piyo 4:a6cc2f03e69b 293 target_yaw = yaw;
echo_piyo 56:a7bd860b85b6 294 yaw_pid.cal(target_yaw, yaw, output_period);
echo_piyo 56:a7bd860b85b6 295
echo_piyo 56:a7bd860b85b6 296 //後進時に方向が逆転するため
echo_piyo 56:a7bd860b85b6 297 if(sbdbt.right_y < 0.0){
echo_piyo 56:a7bd860b85b6 298 out_right_x = -1.0*sbdbt.right_x;
echo_piyo 56:a7bd860b85b6 299 }else{
echo_piyo 56:a7bd860b85b6 300 out_right_x = sbdbt.right_x;
echo_piyo 56:a7bd860b85b6 301 }
echo_piyo 56:a7bd860b85b6 302 mecanum.sbdbt_cal(sbdbt.left_x, sbdbt.left_y, sbdbt.l1, sbdbt.r1, out_right_x, bno055.getYawRad());
echo_piyo 5:6efda58ff71b 303 // pc.printf("%f\t data %f\t %f\t %f\t %f\t\r\n", bno055.getYawRad(), sbdbt.left_x, sbdbt.left_y, mecanum.VX(), mecanum.VY());
echo_piyo 35:5e1ad00f26fb 304 }
echo_piyo 35:5e1ad00f26fb 305 void output()
echo_piyo 35:5e1ad00f26fb 306 {
echo_piyo 35:5e1ad00f26fb 307 motor_cal();
echo_piyo 35:5e1ad00f26fb 308 cylinder_cal();
echo_piyo 35:5e1ad00f26fb 309 sword_cal();
echo_piyo 64:41dcec6c20bc 310 //servo_out();
echo_piyo 38:b071512af5ca 311 cylinder_origin();
echo_piyo 35:5e1ad00f26fb 312 //boost();
echo_piyo 56:a7bd860b85b6 313 sbdbt_indigator = sbdbt.get_pairingState();
echo_piyo 48:96b5f5ebdfb0 314 //led1 = sbdbt.get_pairingState();
echo_piyo 49:b041c815c063 315 if(sbdbt.up)cylinder_origin_flag = 1;
echo_piyo 49:b041c815c063 316 if(sbdbt.left)bno055.yaw_origin();
echo_piyo 49:b041c815c063 317 cylinder_reload.cyclic(sbdbt.down);
echo_piyo 45:a32e8091901b 318
echo_piyo 35:5e1ad00f26fb 319 static int counter;
echo_piyo 53:701dc7886fff 320 static float mecanumV1, mecanumV2, mecanumV3, mecanumV4;
echo_piyo 35:5e1ad00f26fb 321 int id[nucleo_num] = {n1_id, n2_id, n3_id, n4_id, n5_id, n6_id};
echo_piyo 45:a32e8091901b 322
echo_piyo 45:a32e8091901b 323 //sbdbtがpairingしている場合のみ動作
echo_piyo 45:a32e8091901b 324 if(sbdbt.get_pairingState()) {
echo_piyo 45:a32e8091901b 325 switch (counter) {
echo_piyo 45:a32e8091901b 326 case 0:
echo_piyo 53:701dc7886fff 327 rs422.put(id[counter], v1.duty(limitf(((mecanum.v1()*mecanum_power)+(sbdbt.right_y*0.8)),1.0,-1.0)), v3.duty(limitf(((mecanum.v3()*mecanum_power)+(sbdbt.right_y*0.8)),1.0,-1.0)));
echo_piyo 45:a32e8091901b 328 counter++;
echo_piyo 45:a32e8091901b 329 break;
echo_piyo 45:a32e8091901b 330 case 1:
echo_piyo 45:a32e8091901b 331 //.duty(<cal>*<powerControle>+(<boost>*0.5))
echo_piyo 53:701dc7886fff 332 rs422.put(id[counter], v2.duty(limitf(((mecanum.v2()*mecanum_power)-(sbdbt.right_y*0.8)),1.0,-1.0)), v4.duty(limitf(((mecanum.v4()*mecanum_power)-(sbdbt.right_y*0.8)),1.0,-1.0)));
echo_piyo 45:a32e8091901b 333 counter ++;
echo_piyo 45:a32e8091901b 334 break;
echo_piyo 45:a32e8091901b 335 case 2:
echo_piyo 55:2dd2f161ebaf 336 //rs422.put(id[counter], sbdbt.right_y, 0.0);
echo_piyo 53:701dc7886fff 337 rs422.put(id[counter], limitf((-1*enc_cylinder.duty_enableWidth(-5.0,5.0)),1.0,-1.0), 0.0);
echo_piyo 45:a32e8091901b 338 counter ++;
echo_piyo 45:a32e8091901b 339 break;
echo_piyo 45:a32e8091901b 340 case 3:
echo_piyo 53:701dc7886fff 341 rs422.put(id[counter], limitf((-1*shoulder_right_cal()*sholder_power),1.0,-1.0), limitf((shoulder_left_cal()*sholder_power),1.0,-1.0));
echo_piyo 45:a32e8091901b 342 counter ++;
echo_piyo 45:a32e8091901b 343 break;
echo_piyo 45:a32e8091901b 344 case 4:
echo_piyo 53:701dc7886fff 345 rs422.put(id[counter], limitf(((float)sword.getState()*sword_power),1.0,-1.0),0.0);
echo_piyo 45:a32e8091901b 346 counter = 0;
echo_piyo 45:a32e8091901b 347 break;
echo_piyo 45:a32e8091901b 348 default:
echo_piyo 45:a32e8091901b 349 break;
echo_piyo 48:96b5f5ebdfb0 350 }
echo_piyo 45:a32e8091901b 351 }else{
echo_piyo 48:96b5f5ebdfb0 352 switch (counter) {
echo_piyo 48:96b5f5ebdfb0 353 case 0:
echo_piyo 48:96b5f5ebdfb0 354 rs422.put(id[counter],0.0,0.0);
echo_piyo 48:96b5f5ebdfb0 355 counter++;
echo_piyo 48:96b5f5ebdfb0 356 break;
echo_piyo 48:96b5f5ebdfb0 357 case 1:
echo_piyo 48:96b5f5ebdfb0 358 rs422.put(id[counter],0.0,0.0);
echo_piyo 48:96b5f5ebdfb0 359 counter ++;
echo_piyo 48:96b5f5ebdfb0 360 break;
echo_piyo 48:96b5f5ebdfb0 361 case 2:
echo_piyo 48:96b5f5ebdfb0 362 rs422.put(id[counter],0.0,0.0);
echo_piyo 48:96b5f5ebdfb0 363 counter ++;
echo_piyo 48:96b5f5ebdfb0 364 break;
echo_piyo 48:96b5f5ebdfb0 365 case 3:
echo_piyo 48:96b5f5ebdfb0 366 rs422.put(id[counter],0.0,0.0);
echo_piyo 48:96b5f5ebdfb0 367 counter ++;
echo_piyo 48:96b5f5ebdfb0 368 break;
echo_piyo 48:96b5f5ebdfb0 369 case 4:
echo_piyo 48:96b5f5ebdfb0 370 rs422.put(id[counter],0.0,0.0);
echo_piyo 48:96b5f5ebdfb0 371 counter = 0;
echo_piyo 48:96b5f5ebdfb0 372 break;
echo_piyo 48:96b5f5ebdfb0 373 default:
echo_piyo 48:96b5f5ebdfb0 374 break;
echo_piyo 45:a32e8091901b 375 }
echo_piyo 45:a32e8091901b 376 }
echo_piyo 14:aac2f18f6779 377 }