MultiMarkerFiltered.h
Go to the documentation of this file.
1 /*
2  * This file is part of ALVAR, A Library for Virtual and Augmented Reality.
3  *
4  * Copyright 2007-2012 VTT Technical Research Centre of Finland
5  *
6  * Contact: VTT Augmented Reality Team <alvar.info@vtt.fi>
7  * <http://www.vtt.fi/multimedia/alvar.html>
8  *
9  * ALVAR is free software; you can redistribute it and/or modify it under the
10  * terms of the GNU Lesser General Public License as published by the Free
11  * Software Foundation; either version 2.1 of the License, or (at your option)
12  * any later version.
13  *
14  * This library is distributed in the hope that it will be useful, but WITHOUT
15  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
16  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
17  * for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public License
20  * along with ALVAR; if not, see
21  * <http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html>.
22  */
23 
24 #ifndef MULTIMARKERFILTERED_H
25 #define MULTIMARKERFILTERED_H
26 
34 #include "MultiMarker.h"
35 
36 namespace alvar {
37 
46 {
47 protected:
48  static const int filter_buffer_max=15;
50 
51  double _Update(MarkerIterator &begin, MarkerIterator &end,
52  Camera* cam, Pose& pose, IplImage* image);
53 
54 public:
58  MultiMarkerFiltered(std::vector<int>& indices);
59 
62 
68  void PointCloudAverage(int marker_id, double edge_length, Pose &pose);
69 
76  template <class M>
77  double Update(const std::vector<M>* markers, Camera* cam, Pose& pose, IplImage* image = 0)
78  {
79  if(markers->size() < 1) return false;
80  MarkerIteratorImpl<M> begin(markers->begin());
81  MarkerIteratorImpl<M> end(markers->end());
82  return _Update(begin, end,
83  cam, pose, image);
84  }
85 
90  pointcloud_filtered->reset();
91  }
92 };
93 
94 } // namespace alvar
95 
96 #endif
Main ALVAR namespace.
Definition: Alvar.h:174
double Update(const std::vector< M > *markers, Camera *cam, Pose &pose, IplImage *image=0)
Updates the marker field and camera pose.
unsigned char * image
Definition: GlutViewer.cpp:155
Base class for using MultiMarker.
Definition: MultiMarker.h:47
Simple Camera class for calculating distortions, orientation or projections with pre-calibrated camer...
Definition: Camera.h:82
virtual void reset()
Reset the filter state.
Definition: Filter.cpp:63
Multi marker that is constructed by first calculating the marker poses directly relative to base mark...
Pose representation derived from the Rotation class
Definition: Pose.h:50
Iterator type for traversing templated Marker vector without the template.
Definition: Marker.h:277
#define ALVAR_EXPORT
Definition: Alvar.h:168
FilterMedian provides an median filter
Definition: Filter.h:133
This file implements a multi-marker.
Iterator implementation for traversing templated Marker vector without the template.
Definition: Marker.h:294
Camera * cam
void MeasurementsReset()
Reset the measurements.


ar_track_alvar
Author(s): Scott Niekum
autogenerated on Mon Jun 10 2019 12:47:04