Add MANUAL mode, Add vfd direction support

vfd: extend vfd_setState function with direction enum (default fwd)
main: reduce log output from buzzer task
config: use mos1 as vfd_FWD output
control:
    add MANUAL state: motor can be controlled via preset buttons
    adjust code slightly to support new state (also see updated
    function-diagram)
This commit is contained in:
jonny_ji7 2022-08-19 16:29:59 +02:00
parent f6b2093650
commit dddd54b03a
9 changed files with 94 additions and 35 deletions

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

Binary file not shown.

View File

@ -10,13 +10,13 @@ extern "C" {
//===== define output gpio pins ===== //===== define output gpio pins =====
//=================================== //===================================
//4x stepper mosfet outputs for VFD //4x stepper mosfet outputs for VFD
#define GPIO_VFD_FWD GPIO_NUM_4 #define GPIO_VFD_FWD GPIO_NUM_4 //ST4
#define GPIO_VFD_D0 GPIO_NUM_16 #define GPIO_VFD_D0 GPIO_NUM_16 //ST3
#define GPIO_VFD_D1 GPIO_NUM_2 #define GPIO_VFD_D1 GPIO_NUM_2 //ST2
#define GPIO_VFD_D2 GPIO_NUM_15 #define GPIO_VFD_D2 GPIO_NUM_15 //ST1
#define GPIO_MOS1 GPIO_NUM_18 #define GPIO_VFD_REV GPIO_NUM_18 //mos1
#define GPIO_MOS2 GPIO_NUM_5 #define GPIO_MOS2 GPIO_NUM_5 //mos2
#define GPIO_RELAY GPIO_NUM_13 #define GPIO_RELAY GPIO_NUM_13
#define GPIO_BUZZER GPIO_NUM_12 #define GPIO_BUZZER GPIO_NUM_12

View File

@ -79,7 +79,7 @@ int readAdc(adc1_channel_t adc_channel, bool inverted = false) {
//==================== //====================
static const char *TAG = "control"; static const char *TAG = "control";
const char* systemStateStr[4] = {"COUNTING", "WINDING_START", "WINDING", "TARGET_REACHED"}; const char* systemStateStr[5] = {"COUNTING", "WINDING_START", "WINDING", "TARGET_REACHED", "MANUAL"};
systemState_t controlState = COUNTING; systemState_t controlState = COUNTING;
max7219_t display; //display device max7219_t display; //display device
@ -117,6 +117,29 @@ void changeState (systemState_t stateNew) {
} }
//===== check Stop Condition =====
//function that checks whether start button is released or target is reached (used in multiple states)
//returns true when stopped, false when no action
bool checkStopCondition(){
//--- stop conditions ---
//stop conditions that are checked in any mode
//disable motor and switch to COUNTING when start button released
if (SW_START.state == false) { //TODO use fallingEdge here more clean?
changeState(COUNTING);
vfd_setState(false);
return true;
}
//disable motor and switch to TARGET_REACHED
else if (lengthDiff >= 0 ) {
//TODO: display "REACHED" on 7segment here or reached state (start pressed but reached)
changeState(TARGET_REACHED);
vfd_setState(false);
return true;
} else {
return false;
}
}
//======================== //========================
//===== control task ===== //===== control task =====
@ -207,6 +230,10 @@ void task_control(void *pvParameter)
lengthNow = 0; lengthNow = 0;
buzzer.beep(1, 700, 100); buzzer.beep(1, 700, 100);
} }
//TODO add preset switches
@ -216,29 +243,22 @@ void task_control(void *pvParameter)
//calculate length difference //calculate length difference
lengthDiff = lengthNow - lengthTarget; lengthDiff = lengthNow - lengthTarget;
//--- stop conditions ---
//stop conditions that are checked in any mode
//disable motor and switch to COUNTING when start button released
if (SW_START.state == false) { //TODO use fallingEdge here more clean?
changeState(COUNTING);
vfd_setState(false);
}
//disable motor and switch to TARGET_REACHED
else if (lengthDiff >= 0 ) {
//TODO: display "REACHED" on 7segment here or reached state (start pressed but reached)
changeState(TARGET_REACHED);
vfd_setState(false);
}
//--- statemachine --- //--- statemachine ---
switch (controlState) { switch (controlState) {
case COUNTING: //no motor action case COUNTING: //no motor action
//TODO stop motor here every run instead of at button event? vfd_setState(false);
//--- start winding to length ---
if (SW_START.risingEdge) { if (SW_START.risingEdge) {
changeState(WINDING_START); changeState(WINDING_START);
vfd_setSpeedLevel(2); //start at low speed vfd_setSpeedLevel(2); //start at low speed
vfd_setState(true); //start motor vfd_setState(true); //start motor
timestamp_motorStarted = esp_log_timestamp(); //save time started timestamp_motorStarted = esp_log_timestamp(); //save time started
}
//--- switch to manual motor control (2 buttons + poti) ---
else if ( SW_PRESET2.state && (SW_PRESET1.state || SW_PRESET3.state) ) {
changeState(MANUAL);
buzzer.beep(4, 100, 60);
} }
break; break;
@ -247,6 +267,7 @@ void task_control(void *pvParameter)
if (esp_log_timestamp() - timestamp_motorStarted > 2000) { if (esp_log_timestamp() - timestamp_motorStarted > 2000) {
changeState(WINDING); changeState(WINDING);
} }
checkStopCondition();
//TESTING: SIMULATE LENGTH INCREASE //TESTING: SIMULATE LENGTH INCREASE
//lengthNow += 2; //lengthNow += 2;
break; break;
@ -279,6 +300,7 @@ void task_control(void *pvParameter)
//TESTING: SIMULATE LENGTH INCREASE //TESTING: SIMULATE LENGTH INCREASE
//lengthNow += 200; //lengthNow += 200;
} }
checkStopCondition();
//see "stop conditions" above that switches to TARGET_REACHED when targed reached //see "stop conditions" above that switches to TARGET_REACHED when targed reached
break; break;
@ -286,6 +308,23 @@ void task_control(void *pvParameter)
//nothing to do here yet //nothing to do here yet
//see "stop conditions" above that switches to COUNTING when start button released //see "stop conditions" above that switches to COUNTING when start button released
break; break;
case MANUAL:
//P2 + P1 -> turn left
if ( SW_PRESET2.state && SW_PRESET1.state && !SW_PRESET3.state ) {
vfd_setSpeedLevel(2); //TODO: use poti input for level
vfd_setState(true, REV);
}
//P2 + P3 -> turn right
else if ( SW_PRESET2.state && SW_PRESET2.state && !SW_PRESET1.state ) {
vfd_setSpeedLevel(2); //TODO: use poti input for level
vfd_setState(true, FWD);
}
else { //no switch combination matches anymore
vfd_setState(false);
changeState(COUNTING);
buzzer.beep(1, 1000, 100);
}
} }

View File

@ -22,8 +22,8 @@ extern "C"
typedef enum systemState_t {COUNTING, WINDING_START, WINDING, TARGET_REACHED} systemState_t; typedef enum systemState_t {COUNTING, WINDING_START, WINDING, TARGET_REACHED, MANUAL} systemState_t;
extern const char* systemStateStr[4]; extern const char* systemStateStr[5];
void task_control(void *pvParameter); void task_control(void *pvParameter);

View File

@ -32,7 +32,7 @@ void init_gpios(){
gpio_configure_output(GPIO_VFD_D1); gpio_configure_output(GPIO_VFD_D1);
gpio_configure_output(GPIO_VFD_D2); gpio_configure_output(GPIO_VFD_D2);
//2x power mosfets //2x power mosfets
gpio_configure_output(GPIO_MOS1); gpio_configure_output(GPIO_VFD_REV);
gpio_configure_output(GPIO_MOS2); gpio_configure_output(GPIO_MOS2);
//onboard relay and buzzer //onboard relay and buzzer
gpio_configure_output(GPIO_RELAY); gpio_configure_output(GPIO_RELAY);
@ -77,6 +77,7 @@ extern "C" void app_main()
//define loglevel //define loglevel
esp_log_level_set("*", ESP_LOG_INFO); esp_log_level_set("*", ESP_LOG_INFO);
esp_log_level_set("buzzer", ESP_LOG_ERROR);
esp_log_level_set("control", ESP_LOG_INFO); esp_log_level_set("control", ESP_LOG_INFO);
//create task for controlling the machine //create task for controlling the machine

View File

@ -2,33 +2,48 @@
#define CHECK_BIT(var,pos) (((var)>>(pos)) & 1) #define CHECK_BIT(var,pos) (((var)>>(pos)) & 1)
const char* vfd_directionStr[2] = {"FWD", "REV"};
static const char *TAG = "vfd"; static const char *TAG = "vfd";
uint8_t level = 0; //current speed level uint8_t level = 0; //current speed level
bool state = false; //current state bool state = false; //current state
vfd_direction_t direction = FWD; //current direction
//============================= //=============================
//========= setState ========== //========= setState ==========
//============================= //=============================
void vfd_setState(bool stateNew){ void vfd_setState(bool stateNew, vfd_direction_t directionNew){
//only proceed and send log output when state is actually changed //only proceed and send log output when state or direction actually changed
if (state == stateNew) { if ( state == stateNew && direction == directionNew ) {
//already at target state -> nothing todo //already at target state and target direction -> do nothing
return; return;
} }
//log old and new state
ESP_LOGI(TAG, "CHANGING vfd state from: %i %s", (int)state, vfd_directionStr[(int)direction]);
ESP_LOGI(TAG, "CHANGING vfd state to: %i %s", (int)stateNew, vfd_directionStr[(int)directionNew]);
//update stored state //update stored state
state = stateNew; state = stateNew;
direction = directionNew;
//turn motor on/off //turn motor on/off with target direction
if (state == true) { if (state == true) {
gpio_set_level(GPIO_VFD_FWD, 1); switch (direction) {
case FWD:
gpio_set_level(GPIO_VFD_REV, 0);
gpio_set_level(GPIO_VFD_FWD, 1);
break;
case REV:
gpio_set_level(GPIO_VFD_FWD, 0);
gpio_set_level(GPIO_VFD_REV, 1);
break;
}
gpio_set_level(GPIO_RELAY, 1); gpio_set_level(GPIO_RELAY, 1);
} else { } else {
gpio_set_level(GPIO_VFD_FWD, 0); gpio_set_level(GPIO_VFD_FWD, 0);
gpio_set_level(GPIO_VFD_REV, 0);
gpio_set_level(GPIO_RELAY, 0); gpio_set_level(GPIO_RELAY, 0);
} }
ESP_LOGI(TAG, "CHANGED state to %i", (int)state);
} }

View File

@ -11,9 +11,13 @@ extern "C"
#include "config.hpp" #include "config.hpp"
//enum defining motor direction
typedef enum vfd_direction_t {FWD, REV} vfd_direction_t;
//strubg array to be able to log direction state as string
extern const char* vfd_directionStr[2];
//function for setting the state (motor on/off) //function for setting the state and optional direction of the motor: on/off, FWD/REV (default FWD)
void vfd_setState(bool stateNew); void vfd_setState(bool stateNew, vfd_direction_t direction = FWD);
//function for setting the speed level (1-7) //function for setting the speed level (1-7)
void vfd_setSpeedLevel(uint8_t levelNew = 0); void vfd_setSpeedLevel(uint8_t levelNew = 0);