28 #ifndef DBDRIVERSQLITE3_H_ 29 #define DBDRIVERSQLITE3_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 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 updateDepthImageQuery(
101 const cv::Mat & image)
const;
103 virtual void addStatisticsQuery(
const Statistics & statistics)
const;
104 virtual void savePreviewImageQuery(
const cv::Mat & image)
const;
105 virtual cv::Mat loadPreviewImageQuery()
const;
106 virtual void saveOptimizedPosesQuery(
const std::map<int, Transform> & optimizedPoses,
const Transform & lastlocalizationPose)
const;
107 virtual std::map<int, Transform> loadOptimizedPosesQuery(
Transform * lastlocalizationPose)
const;
108 virtual void save2DMapQuery(
const cv::Mat & map,
float xMin,
float yMin,
float cellSize)
const;
109 virtual cv::Mat load2DMapQuery(
float & xMin,
float & yMin,
float & cellSize)
const;
110 virtual void saveOptimizedMeshQuery(
111 const cv::Mat & cloud,
112 const std::vector<std::vector<std::vector<unsigned int> > > & polygons,
113 #
if PCL_VERSION_COMPARE(>=, 1, 8, 0)
114 const std::vector<std::vector<Eigen::Vector2f, Eigen::aligned_allocator<Eigen::Vector2f> > > & texCoords,
116 const std::vector<std::vector<Eigen::Vector2f> > & texCoords,
118 const cv::Mat & textures)
const;
119 virtual cv::Mat loadOptimizedMeshQuery(
120 std::vector<std::vector<std::vector<unsigned int> > > * polygons,
121 #
if PCL_VERSION_COMPARE(>=, 1, 8, 0)
122 std::vector<std::vector<Eigen::Vector2f, Eigen::aligned_allocator<Eigen::Vector2f> > > * texCoords,
124 std::vector<std::vector<Eigen::Vector2f> > * texCoords,
126 cv::Mat * textures)
const;
129 virtual void loadQuery(
VWDictionary * dictionary,
bool lastStateOnly =
true)
const;
130 virtual void loadLastNodesQuery(std::list<Signature *> & signatures)
const;
131 virtual void loadSignaturesQuery(
const std::list<int> & ids, std::list<Signature *> & signatures)
const;
132 virtual void loadWordsQuery(
const std::set<int> & wordIds, std::list<VisualWord *> & vws)
const;
133 virtual void loadLinksQuery(
int signatureId, std::map<int, Link> & links,
Link::Type type =
Link::kUndef)
const;
135 virtual void loadNodeDataQuery(std::list<Signature *> & signatures,
bool images=
true,
bool scan=
true,
bool userData=
true,
bool occupancyGrid=
true)
const;
136 virtual bool getCalibrationQuery(
int signatureId, std::vector<CameraModel> & models,
StereoCameraModel & stereoModel)
const;
137 virtual bool getLaserScanInfoQuery(
int signatureId,
LaserScan & info)
const;
138 virtual bool getNodeInfoQuery(
int signatureId,
Transform & pose,
int & mapId,
int & weight, std::string & label,
double & stamp,
Transform & groundTruthPose, std::vector<float> & velocity,
GPS & gps)
const;
139 virtual void getAllNodeIdsQuery(std::set<int> & ids,
bool ignoreChildren,
bool ignoreBadSignatures)
const;
140 virtual void getAllLinksQuery(std::multimap<int, Link> & links,
bool ignoreNullLinks)
const;
141 virtual void getLastIdQuery(
const std::string & tableName,
int &
id)
const;
142 virtual void getInvertedIndexNiQuery(
int signatureId,
int & ni)
const;
143 virtual void getNodeIdByLabelQuery(
const std::string & label,
int &
id)
const;
144 virtual void getAllLabelsQuery(std::map<int, std::string> & labels)
const;
147 std::string queryStepNode()
const;
148 std::string queryStepImage()
const;
149 std::string queryStepDepth()
const;
150 std::string queryStepDepthUpdate()
const;
151 std::string queryStepSensorData()
const;
152 std::string queryStepLinkUpdate()
const;
153 std::string queryStepLink()
const;
154 std::string queryStepWordsChanged()
const;
155 std::string queryStepKeypoint()
const;
156 std::string queryStepOccupancyGridUpdate()
const;
161 const cv::Mat & imageBytes)
const;
163 void stepDepthUpdate(
sqlite3_stmt * ppStmt,
int nodeId,
const cv::Mat & imageCompressed)
const;
166 void stepWordsChanged(
sqlite3_stmt * ppStmt,
int signatureId,
int oldWordId,
int newWordId)
const;
167 void stepKeypoint(
sqlite3_stmt * ppStmt,
int signatureId,
int wordId,
const cv::KeyPoint & kp,
const cv::Point3f & pt,
const cv::Mat & descriptor)
const;
170 const cv::Mat & ground,
171 const cv::Mat & obstacles,
172 const cv::Mat & empty,
174 const cv::Point3f & viewpoint)
const;
177 void loadLinksQuery(std::list<Signature *> & signatures)
const;
178 int loadOrSaveDb(
sqlite3 *pInMemory,
const std::string & fileName,
int isSave)
const;
struct sqlite3_stmt sqlite3_stmt
std::map< std::string, std::string > ParametersMap
virtual bool isInMemory() const