Add test for new brake feature
Repeatedly apply sequence of pre-defined motor commands in main function
This commit is contained in:
parent
fcecd930d3
commit
3014808d5a
@ -1,3 +1,4 @@
|
||||
|
||||
#include "config.hpp"
|
||||
|
||||
//===================================
|
||||
@ -25,8 +26,8 @@ single100a_config_t configDriverRight = {
|
||||
.gpio_brakeRelay = GPIO_NUM_18, //power mosfet 1
|
||||
.ledc_timer = LEDC_TIMER_1,
|
||||
.ledc_channel = LEDC_CHANNEL_1,
|
||||
.aEnabledPinState = false, //-> pin inverted (mosfet)
|
||||
.bEnabledPinState = true, //-> not inverted (direct)
|
||||
.aEnabledPinState = false, //-> pins inverted (mosfets)
|
||||
.bEnabledPinState = false,
|
||||
.resolution = LEDC_TIMER_11_BIT,
|
||||
.pwmFreq = 10000
|
||||
};
|
||||
@ -37,13 +38,8 @@ single100a_config_t configDriverRight = {
|
||||
motorctl_config_t configMotorControlLeft = {
|
||||
.msFadeAccel = 1900, //acceleration of the motor (ms it takes from 0% to 100%)
|
||||
.msFadeDecel = 1000, //deceleration of the motor (ms it takes from 100% to 0%)
|
||||
<<<<<<< Updated upstream
|
||||
.currentLimitEnabled = true,
|
||||
.currentSensor_adc = ADC1_CHANNEL_0, //GPIO36
|
||||
=======
|
||||
.currentLimitEnabled = false,
|
||||
.currentSensor_adc = ADC1_CHANNEL_6, //GPIO34
|
||||
>>>>>>> Stashed changes
|
||||
.currentSensor_adc = ADC1_CHANNEL_0, //GPIO36
|
||||
.currentSensor_ratedCurrent = 50,
|
||||
.currentMax = 30,
|
||||
.deadTimeMs = 900 //minimum time motor is off between direction change
|
||||
@ -53,13 +49,8 @@ motorctl_config_t configMotorControlLeft = {
|
||||
motorctl_config_t configMotorControlRight = {
|
||||
.msFadeAccel = 1900, //acceleration of the motor (ms it takes from 0% to 100%)
|
||||
.msFadeDecel = 1000, //deceleration of the motor (ms it takes from 100% to 0%)
|
||||
<<<<<<< Updated upstream
|
||||
.currentLimitEnabled = true,
|
||||
.currentSensor_adc = ADC1_CHANNEL_3, //GPIO39
|
||||
=======
|
||||
.currentLimitEnabled = false,
|
||||
.currentSensor_adc = ADC1_CHANNEL_4, //GPIO32
|
||||
>>>>>>> Stashed changes
|
||||
.currentSensor_adc = ADC1_CHANNEL_3, //GPIO39
|
||||
.currentSensor_ratedCurrent = 50,
|
||||
.currentMax = 30,
|
||||
.deadTimeMs = 900 //minimum time motor is off between direction change
|
||||
|
@ -28,6 +28,9 @@ extern "C"
|
||||
//disables other functionality
|
||||
//#define UART_TEST_ONLY
|
||||
|
||||
//only run brake-test (ignore uart input)
|
||||
#define BRAKE_TEST_ONLY
|
||||
|
||||
|
||||
//tag for logging
|
||||
static const char * TAG = "main";
|
||||
@ -92,7 +95,7 @@ void setLoglevels(void){
|
||||
//--- set loglevel for individual tags ---
|
||||
esp_log_level_set("main", ESP_LOG_INFO);
|
||||
esp_log_level_set("buzzer", ESP_LOG_ERROR);
|
||||
//esp_log_level_set("motordriver", ESP_LOG_INFO);
|
||||
esp_log_level_set("motordriver", ESP_LOG_DEBUG);
|
||||
//esp_log_level_set("motor-control", ESP_LOG_DEBUG);
|
||||
//esp_log_level_set("evaluatedJoystick", ESP_LOG_DEBUG);
|
||||
//esp_log_level_set("joystickCommands", ESP_LOG_DEBUG);
|
||||
@ -150,15 +153,52 @@ extern "C" void app_main(void) {
|
||||
//-------------------------------------------
|
||||
//--- create tasks for uart communication ---
|
||||
//-------------------------------------------
|
||||
#ifndef BRAKE_TEST_ONLY
|
||||
uart_init();
|
||||
xTaskCreate(task_uartReceive, "task_uartReceive", 4096, NULL, 10, NULL);
|
||||
xTaskCreate(task_uartSend, "task_uartSend", 4096, NULL, 10, NULL);
|
||||
#endif
|
||||
|
||||
|
||||
//--- main loop ---
|
||||
//does nothing except for testing things
|
||||
while(1){
|
||||
vTaskDelay(500 / portTICK_PERIOD_MS);
|
||||
#ifdef BRAKE_TEST_ONLY
|
||||
//test relays at standstill
|
||||
ESP_LOGW("brake-test", "test relays via motorctl");
|
||||
//turn on
|
||||
motorRight.setTarget(motorstate_t::BRAKE, 0);
|
||||
vTaskDelay(500 / portTICK_PERIOD_MS);
|
||||
motorRight.setTarget(motorstate_t::BRAKE, 0);
|
||||
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
||||
//turn off
|
||||
motorRight.setTarget(motorstate_t::IDLE, 0);
|
||||
vTaskDelay(500 / portTICK_PERIOD_MS);
|
||||
motorRight.setTarget(motorstate_t::IDLE, 0);
|
||||
|
||||
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
||||
|
||||
//go forward and brake
|
||||
ESP_LOGW("brake-test", "go forward 30%% then brake");
|
||||
motorRight.setTarget(motorstate_t::FWD, 30);
|
||||
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
||||
motorRight.setTarget(motorstate_t::BRAKE, 0);
|
||||
|
||||
vTaskDelay(3000 / portTICK_PERIOD_MS);
|
||||
|
||||
//brake partial
|
||||
ESP_LOGW("brake-test", "go forward 30%% then brake partial 10%%, hold for 5sec");
|
||||
motorRight.setTarget(motorstate_t::FWD, 30);
|
||||
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
||||
motorRight.setTarget(motorstate_t::BRAKE, 10);
|
||||
|
||||
vTaskDelay(5000 / portTICK_PERIOD_MS);
|
||||
//reset to idle
|
||||
motorRight.setTarget(motorstate_t::IDLE, 0);
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
//--- test controlledMotor --- (ramp)
|
||||
// //brake for 1 s
|
||||
|
Loading…
x
Reference in New Issue
Block a user