/******************************************************************** ** Image Component Library (ICL) ** ** ** ** Copyright (C) 2006-2013 CITEC, University of Bielefeld ** ** Neuroinformatics Group ** ** Website: www.iclcv.org and ** ** http://opensource.cit-ec.de/projects/icl ** ** ** ** File : ICLMarkers/src/ICLMarkers/MultiCamFiducialImpl.cpp ** ** Module : ICLMarkers ** ** Authors: Christof Elbrechter ** ** ** ** ** ** GNU LESSER GENERAL PUBLIC LICENSE ** ** This file may be used under the terms of the GNU Lesser General ** ** Public License version 3.0 as published by the ** ** ** ** Free Software Foundation and appearing in the file LICENSE.LGPL ** ** included in the packaging of this file. Please review the ** ** following information to ensure the license requirements will ** ** be met: http://www.gnu.org/licenses/lgpl-3.0.txt ** ** ** ** The development of this software was supported by the ** ** Excellence Cluster EXC 277 Cognitive Interaction Technology. ** ** The Excellence Cluster EXC 277 is a grant of the Deutsche ** ** Forschungsgemeinschaft (DFG) in the context of the German ** ** Excellence Initiative. ** ** ** ********************************************************************/ #include #include using namespace icl::utils; using namespace icl::math; using namespace icl::core; using namespace icl::geom; namespace icl{ namespace markers{ MultiCamFiducialImpl::MultiCamFiducialImpl(){} MultiCamFiducialImpl::MultiCamFiducialImpl(int id, const std::vector &fids, const std::vector cams):id(id),numFound(0), fids(fids),cams(cams), haveCenter(false), haveOrientation(false), havePose(false){} void MultiCamFiducialImpl::init(int id){ this->numFound = 0; this->id = id; this->fids.clear(); this->cams.clear(); this->haveCenter = this->haveOrientation = this->havePose = false; } const FixedColVector &MultiCamFiducialImpl::estimateCenter3D(){ if(haveCenter) return center; if(numFound == 1){ center = fids[0].getCenter3D().part<0,0,1,3>(); }else{ std::vector centerPoints(numFound); for(int i=0;i(); } haveCenter = true; return center; } const Mat &MultiCamFiducialImpl::estimatePose3D(){ if(havePose) return pose; if(numFound == 1){ pose = fids[0].getPose3D(); }else{ int n = fids[0].getKeyPoints2D().size(); // assumtion keypoints are ordered and identical ... DynMatrix W(n,3),O(n,3); for(int i=0;i pI(numFound); for(int j=0;j(pose(3,0), pose(3,1), pose(3,2)); haveCenter = true; return pose; } const FixedColVector &MultiCamFiducialImpl::estimateOrientation3D(){ if(haveOrientation) return orientation; estimatePose3D(); orientation = extract_euler_angles(pose); haveOrientation = true; return orientation; } } // namespace markers }