#include <ArSickLogger.h>
This class has a pointer to a robot and a laser... every time the robot has EITHER moved the distDiff, or turned the degDiff, it will take the current readings from the laser and log them into the log file given as the fileName to the constructor. Readings can also be taken by calling takeReading which explicitly tells the logger to take a reading.
The class can also add goals, see the constructor arg addGoals for information about that... you can also explicitly have it add a goal by calling addGoal.
Definition at line 53 of file ArSickLogger.h.
Public Member Functions | |
void | addGoal (void) |
Adds a goal where the robot is at the moment. | |
void | addInfoToLog (const char *str,...) |
Adds a string to the log file without a tag for where or when we are
Java and Python Wrappers: Not available in Java or Python wrapper libraries. | |
void | addInfoToLogPlain (const char *str) |
Same ass addToInfo, but does it without marking robot position. | |
void | addTagToLog (const char *str,...) |
Adds a string to the log file with a tag at the given moment
Java and Python Wrappers: Not available in Java or Python wrapper libraries. | |
void | addTagToLogPlain (const char *str) |
Same ass addToLog, but no varargs, wrapper for java. | |
ArSickLogger (ArRobot *robot, ArSick *sick, double distDiff, double degDiff, const char *fileName, bool addGoals=false, ArJoyHandler *joyHandler=NULL, const char *baseDirectory=NULL, bool useReflectorValues=false, ArRobotJoyHandler *robotJoyHandler=NULL) | |
Constructor. | |
double | getDegDiff (void) |
Gets the degrees to turn at which the robot will take a new reading. | |
double | getDistDiff (void) |
Gets the distance at which the robot will take a new reading. | |
void | robotTask (void) |
The task which gets attached to the robot. | |
void | setDegDiff (double degDiff) |
Sets the degrees to turn at which the robot will take a new reading. | |
void | setDistDiff (double distDiff) |
Sets the distance at which the robot will take a new reading. | |
void | takeNewReadings (bool takeNew) |
Sets if we're taking old (scan1:) readings. | |
void | takeOldReadings (bool takeOld) |
Sets if we're taking old (sick1:) readings. | |
void | takeReading (void) |
Explicitly tells the robot to take a reading. | |
bool | takingNewReadings (void) |
Gets if we're taking new (scan1:) readings. | |
bool | takingOldReadings (void) |
Gets if we're taking old (sick1:) readings. | |
bool | wasFileOpenedSuccessfully (void) |
Sees if the file was opened successfully. | |
virtual | ~ArSickLogger () |
Destructor. | |
Protected Member Functions | |
void | goalKeyCallback (void) |
void | internalAddGoal (void) |
void | internalPrintPos (ArPose poseTaken) |
void | internalTakeReading (void) |
void | internalWriteTags (void) |
bool | loopPacketHandler (ArRobotPacket *packet) |
Protected Attributes | |
bool | myAddGoalExplicit |
bool | myAddGoalKeyboard |
bool | myAddGoals |
std::string | myBaseDirectory |
double | myDegDiff |
double | myDistDiff |
FILE * | myFile |
std::string | myFileName |
bool | myFirstGoalTaken |
bool | myFirstTaken |
ArFunctorC< ArSickLogger > | myGoalKeyCB |
std::list< std::string > | myInfos |
ArJoyHandler * | myJoyHandler |
ArPose | myLast |
bool | myLastAddGoalKeyboard |
ArPose | myLastGoalTakenPose |
ArTime | myLastGoalTakenTime |
bool | myLastJoyButton |
unsigned char | myLastLoops |
bool | myLastRobotJoyButton |
double | myLastVel |
ArRetFunctor1C< bool, ArSickLogger, ArRobotPacket * > | myLoopPacketHandlerCB |
bool | myNewReadings |
int | myNumGoal |
bool | myOldReadings |
ArRobot * | myRobot |
ArRobotJoyHandler * | myRobotJoyHandler |
int | myScanNumber |
ArSectors | mySectors |
ArSick * | mySick |
ArTime | myStartTime |
std::list< std::string > | myTags |
bool | myTakeReadingExplicit |
ArFunctorC< ArSickLogger > | myTaskCB |
bool | myUseReflectorValues |
bool | myWrote |
|
Constructor. Make sure you have called ArSick::configure or ArSick::configureShort on your laser before you make this class
Definition at line 57 of file ArSickLogger.cpp. |
|
Adds a string to the log file without a tag for where or when we are Java and Python Wrappers: Not available in Java or Python wrapper libraries. The robot MUST be locked before you call this function, so that this function is not adding to a list as the robotTask is using it. This function takes the given tag and puts it into the log file by itself Definition at line 257 of file ArSickLogger.cpp. |
|
Same ass addToInfo, but does it without marking robot position. The robot MUST be locked before you call this function, so that this function is not adding to a list as the robotTask is using it. This function takes the given tag and puts it into the log file by itself Definition at line 245 of file ArSickLogger.cpp. |
|
Adds a string to the log file with a tag at the given moment Java and Python Wrappers: Not available in Java or Python wrapper libraries. The robot MUST be locked before you call this function, so that this function is not adding to a list as the robotTask is using it. This function takes the given tag and puts it into the log file along with a tag as to where the robot was and when in the mapping it was Definition at line 226 of file ArSickLogger.cpp. |
|
Same ass addToLog, but no varargs, wrapper for java. The robot MUST be locked before you call this function, so that this function is not adding to a list as the robotTask is using it. This function takes the given tag and puts it into the log file along with a tag as to where the robot was and when in the mapping it was Definition at line 213 of file ArSickLogger.cpp. |
|
use the adjusted raw readings if we can, otherwise just use the raw readings like before Note that the the sick1: or scan1: must be the last thing in that timestamp, ie that you should put any other data before it. Definition at line 354 of file ArSickLogger.cpp. |