measmodel_pos.cpp
Go to the documentation of this file.
1 /*********************************************************************
2 * Software License Agreement (BSD License)
3 *
4 * Copyright (c) 2008, Willow Garage, Inc.
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 *
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * * Redistributions in binary form must reproduce the above
14 * copyright notice, this list of conditions and the following
15 * disclaimer in the documentation and/or other materials provided
16 * with the distribution.
17 * * Neither the name of the Willow Garage nor the names of its
18 * contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 * POSSIBILITY OF SUCH DAMAGE.
33 *********************************************************************/
34 
35 /* Author: Wim Meeussen */
36 
38 
39 using namespace std;
40 using namespace BFL;
41 using namespace tf;
42 
43 
44 static const unsigned int NUM_MEASMODEL_POS_COND_ARGS = 1;
45 static const unsigned int DIM_MEASMODEL_POS = 13;
46 
47 
48 
49 // Constructor
50 MeasPdfPos::MeasPdfPos(const Vector3& sigma)
52  meas_noise_(Vector3(0, 0, 0), sigma)
53 {}
54 
55 
56 // Destructor
58 {}
59 
60 
61 
62 Probability
63 MeasPdfPos::ProbabilityGet(const Vector3& measurement) const
64 {
65  return meas_noise_.ProbabilityGet(measurement - ConditionalArgumentGet(0).pos_);
66 }
67 
68 
69 
70 bool
71 MeasPdfPos::SampleFrom(Sample<Vector3>& one_sample, int method, void *args) const
72 {
73  cerr << "MeasPdfPos::SampleFrom Method not applicable" << endl;
74  assert(0);
75  return false;
76 }
77 
78 
79 
80 
81 Vector3
83 {
84  cerr << "MeasPdfPos::ExpectedValueGet Method not applicable" << endl;
85  Vector3 result;
86  assert(0);
87  return result;
88 }
89 
90 
91 
92 
93 SymmetricMatrix
95 {
96  cerr << "MeasPdfPos::CovarianceGet Method not applicable" << endl;
97  SymmetricMatrix Covar(DIM_MEASMODEL_POS);
98  assert(0);
99  return Covar;
100 }
101 
102 
103 void
104 MeasPdfPos::CovarianceSet(const MatrixWrapper::SymmetricMatrix& cov)
105 {
106  tf::Vector3 cov_vec(sqrt(cov(1, 1)), sqrt(cov(2, 2)), sqrt(cov(3, 3)));
107  meas_noise_.sigmaSet(cov_vec);
108 }
109 
110 
111 
void sigmaSet(const tf::Vector3 &sigma)
Class representing state with pos and vel.
Definition: state_pos_vel.h:46
virtual Probability ProbabilityGet(const tf::Vector3 &input) const
GaussianVector meas_noise_
Definition: measmodel_pos.h:72
void CovarianceSet(const MatrixWrapper::SymmetricMatrix &cov)
virtual MatrixWrapper::SymmetricMatrix CovarianceGet() const
virtual tf::Vector3 ExpectedValueGet() const
static const unsigned int NUM_MEASMODEL_POS_COND_ARGS
static const unsigned int DIM_MEASMODEL_POS
virtual ~MeasPdfPos()
Destructor.
virtual BFL::Probability ProbabilityGet(const tf::Vector3 &input) const
virtual bool SampleFrom(BFL::Sample< tf::Vector3 > &one_sample, int method, void *args) const


people_tracking_filter
Author(s): Caroline Pantofaru
autogenerated on Fri Jun 7 2019 22:07:49