This commit is contained in:
Rene Hopf 2018-02-18 13:37:50 +01:00
parent b988e09e3e
commit ff224a2509
4 changed files with 39 additions and 14 deletions

View file

@ -13,12 +13,13 @@
#define PWM_FREQ 16000 // PWM frequency in Hz #define PWM_FREQ 16000 // PWM frequency in Hz
#define DEAD_TIME 32 // PWM deadtime #define DEAD_TIME 32 // PWM deadtime
#define DC_CUR_LIMIT 34 // Motor DC current limit in amps //#define DC_CUR_LIMIT 34 // Motor DC current limit in amps
#define DC_CUR_LIMIT 24 // Motor DC current limit in amps
//#define DEBUG_SERIAL_SERVOTERM //#define DEBUG_SERIAL_SERVOTERM
#define DEBUG_SERIAL_ASCII // #define DEBUG_SERIAL_ASCII
#define DEBUG_BAUD 115200 // UART baud rate #define DEBUG_BAUD 115200 // UART baud rate
//#define DEBUG_I2C_LCD //#define DEBUG_I2C_LCD
#define CONTROL_PPM // use PPM CONTROL_PPM // #define CONTROL_PPM // use PPM CONTROL_PPM
#define PPM_NUM_CHANNELS 6 // number of PPM channels to receive #define PPM_NUM_CHANNELS 6 // number of PPM channels to receive

View file

@ -9,6 +9,7 @@ volatile int posl = 0;
volatile int posr = 0; volatile int posr = 0;
volatile int pwml = 0; volatile int pwml = 0;
volatile int pwmr = 0; volatile int pwmr = 0;
float pwmrl = 0;
extern volatile adc_buf_t adc_buffer; extern volatile adc_buf_t adc_buffer;
@ -117,11 +118,7 @@ inline void blockPhaseCurrent(int pos, int u, int v, int *q) {
} }
} }
int last_pos = 0;
int timer = 0;
uint16_t buzzerTimer = 0; uint16_t buzzerTimer = 0;
int max_time = PWM_FREQ / 10;
volatile int vel = 0;
int offsetcount = 0; int offsetcount = 0;
int offsetrl1 = 2000; int offsetrl1 = 2000;
@ -132,12 +129,19 @@ int offsetdcl = 2000;
int offsetdcr = 2000; int offsetdcr = 2000;
float batteryVoltage; float batteryVoltage;
float adccmd1;
float adccmd2;
int curl = 0; int curl = 0;
// int errorl = 0; // int errorl = 0;
// int kp = 5; // int kp = 5;
// volatile int cmdl = 0; // volatile int cmdl = 0;
int last_pos = 0;
int timer = 0;
const int max_time = PWM_FREQ / 10;
volatile int vel = 0;
void DMA1_Channel1_IRQHandler() { void DMA1_Channel1_IRQHandler() {
DMA1->IFCR = DMA_IFCR_CTCIF1; DMA1->IFCR = DMA_IFCR_CTCIF1;
// HAL_GPIO_WritePin(LED_PORT, LED_PIN, 1); // HAL_GPIO_WritePin(LED_PORT, LED_PIN, 1);
@ -154,6 +158,21 @@ void DMA1_Channel1_IRQHandler() {
} }
batteryVoltage = batteryVoltage * 0.999 + ((float)adc_buffer.batt1 * ADC_BATTERY_VOLT) * 0.001; batteryVoltage = batteryVoltage * 0.999 + ((float)adc_buffer.batt1 * ADC_BATTERY_VOLT) * 0.001;
adccmd1 = adccmd1 * 0.999 + (float)adc_buffer.l_rx2 * 0.001;
adccmd2 = adccmd2 * 0.999 + (float)adc_buffer.l_tx2 * 0.001;
//0-4096
//+-2000
pwmrl = 0;
if(adccmd1 - 700 > 0){
pwmrl += adccmd1 - 700;
}
if(adccmd2 - 700 > 0){
pwmrl -= adccmd2 - 700;
}
pwml = -pwmrl/4;
pwmr = pwmrl/4;
if(ABS((adc_buffer.dcl - offsetdcl) * MOTOR_AMP_CONV_DC_AMP) > DC_CUR_LIMIT || timeout > 50 || enable == 0) { if(ABS((adc_buffer.dcl - offsetdcl) * MOTOR_AMP_CONV_DC_AMP) > DC_CUR_LIMIT || timeout > 50 || enable == 0) {
LEFT_TIM->BDTR &= ~TIM_BDTR_MOE; LEFT_TIM->BDTR &= ~TIM_BDTR_MOE;
@ -195,10 +214,8 @@ void DMA1_Channel1_IRQHandler() {
setScopeChannel(2, (adc_buffer.rl1 - offsetrl1) / 8); setScopeChannel(2, (adc_buffer.rl1 - offsetrl1) / 8);
setScopeChannel(3, (adc_buffer.rl2 - offsetrl2) / 8); setScopeChannel(3, (adc_buffer.rl2 - offsetrl2) / 8);
timer++;
buzzerTimer++; buzzerTimer++;
if (buzzerFreq != 0 && (buzzerTimer / 1500) % (buzzerPattern + 1) == 0) { if (buzzerFreq != 0 && (buzzerTimer / 1500) % (buzzerPattern + 1) == 0) {
if (buzzerTimer % buzzerFreq == 0) { if (buzzerTimer % buzzerFreq == 0) {
HAL_GPIO_TogglePin(BUZZER_PORT, BUZZER_PIN); HAL_GPIO_TogglePin(BUZZER_PORT, BUZZER_PIN);
@ -207,22 +224,23 @@ void DMA1_Channel1_IRQHandler() {
HAL_GPIO_WritePin(BUZZER_PORT, BUZZER_PIN, 0); HAL_GPIO_WritePin(BUZZER_PORT, BUZZER_PIN, 0);
} }
// //measure vel
// timer++;
// if(timer > max_time){ // if(timer > max_time){
// timer = max_time; // timer = max_time;
// vel = 0; // vel = 0;
// } // }
// if(pos != last_pos){ // if(posl != last_pos){
// vel = 1000 * PWM_FREQ / timer / P / 6 * 2; // vel = 1000 * PWM_FREQ / timer / P / 6 * 2;
// if((pos - last_pos + 6) % 6 > 2){ // if((posl - last_pos + 6) % 6 > 2){
// vel = -vel; // vel = -vel;
// } // }
// timer = 0; // timer = 0;
// } // }
// last_pos = pos; // last_pos = posl;
//YOLOTEST //YOLOTEST
// errorl = cmdl - curl; // errorl = cmdl - curl;

View file

@ -128,7 +128,7 @@ int main(void) {
consoleScope(); consoleScope();
timeout++; timeout=0;
if (HAL_GPIO_ReadPin(BUTTON_PORT, BUTTON_PIN)) { if (HAL_GPIO_ReadPin(BUTTON_PORT, BUTTON_PIN)) {
enable = 0; enable = 0;

View file

@ -179,6 +179,12 @@ void MX_GPIO_Init(void) {
GPIO_InitStruct.Pin = DCLINK_PIN; GPIO_InitStruct.Pin = DCLINK_PIN;
HAL_GPIO_Init(DCLINK_PORT, &GPIO_InitStruct); HAL_GPIO_Init(DCLINK_PORT, &GPIO_InitStruct);
//Analog in
GPIO_InitStruct.Pin = GPIO_PIN_3;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
GPIO_InitStruct.Pin = GPIO_PIN_2;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
GPIO_InitStruct.Pin = LEFT_TIM_UH_PIN; GPIO_InitStruct.Pin = LEFT_TIM_UH_PIN;