Compare commits

..

No commits in common. "60e19a8968ad06b09b137865c23222e6d67b4afa" and "6a55bda5191887ed30ed23552c26af3b5d148706" have entirely different histories.

View File

@ -25,10 +25,12 @@ void LFR_StateMachine::sanitize (string& s) const
bool LFR_StateMachine::checkStringValidity (const std::vector<std::string>& s) const bool LFR_StateMachine::checkStringValidity (const std::vector<std::string>& s) const
{ {
try if(s.size() != 5)
{ {
int i = stoi(s[0]); return false;
if(i == 0 && s.size() == 5) }
try
{ {
for(int i = 0; i < 4; i ++) for(int i = 0; i < 4; i ++)
{ {
@ -37,12 +39,8 @@ bool LFR_StateMachine::checkStringValidity (const std::vector<std::string>& s) c
return false; return false;
} }
} }
} int i = stoi(s[4]);
else if(i == 1) if(i != 0 && i != 1)
{
return true;
}
else
{ {
return false; return false;
} }
@ -61,12 +59,12 @@ void LFR_StateMachine::parseString(string s)
return; return;
} }
double wheels[4] = {0.0, 0.0, 0.0, 0.0}; double wheels[4] = {0.0, 0.0, 0.0, 0.0};
int mode = std::stoi(splitStr[0]); int mode = std::stoi(splitStr[4]);
if(mode == 0) { for(int i = 0; i < 3; i++)
for(int i = 1; i < 4; i++)
{ {
wheels[i] = std::stod(splitStr[i]); wheels[i] = std::stod(splitStr[i]);
} }
if(mode == 0) {
setState(State::Manual::getInstance()); setState(State::Manual::getInstance());
uartCommunicator.sendTelegram(wheels[0], wheels[1], wheels[2], wheels[3]); uartCommunicator.sendTelegram(wheels[0], wheels[1], wheels[2], wheels[3]);
} }
@ -75,7 +73,7 @@ void LFR_StateMachine::parseString(string s)
} }
LFR_StateMachine::LFR_StateMachine(): LFR_StateMachine::LFR_StateMachine():
autonomousMode(videoHeight, videoWidth, thresholdBinary, gaussKernelSize, maxSpeed, [&](std::exception const &ex) autonomousMode(videoHeight, videoWidth, thresholdBinary, gaussKernelSize, maxSpeed [&](std::exception const &ex)
{ {
std::unique_lock<std::mutex> lock(mutex); std::unique_lock<std::mutex> lock(mutex);
std::cerr<<"camera exception:"<<ex.what()<<std::endl; std::cerr<<"camera exception:"<<ex.what()<<std::endl;