Add auto-cut functionality: diagram, switches, new state
control.cpp: - Add new systemState CUTTING - change systemState_t from enum to enum class (conflicting with cutter enum) - Add CUTTING functionality to CUT switch and auto cut after target reached if enabled cutter.cpp: - Add function cutter_isRunning() config: - Add GPIO_LAMP macro to config
This commit is contained in:
parent
824bad930e
commit
992d852189
File diff suppressed because one or more lines are too long
@ -17,7 +17,8 @@ extern "C" {
|
|||||||
#define GPIO_VFD_D1 GPIO_NUM_15 //ST1
|
#define GPIO_VFD_D1 GPIO_NUM_15 //ST1
|
||||||
//#define GPIO_VFD_D2 GPIO_NUM_15 //ST1 (D2 only used with 7.5kw vfd)
|
//#define GPIO_VFD_D2 GPIO_NUM_15 //ST1 (D2 only used with 7.5kw vfd)
|
||||||
|
|
||||||
#define GPIO_MOS2 GPIO_NUM_5 //mos2
|
#define GPIO_MOS1 GPIO_NUM_18 //mos1 (free)
|
||||||
|
#define GPIO_LAMP 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
|
||||||
|
|
||||||
|
@ -30,8 +30,8 @@ QueueHandle_t init_encoder(rotary_encoder_info_t * info){
|
|||||||
//====================
|
//====================
|
||||||
static const char *TAG = "control"; //tag for logging
|
static const char *TAG = "control"; //tag for logging
|
||||||
|
|
||||||
const char* systemStateStr[5] = {"COUNTING", "WINDING_START", "WINDING", "TARGET_REACHED", "MANUAL"};
|
const char* systemStateStr[6] = {"COUNTING", "WINDING_START", "WINDING", "TARGET_REACHED", "CUTTING", "MANUAL"};
|
||||||
systemState_t controlState = COUNTING;
|
systemState_t controlState = systemState_t::COUNTING;
|
||||||
|
|
||||||
char buf_disp[20]; //both displays
|
char buf_disp[20]; //both displays
|
||||||
char buf_disp1[10];// 8 digits + decimal point + \0
|
char buf_disp1[10];// 8 digits + decimal point + \0
|
||||||
@ -75,7 +75,7 @@ bool handleStopCondition(handledDisplay * displayTop, handledDisplay * displayBo
|
|||||||
//stop conditions that are checked in any mode
|
//stop conditions that are checked in any mode
|
||||||
//target reached
|
//target reached
|
||||||
if (lengthRemaining <= 0 ) {
|
if (lengthRemaining <= 0 ) {
|
||||||
changeState(TARGET_REACHED);
|
changeState(systemState_t::TARGET_REACHED);
|
||||||
vfd_setState(false);
|
vfd_setState(false);
|
||||||
displayTop->blink(1, 0, 1500, " S0LL ");
|
displayTop->blink(1, 0, 1500, " S0LL ");
|
||||||
displayBot->blink(1, 0, 1500, "ERREICHT");
|
displayBot->blink(1, 0, 1500, "ERREICHT");
|
||||||
@ -84,7 +84,7 @@ bool handleStopCondition(handledDisplay * displayTop, handledDisplay * displayBo
|
|||||||
}
|
}
|
||||||
//start button released
|
//start button released
|
||||||
else if (SW_START.state == false) {
|
else if (SW_START.state == false) {
|
||||||
changeState(COUNTING);
|
changeState(systemState_t::COUNTING);
|
||||||
vfd_setState(false);
|
vfd_setState(false);
|
||||||
displayTop->blink(2, 900, 1000, "- STOP -");
|
displayTop->blink(2, 900, 1000, "- STOP -");
|
||||||
displayBot->blink(2, 900, 1000, " TASTER ");
|
displayBot->blink(2, 900, 1000, " TASTER ");
|
||||||
@ -188,19 +188,22 @@ void task_control(void *pvParameter)
|
|||||||
rotary_encoder_reset(&encoder);
|
rotary_encoder_reset(&encoder);
|
||||||
lengthNow = 0;
|
lengthNow = 0;
|
||||||
buzzer.beep(1, 700, 100);
|
buzzer.beep(1, 700, 100);
|
||||||
|
//TODO: stop cutter with reset switch?
|
||||||
|
//cutter_stop();
|
||||||
|
}
|
||||||
|
|
||||||
//######### TESTING #########
|
|
||||||
//stop cutter
|
//--- CUT switch ---
|
||||||
cutter_stop();
|
if (SW_CUT.risingEdge) {
|
||||||
//######### TESTING #########
|
cutter_start();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//--- manual mode ---
|
//--- manual mode ---
|
||||||
//switch to manual motor control (2 buttons + poti)
|
//switch to manual motor control (2 buttons + poti)
|
||||||
if ( SW_PRESET2.state && (SW_PRESET1.state || SW_PRESET3.state) && controlState != MANUAL ) {
|
if ( SW_PRESET2.state && (SW_PRESET1.state || SW_PRESET3.state) && controlState != systemState_t::MANUAL ) {
|
||||||
//enable manual control
|
//enable manual control
|
||||||
changeState(MANUAL);
|
changeState(systemState_t::MANUAL);
|
||||||
buzzer.beep(3, 100, 60);
|
buzzer.beep(3, 100, 60);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -242,7 +245,7 @@ void task_control(void *pvParameter)
|
|||||||
|
|
||||||
|
|
||||||
//--- target length presets ---
|
//--- target length presets ---
|
||||||
if (controlState != MANUAL) { //dont apply preset length while controlling motor with preset buttons
|
if (controlState != systemState_t::MANUAL) { //dont apply preset length while controlling motor with preset buttons
|
||||||
if (SW_PRESET1.risingEdge){
|
if (SW_PRESET1.risingEdge){
|
||||||
lengthTarget = 1000;
|
lengthTarget = 1000;
|
||||||
buzzer.beep(lengthTarget/1000, 25, 30);
|
buzzer.beep(lengthTarget/1000, 25, 30);
|
||||||
@ -257,11 +260,6 @@ void task_control(void *pvParameter)
|
|||||||
lengthTarget = 10000;
|
lengthTarget = 10000;
|
||||||
buzzer.beep(lengthTarget/1000, 25, 30);
|
buzzer.beep(lengthTarget/1000, 25, 30);
|
||||||
displayBot.blink(2, 100, 100, "S0LL ");
|
displayBot.blink(2, 100, 100, "S0LL ");
|
||||||
|
|
||||||
//######### TESTING #########
|
|
||||||
//stop cutter
|
|
||||||
cutter_start();
|
|
||||||
//######### TESTING #########
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -275,12 +273,12 @@ void task_control(void *pvParameter)
|
|||||||
|
|
||||||
//--- statemachine ---
|
//--- statemachine ---
|
||||||
switch (controlState) {
|
switch (controlState) {
|
||||||
case COUNTING: //no motor action
|
case systemState_t::COUNTING: //no motor action
|
||||||
vfd_setState(false);
|
vfd_setState(false);
|
||||||
//TODO check stop condition before starting - prevents motor from starting 2 cycles when
|
//TODO check stop condition before starting - prevents motor from starting 2 cycles when
|
||||||
//--- start winding to length ---
|
//--- start winding to length ---
|
||||||
if (SW_START.risingEdge) {
|
if (SW_START.risingEdge) {
|
||||||
changeState(WINDING_START);
|
changeState(systemState_t::WINDING_START);
|
||||||
//TODO apply dynamic speed here too (if started when already very close)
|
//TODO apply dynamic speed here too (if started when already very close)
|
||||||
vfd_setSpeedLevel(1); //start at low speed
|
vfd_setSpeedLevel(1); //start at low speed
|
||||||
vfd_setState(true); //start motor
|
vfd_setState(true); //start motor
|
||||||
@ -289,28 +287,33 @@ void task_control(void *pvParameter)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WINDING_START: //wind slow for certain time
|
case systemState_t::WINDING_START: //wind slow for certain time
|
||||||
//set vfd speed depending on remaining distance
|
//set vfd speed depending on remaining distance
|
||||||
setDynSpeedLvl(1); //limit to speed lvl 1 (force slow start)
|
setDynSpeedLvl(1); //limit to speed lvl 1 (force slow start)
|
||||||
if (esp_log_timestamp() - timestamp_motorStarted > 2000) {
|
if (esp_log_timestamp() - timestamp_motorStarted > 2000) {
|
||||||
changeState(WINDING);
|
changeState(systemState_t::WINDING);
|
||||||
}
|
}
|
||||||
handleStopCondition(&displayTop, &displayBot); //stops if button released or target reached
|
handleStopCondition(&displayTop, &displayBot); //stops if button released or target reached
|
||||||
//TODO: cancel when there was no cable movement during start time?
|
//TODO: cancel when there was no cable movement during start time?
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WINDING: //wind fast, slow down when close
|
case systemState_t::WINDING: //wind fast, slow down when close
|
||||||
//set vfd speed depending on remaining distance
|
//set vfd speed depending on remaining distance
|
||||||
setDynSpeedLvl(); //slow down when close to target
|
setDynSpeedLvl(); //slow down when close to target
|
||||||
handleStopCondition(&displayTop, &displayBot); //stops if button released or target reached
|
handleStopCondition(&displayTop, &displayBot); //stops if button released or target reached
|
||||||
//TODO: cancel when there is no cable movement anymore e.g. empty / timeout?
|
//TODO: cancel when there is no cable movement anymore e.g. empty / timeout?
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TARGET_REACHED:
|
case systemState_t::TARGET_REACHED:
|
||||||
vfd_setState(false);
|
vfd_setState(false);
|
||||||
//switch to counting state when no longer at or above target length
|
//switch to counting state when no longer at or above target length
|
||||||
if ( lengthRemaining > 0 ) {
|
if ( lengthRemaining > 20 ) { //FIXME: require reset switch to be able to restart? or evaluate a tolerance here?
|
||||||
changeState(COUNTING);
|
changeState(systemState_t::COUNTING);
|
||||||
|
}
|
||||||
|
//start cutting if automatic cut is enabled
|
||||||
|
else if (SW_AUTO_CUT.state == true){
|
||||||
|
cutter_start();
|
||||||
|
changeState(systemState_t::CUTTING);
|
||||||
}
|
}
|
||||||
//show msg when trying to start, but target is reached
|
//show msg when trying to start, but target is reached
|
||||||
if (SW_START.risingEdge){
|
if (SW_START.risingEdge){
|
||||||
@ -320,14 +323,26 @@ void task_control(void *pvParameter)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MANUAL: //manually control motor via preset buttons + poti
|
case systemState_t::CUTTING:
|
||||||
|
//exit if finished cutting
|
||||||
|
if (cutter_isRunning() == false){
|
||||||
|
//TODO stop if start buttons released?
|
||||||
|
changeState(systemState_t::COUNTING);
|
||||||
|
//TODO reset automatically or wait for manual reset?
|
||||||
|
rotary_encoder_reset(&encoder);
|
||||||
|
lengthNow = 0;
|
||||||
|
buzzer.beep(1, 700, 100);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case systemState_t::MANUAL: //manually control motor via preset buttons + poti
|
||||||
//read poti value
|
//read poti value
|
||||||
potiRead = gpio_readAdc(ADC_CHANNEL_POTI); //0-4095
|
potiRead = gpio_readAdc(ADC_CHANNEL_POTI); //0-4095
|
||||||
//scale poti to speed levels 0-3
|
//scale poti to speed levels 0-3
|
||||||
uint8_t level = round( (float)potiRead / 4095 * 3 );
|
uint8_t level = round( (float)potiRead / 4095 * 3 );
|
||||||
//exit manual mode if preset2 released
|
//exit manual mode if preset2 released
|
||||||
if ( SW_PRESET2.state == false ) {
|
if ( SW_PRESET2.state == false ) {
|
||||||
changeState(COUNTING);
|
changeState(systemState_t::COUNTING);
|
||||||
buzzer.beep(1, 1000, 100);
|
buzzer.beep(1, 1000, 100);
|
||||||
}
|
}
|
||||||
//P2 + P1 -> turn left
|
//P2 + P1 -> turn left
|
||||||
@ -400,7 +415,7 @@ void task_control(void *pvParameter)
|
|||||||
displayBot.blinkStrings(buf_tmp, "S0LL ", 300, 100);
|
displayBot.blinkStrings(buf_tmp, "S0LL ", 300, 100);
|
||||||
}
|
}
|
||||||
//manual state: blink "manual"
|
//manual state: blink "manual"
|
||||||
else if (controlState == MANUAL) {
|
else if (controlState == systemState_t::MANUAL) {
|
||||||
displayBot.blinkStrings(" MANUAL ", buf_disp2, 1000, 1000);
|
displayBot.blinkStrings(" MANUAL ", buf_disp2, 1000, 1000);
|
||||||
}
|
}
|
||||||
//otherwise show target length
|
//otherwise show target length
|
||||||
|
@ -26,8 +26,8 @@ extern "C"
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
typedef enum systemState_t {COUNTING, WINDING_START, WINDING, TARGET_REACHED, MANUAL} systemState_t;
|
enum class systemState_t {COUNTING, WINDING_START, WINDING, TARGET_REACHED, CUTTING, MANUAL};
|
||||||
extern const char* systemStateStr[5];
|
extern const char* systemStateStr[6];
|
||||||
|
|
||||||
|
|
||||||
void task_control(void *pvParameter);
|
void task_control(void *pvParameter);
|
||||||
|
@ -55,6 +55,20 @@ cutter_state_t cutter_getState(){
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//============================
|
||||||
|
//===== cutter_isRunning =====
|
||||||
|
//============================
|
||||||
|
bool cutter_isRunning(){
|
||||||
|
if (cutter_state == cutter_state_t::START
|
||||||
|
|| cutter_state == cutter_state_t::CUTTING) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//---------------------------
|
//---------------------------
|
||||||
//-------- setState ---------
|
//-------- setState ---------
|
||||||
//---------------------------
|
//---------------------------
|
||||||
|
@ -28,5 +28,8 @@ void cutter_stop();
|
|||||||
cutter_state_t cutter_getState();
|
cutter_state_t cutter_getState();
|
||||||
//TODO: bool cutter_isOn() (simply return boolean instead of enum)
|
//TODO: bool cutter_isOn() (simply return boolean instead of enum)
|
||||||
|
|
||||||
|
//check if cutter is currently operating
|
||||||
|
bool cutter_isRunning();
|
||||||
|
|
||||||
//handle function - has to be run repeatedly
|
//handle function - has to be run repeatedly
|
||||||
void cutter_handle();
|
void cutter_handle();
|
||||||
|
@ -32,10 +32,11 @@ void init_gpios(){
|
|||||||
gpio_configure_output(GPIO_VFD_FWD);
|
gpio_configure_output(GPIO_VFD_FWD);
|
||||||
gpio_configure_output(GPIO_VFD_D0);
|
gpio_configure_output(GPIO_VFD_D0);
|
||||||
gpio_configure_output(GPIO_VFD_D1);
|
gpio_configure_output(GPIO_VFD_D1);
|
||||||
|
gpio_configure_output(GPIO_VFD_REV);
|
||||||
//gpio_configure_output(GPIO_VFD_D2); only used with 7.5kw vfd
|
//gpio_configure_output(GPIO_VFD_D2); only used with 7.5kw vfd
|
||||||
//2x power mosfets
|
//2x power mosfets
|
||||||
gpio_configure_output(GPIO_VFD_REV);
|
gpio_configure_output(GPIO_MOS1); //mos1
|
||||||
gpio_configure_output(GPIO_MOS2);
|
gpio_configure_output(GPIO_LAMP); //lamp
|
||||||
//onboard relay and buzzer
|
//onboard relay and buzzer
|
||||||
gpio_configure_output(GPIO_RELAY);
|
gpio_configure_output(GPIO_RELAY);
|
||||||
gpio_configure_output(GPIO_BUZZER);
|
gpio_configure_output(GPIO_BUZZER);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user