RtabmapThread.h
Go to the documentation of this file.
00001 /*
00002 Copyright (c) 2010-2014, Mathieu Labbe - IntRoLab - Universite de Sherbrooke
00003 All rights reserved.
00004 
00005 Redistribution and use in source and binary forms, with or without
00006 modification, are permitted provided that the following conditions are met:
00007     * Redistributions of source code must retain the above copyright
00008       notice, this list of conditions and the following disclaimer.
00009     * Redistributions in binary form must reproduce the above copyright
00010       notice, this list of conditions and the following disclaimer in the
00011       documentation and/or other materials provided with the distribution.
00012     * Neither the name of the Universite de Sherbrooke nor the
00013       names of its contributors may be used to endorse or promote products
00014       derived from this software without specific prior written permission.
00015 
00016 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
00017 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00018 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00019 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY
00020 DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00021 (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00022 LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00023 ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00024 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00025 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00026 */
00027 
00028 #ifndef RTABMAPTHREAD_H_
00029 #define RTABMAPTHREAD_H_
00030 
00031 #include "rtabmap/core/RtabmapExp.h" // DLL export/import defines
00032 
00033 #include <rtabmap/utilite/UThreadNode.h>
00034 #include <rtabmap/utilite/UEventsHandler.h>
00035 #include <rtabmap/utilite/USemaphore.h>
00036 #include <rtabmap/utilite/UMutex.h>
00037 
00038 #include "rtabmap/core/RtabmapEvent.h"
00039 #include "rtabmap/core/SensorData.h"
00040 #include "rtabmap/core/Parameters.h"
00041 
00042 #include <stack>
00043 
00044 class UTimer;
00045 
00046 namespace rtabmap {
00047 
00048 class Rtabmap;
00049 
00050 class RTABMAP_EXP RtabmapThread :
00051         public UThreadNode,
00052         public UEventsHandler
00053 {
00054 public:
00055         enum State {
00056                 kStateInit,
00057                 kStateDetecting,
00058                 kStateReseting,
00059                 kStateClose,
00060                 kStateChangingParameters,
00061                 kStateDumpingMemory,
00062                 kStateDumpingPrediction,
00063                 kStateGeneratingDOTGraph,
00064                 kStateGeneratingDOTLocalGraph,
00065                 kStateGeneratingTOROGraphLocal,
00066                 kStateGeneratingTOROGraphGlobal,
00067                 kStateCleanDataBuffer,
00068                 kStatePublishingMapLocal,
00069                 kStatePublishingMapGlobal,
00070                 kStatePublishingTOROGraphLocal,
00071                 kStatePublishingTOROGraphGlobal,
00072                 kStateTriggeringMap,
00073                 kStateAddingUserData,
00074                 kStateSettingGoal
00075         };
00076 
00077 public:
00078         // take ownership
00079         RtabmapThread(Rtabmap * rtabmap);
00080         virtual ~RtabmapThread();
00081 
00082         void clearBufferedData();
00083         void setDetectorRate(float rate);
00084         void setBufferSize(int bufferSize);
00085 
00086 protected:
00087         virtual void handleEvent(UEvent * anEvent);
00088 
00089 private:
00090         virtual void mainLoop();
00091         virtual void mainLoopKill();
00092         void process();
00093         void addData(const SensorData & data);
00094         void getData(SensorData & data);
00095         void pushNewState(State newState, const ParametersMap & parameters = ParametersMap());
00096         void setDataBufferSize(int size);
00097         void publishMap(bool optimized, bool full) const;
00098         void publishTOROGraph(bool optimized, bool full) const;
00099 
00100 private:
00101         UMutex _stateMutex;
00102         std::stack<State> _state;
00103         std::stack<ParametersMap> _stateParam;
00104 
00105         std::list<SensorData> _dataBuffer;
00106         UMutex _dataMutex;
00107         USemaphore _dataAdded;
00108         int _dataBufferMaxSize;
00109         float _rate;
00110         UTimer * _frameRateTimer;
00111 
00112         Rtabmap * _rtabmap;
00113         bool _paused;
00114         Transform lastPose_;
00115         float _rotVariance;
00116         float _transVariance;
00117 
00118         std::vector<unsigned char> _userData;
00119         UMutex _userDataMutex;
00120 };
00121 
00122 } /* namespace rtabmap */
00123 #endif /* RTABMAPTHREAD_H_ */


rtabmap
Author(s): Mathieu Labbe
autogenerated on Fri Aug 28 2015 12:51:32