28 #ifndef DBDRIVERSQLITE3_H_
29 #define DBDRIVERSQLITE3_H_
31 #include "rtabmap/core/rtabmap_core_export.h"
33 #include <opencv2/features2d/features2d.hpp>
45 virtual void parseParameters(
const ParametersMap & parameters);
46 virtual bool isInMemory()
const {
return getUrl().empty() || _dbInMemory;}
47 void setDbInMemory(
bool dbInMemory);
48 void setJournalMode(
int journalMode);
49 void setCacheSize(
unsigned int cacheSize);
50 void setSynchronous(
int synchronous);
51 void setTempStore(
int tempStore);
54 virtual bool connectDatabaseQuery(
const std::string & url,
bool overwritten =
false);
55 virtual void disconnectDatabaseQuery(
bool save =
true,
const std::string & outputUrl =
"");
56 virtual bool isConnectedQuery()
const;
57 virtual unsigned long getMemoryUsedQuery()
const;
58 virtual bool getDatabaseVersionQuery(std::string & version)
const;
59 virtual long getNodesMemoryUsedQuery()
const;
60 virtual long getLinksMemoryUsedQuery()
const;
61 virtual long getImagesMemoryUsedQuery()
const;
62 virtual long getDepthImagesMemoryUsedQuery()
const;
63 virtual long getCalibrationsMemoryUsedQuery()
const;
64 virtual long getGridsMemoryUsedQuery()
const;
65 virtual long getLaserScansMemoryUsedQuery()
const;
66 virtual long getUserDataMemoryUsedQuery()
const;
67 virtual long getWordsMemoryUsedQuery()
const;
68 virtual long getFeaturesMemoryUsedQuery()
const;
69 virtual long getStatisticsMemoryUsedQuery()
const;
70 virtual int getLastNodesSizeQuery()
const;
71 virtual int getLastDictionarySizeQuery()
const;
72 virtual int getTotalNodesSizeQuery()
const;
73 virtual int getTotalDictionarySizeQuery()
const;
75 virtual std::map<std::string, float> getStatisticsQuery(
int nodeId,
double & stamp, std::vector<int> * wmState)
const;
76 virtual std::map<int, std::pair<std::map<std::string, float>,
double> > getAllStatisticsQuery()
const;
77 virtual std::map<int, std::vector<int> > getAllStatisticsWmStatesQuery()
const;
79 virtual void executeNoResultQuery(
const std::string & sql)
const;
81 virtual void getWeightQuery(
int signatureId,
int & weight)
const;
83 virtual void saveQuery(
const std::list<Signature *> & signatures);
84 virtual void saveQuery(
const std::list<VisualWord *> & words)
const;
85 virtual void updateQuery(
const std::list<Signature *> & signatures,
bool updateTimestamp)
const;
86 virtual void updateQuery(
const std::list<VisualWord *> & words,
bool updateTimestamp)
const;
88 virtual void addLinkQuery(
const Link & link)
const;
89 virtual void updateLinkQuery(
const Link & link)
const;
91 virtual void updateOccupancyGridQuery(
93 const cv::Mat & ground,
94 const cv::Mat & obstacles,
95 const cv::Mat &
empty,
97 const cv::Point3f & viewpoint)
const;
99 virtual void updateCalibrationQuery(
101 const std::vector<CameraModel> & models,
102 const std::vector<StereoCameraModel> & stereoModels)
const;
104 virtual void updateDepthImageQuery(
106 const cv::Mat & image)
const;
108 void updateLaserScanQuery(
112 virtual void addStatisticsQuery(
const Statistics & statistics,
bool saveWmState)
const;
113 virtual void savePreviewImageQuery(
const cv::Mat & image)
const;
114 virtual cv::Mat loadPreviewImageQuery()
const;
115 virtual void saveOptimizedPosesQuery(
const std::map<int, Transform> & optimizedPoses,
const Transform & lastlocalizationPose)
const;
116 virtual std::map<int, Transform> loadOptimizedPosesQuery(
Transform * lastlocalizationPose = 0)
const;
117 virtual void save2DMapQuery(
const cv::Mat & map,
float xMin,
float yMin,
float cellSize)
const;
118 virtual cv::Mat load2DMapQuery(
float & xMin,
float & yMin,
float & cellSize)
const;
119 virtual void saveOptimizedMeshQuery(
120 const cv::Mat & cloud,
121 const std::vector<std::vector<std::vector<RTABMAP_PCL_INDEX> > > & polygons,
122 #
if PCL_VERSION_COMPARE(>=, 1, 8, 0)
125 const std::vector<std::vector<Eigen::Vector2f> > & texCoords,
127 const cv::Mat & textures)
const;
128 virtual cv::Mat loadOptimizedMeshQuery(
129 std::vector<std::vector<std::vector<RTABMAP_PCL_INDEX> > > * polygons,
130 #
if PCL_VERSION_COMPARE(>=, 1, 8, 0)
133 std::vector<std::vector<Eigen::Vector2f> > * texCoords,
135 cv::Mat * textures)
const;
138 virtual void loadQuery(
VWDictionary * dictionary,
bool lastStateOnly =
true)
const;
139 virtual void loadLastNodesQuery(std::list<Signature *> & signatures)
const;
140 virtual void loadSignaturesQuery(
const std::list<int> & ids, std::list<Signature *> & signatures)
const;
141 virtual void loadWordsQuery(
const std::set<int> & wordIds, std::list<VisualWord *> & vws)
const;
144 virtual void loadNodeDataQuery(std::list<Signature *> & signatures,
bool images=
true,
bool scan=
true,
bool userData=
true,
bool occupancyGrid=
true)
const;
145 virtual bool getCalibrationQuery(
int signatureId, std::vector<CameraModel> & models, std::vector<StereoCameraModel> & stereoModels)
const;
146 virtual bool getLaserScanInfoQuery(
int signatureId,
LaserScan & info)
const;
147 virtual bool getNodeInfoQuery(
int signatureId,
Transform & pose,
int & mapId,
int & weight, std::string & label,
double & stamp,
Transform & groundTruthPose, std::vector<float> & velocity,
GPS & gps,
EnvSensors & sensors)
const;
148 virtual void getLastNodeIdsQuery(std::set<int> & ids)
const;
149 virtual void getAllNodeIdsQuery(std::set<int> & ids,
bool ignoreChildren,
bool ignoreBadSignatures,
bool ignoreIntermediateNodes)
const;
150 virtual void getAllLinksQuery(std::multimap<int, Link> & links,
bool ignoreNullLinks,
bool withLandmarks)
const;
151 virtual void getLastIdQuery(
const std::string & tableName,
int &
id,
const std::string & fieldName=
"id")
const;
152 virtual void getInvertedIndexNiQuery(
int signatureId,
int & ni)
const;
153 virtual void getNodesObservingLandmarkQuery(
int landmarkId, std::map<int, Link> & nodes)
const;
154 virtual void getNodeIdByLabelQuery(
const std::string & label,
int &
id)
const;
155 virtual void getAllLabelsQuery(std::map<int, std::string> & labels)
const;
158 std::string queryStepNode()
const;
159 std::string queryStepImage()
const;
160 std::string queryStepDepth()
const;
161 std::string queryStepCalibrationUpdate()
const;
162 std::string queryStepDepthUpdate()
const;
163 std::string queryStepScanUpdate()
const;
164 std::string queryStepSensorData()
const;
165 std::string queryStepLinkUpdate()
const;
166 std::string queryStepLink()
const;
167 std::string queryStepWordsChanged()
const;
168 std::string queryStepKeypoint()
const;
169 std::string queryStepGlobalDescriptor()
const;
170 std::string queryStepOccupancyGridUpdate()
const;
172 void stepImage(
sqlite3_stmt * ppStmt,
int id,
const cv::Mat & imageBytes)
const;
174 void stepCalibrationUpdate(
sqlite3_stmt * ppStmt,
int nodeId,
const std::vector<CameraModel> & models,
const std::vector<StereoCameraModel> & stereoModels)
const;
175 void stepDepthUpdate(
sqlite3_stmt * ppStmt,
int nodeId,
const cv::Mat & imageCompressed)
const;
179 void stepWordsChanged(
sqlite3_stmt * ppStmt,
int signatureId,
int oldWordId,
int newWordId)
const;
180 void stepKeypoint(
sqlite3_stmt * ppStmt,
int nodeID,
int wordId,
const cv::KeyPoint & kp,
const cv::Point3f & pt,
const cv::Mat &
descriptor)
const;
184 const cv::Mat & ground,
185 const cv::Mat & obstacles,
186 const cv::Mat &
empty,
188 const cv::Point3f & viewpoint)
const;
191 void loadLinksQuery(std::list<Signature *> & signatures)
const;
192 int loadOrSaveDb(
sqlite3 *pInMemory,
const std::string & fileName,
int isSave)
const;