Fix bug in scaling, Fix http cmd gen, Fix overflow
Fix several bugs noticed while testing the preceding commits in dev
branch:
- Fix bug in function scaleCoordinate
  - scaling was wrong resulting in negative/inverted values at start of axis
- Adjust timeout value from 30s to 5min
- Fix http joystick behaivor
  - calculate angle, radius and evaluate position AFTER the coordinates
    have been scaled in control.cpp (bug introduced when switching applying tolerance
    on controller instead of in the app)
- Add independent toleranceZero for X and Y axis -> unnecessary to have
  large tolerance for x axis... makes turning more sensitive
- Fix stack overflow in control task
  - controller crashed repeatedly when logging output was enabled in
    control task
  - -> doubled stack size at task creation in main.cpp
currently works, position hast to be evaluated AFTER coordinate scaling
			
			
This commit is contained in:
		
							parent
							
								
									f38940b7bf
								
							
						
					
					
						commit
						73325e08ce
					
				| @ -45,10 +45,11 @@ controlledMotor motorRight(configDriverRight, configMotorControl); | |||||||
| control_config_t configControl = { | control_config_t configControl = { | ||||||
|     .defaultMode = controlMode_t::JOYSTICK, //default mode after startup and toggling IDLE
 |     .defaultMode = controlMode_t::JOYSTICK, //default mode after startup and toggling IDLE
 | ||||||
|     //--- timeout ---    
 |     //--- timeout ---    
 | ||||||
|     .timeoutMs = 30*1000,        //time of inactivity after which the mode gets switched to IDLE
 |     .timeoutMs = 5*60*1000,      //time of inactivity after which the mode gets switched to IDLE
 | ||||||
|     .timeoutTolerancePer = 5,    //percentage the duty can vary between timeout checks considered still inactive
 |     .timeoutTolerancePer = 5,    //percentage the duty can vary between timeout checks considered still inactive
 | ||||||
|     //--- http mode ---
 |     //--- http mode ---
 | ||||||
|     .http_toleranceZeroPer = 5,  //percentage around joystick axis the coordinate snaps to 0
 |     .http_toleranceZeroX_Per = 3,  //percentage around joystick axis the coordinate snaps to 0
 | ||||||
|  |     .http_toleranceZeroY_Per = 10, | ||||||
|     .http_toleranceEndPer = 2,   //percentage before joystick end the coordinate snaps to 1/-1
 |     .http_toleranceEndPer = 2,   //percentage before joystick end the coordinate snaps to 1/-1
 | ||||||
|     .http_timeoutMs = 3000       //time no new data was received before the motors get turned off
 |     .http_timeoutMs = 3000       //time no new data was received before the motors get turned off
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -100,15 +100,19 @@ void controlledArmchair::startHandleLoop() { | |||||||
|                     //--- scale coordinates ---
 |                     //--- scale coordinates ---
 | ||||||
|                     //note: scaleCoordinate function currently can not handle negative input -> added offset to input
 |                     //note: scaleCoordinate function currently can not handle negative input -> added offset to input
 | ||||||
|                     // scaleCoordinate(input, min, max, center, tolerance_zero_per, tolerance_end_per)
 |                     // scaleCoordinate(input, min, max, center, tolerance_zero_per, tolerance_end_per)
 | ||||||
|                     dataRead.x = scaleCoordinate(dataRead.x+1, 0, 2, 1, config.http_toleranceZeroPer, config.http_toleranceEndPer);  |                     dataRead.x = scaleCoordinate(dataRead.x+1, 0, 2, 1, config.http_toleranceZeroX_Per, config.http_toleranceEndPer);  | ||||||
|                     dataRead.y = scaleCoordinate(dataRead.y+1, 0, 2, 1, config.http_toleranceZeroPer, config.http_toleranceEndPer); |                     dataRead.y = scaleCoordinate(dataRead.y+1, 0, 2, 1, config.http_toleranceZeroY_Per, config.http_toleranceEndPer); | ||||||
|                     //--- calculate radius with new coordinates ---
 |                     //--- re-calculate radius, angle and position with new/scaled coordinates ---
 | ||||||
|                     dataRead.radius = sqrt(pow(dataRead.x,2) + pow(dataRead.y,2)); |                     dataRead.radius = sqrt(pow(dataRead.x,2) + pow(dataRead.y,2)); | ||||||
|  |                     dataRead.angle = (atan(dataRead.y/dataRead.x) * 180) / 3.141; | ||||||
|  |                     dataRead.position = joystick_evaluatePosition(dataRead.x, dataRead.y); | ||||||
|  | 
 | ||||||
|                     ESP_LOGD(TAG, "processed/scaled data: x=%.3f  y=%.3f  radius=%.3f", dataRead.x, dataRead.y, dataRead.radius); |                     ESP_LOGD(TAG, "processed/scaled data: x=%.3f  y=%.3f  radius=%.3f", dataRead.x, dataRead.y, dataRead.radius); | ||||||
| 
 | 
 | ||||||
|                     //--- generate motor commands ---
 |                     //--- generate motor commands ---
 | ||||||
|                     //pass received joystick data from http queue to generatecommands function from joystick.hpp
 |                     //pass received joystick data from http queue to generatecommands function from joystick.hpp
 | ||||||
|                     ESP_LOGV(TAG, "generating commands..."); |                     ESP_LOGV(TAG, "generating commands..."); | ||||||
|  |                     ESP_LOGD(TAG, "generating commands from x=%.3f  y=%.3f  radius=%.3f  angle=%.3f", dataRead.x, dataRead.y, dataRead.radius, dataRead.angle); | ||||||
|                     commands = joystick_generateCommandsDriving(dataRead); |                     commands = joystick_generateCommandsDriving(dataRead); | ||||||
| 
 | 
 | ||||||
|                     //--- apply commands to motors ---
 |                     //--- apply commands to motors ---
 | ||||||
|  | |||||||
| @ -20,7 +20,8 @@ typedef struct control_config_t { | |||||||
|     uint32_t timeoutMs;         //time of inactivity after which the mode gets switched to IDLE
 |     uint32_t timeoutMs;         //time of inactivity after which the mode gets switched to IDLE
 | ||||||
|     float timeoutTolerancePer;  //percentage the duty can vary between timeout checks considered still inactive
 |     float timeoutTolerancePer;  //percentage the duty can vary between timeout checks considered still inactive
 | ||||||
|     //--- http mode ---
 |     //--- http mode ---
 | ||||||
|     float http_toleranceZeroPer;//percentage around joystick axis the coordinate snaps to 0
 |     float http_toleranceZeroX_Per;//percentage around joystick axis the coordinate snaps to 0
 | ||||||
|  |     float http_toleranceZeroY_Per; | ||||||
|     float http_toleranceEndPer; //percentage before joystick end the coordinate snaps to 1/-1
 |     float http_toleranceEndPer; //percentage before joystick end the coordinate snaps to 1/-1
 | ||||||
|     uint32_t http_timeoutMs;    //time no new data was received before the motors get turned off
 |     uint32_t http_timeoutMs;    //time no new data was received before the motors get turned off
 | ||||||
| } control_config_t; | } control_config_t; | ||||||
|  | |||||||
| @ -136,7 +136,7 @@ esp_err_t on_joystick_url(httpd_req_t *req) | |||||||
|     data.angle = static_cast<float>(angle_json->valuedouble); |     data.angle = static_cast<float>(angle_json->valuedouble); | ||||||
| 
 | 
 | ||||||
|     //--- evaluate joystick position enum ---
 |     //--- evaluate joystick position enum ---
 | ||||||
|     data.position = joystick_evaluatePosition(data.x, data.y); |     //data.position = joystick_evaluatePosition(data.x, data.y);
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     //log received and parsed values
 |     //log received and parsed values
 | ||||||
|  | |||||||
| @ -146,15 +146,15 @@ float scaleCoordinate(float input, float min, float max, float center, float tol | |||||||
|     //--- positive area ---
 |     //--- positive area ---
 | ||||||
|     else if (input > center) { |     else if (input > center) { | ||||||
|         float range = max - center - tolerance_zero - tolerance_end; |         float range = max - center - tolerance_zero - tolerance_end; | ||||||
|         coordinate = (input - center - tolerance_zero - tolerance_end) / range; |         coordinate = (input - center - tolerance_zero) / range; | ||||||
|     } |     } | ||||||
|     //--- negative area ---
 |     //--- negative area ---
 | ||||||
|     else if (input < center) { |     else if (input < center) { | ||||||
|         float range = (center - min - tolerance_zero - tolerance_end); |         float range = (center - min - tolerance_zero - tolerance_end); | ||||||
|         coordinate = -(center-input - tolerance_zero - tolerance_end) / range; |         coordinate = -(center-input - tolerance_zero) / range; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     ESP_LOGD(TAG, "scaled coordinate from %.3f to %.3f", input, coordinate); |     ESP_LOGD(TAG, "scaled coordinate from %.3f to %.3f, tolZero=%.3f, tolEnd=%.3f", input, coordinate, tolerance_zero, tolerance_end); | ||||||
|     //return coordinate (-1 to 1)
 |     //return coordinate (-1 to 1)
 | ||||||
|     return coordinate; |     return coordinate; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -169,7 +169,7 @@ extern "C" void app_main(void) { | |||||||
|     //--- create task for control ---
 |     //--- create task for control ---
 | ||||||
|     //-------------------------------
 |     //-------------------------------
 | ||||||
|     //task that generates motor commands depending on the current mode and sends those to motorctl task
 |     //task that generates motor commands depending on the current mode and sends those to motorctl task
 | ||||||
|     xTaskCreate(&task_control, "task_control", 2048, NULL, 5, NULL); |     xTaskCreate(&task_control, "task_control", 4096, NULL, 5, NULL); | ||||||
| 
 | 
 | ||||||
|     //------------------------------
 |     //------------------------------
 | ||||||
|     //--- create task for button ---
 |     //--- create task for button ---
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user