Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
main.cpp
- Committer:
- kintoki231
- Date:
- 2020-11-15
- Revision:
- 0:b44e107ade58
- Child:
- 1:4a358f08c963
File content as of revision 0:b44e107ade58:
#include "mbed.h"
//#define USB_DEBUG
#define SIMPLE_USE
const int kModuleID = 1;
int sluster_up = 0;
float battery_voltage;
float motor_current;
int sluster_power;
int pump_power;
const float k_vbat_offset[] = {
1.4f,
0.6f
};
const float k_Im_offset[] = {
0.0f,
0.0f
};
DigitalOut led[] = {
DigitalOut(PA_4),
DigitalOut(PA_5),
DigitalOut(PA_6),
};
DigitalOut user[] = {
DigitalOut(PB_1),
DigitalOut(PF_0),
DigitalOut(PF_1),
};
DigitalOut xbee_nreset(PB_5);
AnalogIn raw_battery_voltage(PA_1);
AnalogIn raw_motor_shunt_voltage(PA_0);
//DigitalOut sluster(PA_8);
//DigitalOut pump(PA_11);
DigitalOut pump(PA_8);
DigitalOut sluster(PA_11); //修正
#ifndef USE_DEBUG
Serial xbee(PA_9, PA_10);
#else
Serial xbee(USBTX, USBRX);
#endif
Ticker pwm;
void myPWM(void)
{
static int t = 0;
if(t == 100){
sluster = 0;
pump = 0;
t = 0;
return;
}
if(t == 100-sluster_power)
sluster = 1;
if(t == 100-pump_power)
pump = 1;
t++;
}
void SerialReceive(void)
{
char message = xbee.getc();
while(xbee.readable()) // bufferを綺麗に
xbee.getc();
switch (message) {
case 'a':
sluster_up = 35;
break;
case 'u':
sluster_power += 5;
break;
case 'd':
sluster_power -= 5;
break;
case '+':
pump_power += 5;
break;
case '-':
pump_power -= 5;
break;
default :
sluster_power = 0;
pump_power = 0;
sluster_up = 0;
break;
}
if (sluster_power > 95){
sluster_power = 95;
} else if (sluster_power < 0) {
sluster_power = 0;
}
if (pump_power > 95){
pump_power = 95;
} else if (pump_power < 0) {
pump_power = 0;
}
led[2] =~ led[2];
}
int main()
{
// Initialization
pump_power = 0;
sluster_power = 0;
pwm.attach_us(myPWM, 100); // original PWM function
//sluster.period_ms(1);
//pump.period_ms(1);
xbee_nreset = 1; // xBee nreset
xbee.baud(9600);
xbee.attach(SerialReceive,Serial::RxIrq);
// start motion
wait(1);
#ifdef USB_DEBUG
xbee.printf("2020 Project Iwatobi, PowerModule ID : %02d\n", kModuleID);
#else
xbee.printf("PM : %02d\n", kModuleID);
#endif
wait(1);
led[0] = 1;
while(1) {
//sluster.write(0.01*sluster_power);
//pump.write(0.01*pump_power);
if ((sluster_up > 0)&&(sluster_up > sluster_power)){
sluster_power+=20;
}
battery_voltage = k_vbat_offset[kModuleID] + raw_battery_voltage.read() * 33.0f; // 10.0 * 3.3
motor_current = k_Im_offset[kModuleID] + raw_motor_shunt_voltage * 33.0f; // 10.0 * 3.3
led[1] =~ led[1];
#ifndef SIMPLE_USE
#ifdef USB_DEBUG
xbee.printf("p1 : %03d, p2 : %03d\n", sluster_power, pump_power);
xbee.printf("Vbat : %2.1f [V], Im : %2.1f [A]\n", battery_voltage, motor_current);
#else
xbee.printf("%03d, %03d, %2.1f, %2.1f\n", sluster_power, pump_power, battery_voltage, motor_current);
#endif
#else
xbee.printf("PM : %02d\n", kModuleID);
#endif
wait(0.5);
}
}