Multi marker that uses bundle adjustment to refine the 3D positions of the markers (point cloud).
More...
|
double | GetOptimizationError () |
|
int | GetOptimizationKeyframes () |
|
int | GetOptimizationMarkers () |
|
bool | GetOptimizing () |
|
template<class M > |
void | MeasurementsAdd (const std::vector< M, Eigen::aligned_allocator< M > > *markers, const Pose &camera_pose) |
| Adds new measurements that are used in bundle adjustment. More...
|
|
void | MeasurementsReset () |
| Resets the measurements and camera poses that are stored for bundle adjustment. If something goes from in optimization one will call this and acquire new measurements. More...
|
|
| MultiMarkerBundle (std::vector< int > &indices) |
| Constructor. More...
|
|
bool | Optimize (Camera *_cam, double stop, int max_iter, Optimization::OptimizeMethod method=Optimization::TUKEY_LM) |
| Runs the bundle adjustment optimization. More...
|
|
| ~MultiMarkerBundle () |
|
double | _GetPose (MarkerIterator &begin, MarkerIterator &end, Camera *cam, Pose &pose, IplImage *image) |
|
int | _SetTrackMarkers (MarkerDetectorImpl &marker_detector, Camera *cam, Pose &pose, IplImage *image) |
|
int | get_id_index (int id, bool add_if_missing=false) |
|
std::vector< int > | getIndices () |
|
int | getMasterId () |
|
template<class M > |
double | GetPose (const std::vector< M, Eigen::aligned_allocator< M > > *markers, Camera *cam, Pose &pose, IplImage *image=0) |
| Calculates the pose of the camera from multi marker. Method uses the true 3D coordinates of markers to get the initial pose and then optimizes it by minimizing the reprojection error. More...
|
|
bool | IsValidMarker (int marker_id) |
| Returns true if the marker is in the point cloud. More...
|
|
bool | Load (const char *fname, FILE_FORMAT format=FILE_FORMAT_DEFAULT) |
| Loads multi marker configuration from a text file. More...
|
|
| MultiMarker (std::vector< int > &indices) |
| Constructor. More...
|
|
| MultiMarker () |
| Default constructor. More...
|
|
int | pointcloud_index (int marker_id, int marker_corner, bool add_if_missing=false) |
|
void | PointCloudAdd (int marker_id, double edge_length, Pose &pose) |
| Adds marker corners to 3D point cloud of multi marker. More...
|
|
void | PointCloudCopy (const MultiMarker *m) |
| Copies the 3D point cloud from other multi marker object. More...
|
|
void | PointCloudCorners3d (double edge_length, Pose &pose, CvPoint3D64f corners[4]) |
| Calculates 3D coordinates of marker corners relative to given pose (camera). More...
|
|
void | PointCloudGet (int marker_id, int point, double &x, double &y, double &z) |
| Returns 3D co-ordinates of one corner point of a marker. More...
|
|
bool | PointCloudIsEmpty () |
| Returns true if the are not points in the 3D opint cloud. More...
|
|
void | PointCloudReset () |
| Reserts the 3D point cloud of the markers. More...
|
|
virtual void | Reset () |
| Resets the multi marker. More...
|
|
bool | Save (const char *fname, FILE_FORMAT format=FILE_FORMAT_DEFAULT) |
| Saves multi marker configuration to a text file. More...
|
|
template<class M > |
int | SetTrackMarkers (MarkerDetector< M > &marker_detector, Camera *cam, Pose &pose, IplImage *image=0) |
| Set new markers to be tracked for MarkerDetector Sometimes the MultiMarker implementation knows more about marker locations compared to MarkerDetector . Then this method can be used to reset the internal state of MarkerDetector for tracking also these markers. More...
|
|
size_t | Size () |
| Return the number of markers added using PointCloudAdd. More...
|
|
template<class M > |
double | Update (const std::vector< M, Eigen::aligned_allocator< M > > *markers, Camera *cam, Pose &pose, IplImage *image=0) |
| Calls GetPose to obtain camera pose. More...
|
|
Multi marker that uses bundle adjustment to refine the 3D positions of the markers (point cloud).
This can be initialized by using e.g. MultiMarkerAverage class.
- Examples:
- SampleMultiMarkerBundle.cpp.
Definition at line 45 of file MultiMarkerBundle.h.