utm_transformer.h
Go to the documentation of this file.
1 // *****************************************************************************
2 //
3 // Copyright (c) 2014, Southwest Research Institute® (SwRI®)
4 // All rights reserved.
5 //
6 // Redistribution and use in source and binary forms, with or without
7 // modification, are permitted provided that the following conditions are met:
8 // * Redistributions of source code must retain the above copyright
9 // notice, this list of conditions and the following disclaimer.
10 // * Redistributions in binary form must reproduce the above copyright
11 // notice, this list of conditions and the following disclaimer in the
12 // documentation and/or other materials provided with the distribution.
13 // * Neither the name of Southwest Research Institute® (SwRI®) nor the
14 // names of its contributors may be used to endorse or promote products
15 // derived from this software without specific prior written permission.
16 //
17 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 // ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
21 // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24 // ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
26 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 //
28 // *****************************************************************************
29 
30 #ifndef TRANSFORM_UTIL_UTM_TRANSFORMER_H_
31 #define TRANSFORM_UTIL_UTM_TRANSFORMER_H_
32 
33 #include <map>
34 #include <string>
35 #include <vector>
36 
37 #include <boost/shared_ptr.hpp>
38 
39 #include <tf/transform_datatypes.h>
40 #include <tf/transform_listener.h>
41 
45 
46 namespace swri_transform_util
47 {
51  class UtmTransformer : public Transformer
52  {
53  public:
55 
62  virtual std::map<std::string, std::vector<std::string> > Supports() const;
63 
64 
80  virtual bool GetTransform(
81  const std::string& target_frame,
82  const std::string& source_frame,
83  const ros::Time& time,
84  Transform& transform);
85 
86  protected:
87  virtual bool Initialize();
88 
90 
91  int32_t utm_zone_;
92  char utm_band_;
93  std::string local_xy_frame_;
94  };
95 
96 
104  {
105  public:
107  const tf::StampedTransform& transform,
110  int32_t utm_zone,
111  char utm_band);
112 
113  virtual void Transform(const tf::Vector3& v_in, tf::Vector3& v_out) const;
114 
115  virtual tf::Quaternion GetOrientation() const;
116  virtual TransformImplPtr Inverse() const;
117 
118  protected:
122  int32_t utm_zone_;
123  char utm_band_;
124  };
125 
126 
134  {
135  public:
137  const tf::StampedTransform& transform,
140  int32_t utm_zone,
141  char utm_band);
142 
143  virtual void Transform(const tf::Vector3& v_in, tf::Vector3& v_out) const;
144 
145  virtual tf::Quaternion GetOrientation() const;
146  virtual TransformImplPtr Inverse() const;
147 
148  protected:
152  int32_t utm_zone_;
153  char utm_band_;
154  };
155 
156 
164  {
165  public:
168  int32_t utm_zone,
169  char utm_band);
170 
171  virtual void Transform(const tf::Vector3& v_in, tf::Vector3& v_out) const;
172  virtual TransformImplPtr Inverse() const;
173 
174  protected:
176  int32_t utm_zone_;
177  char utm_band_;
178  };
179 
187  {
188  public:
189  explicit Wgs84ToUtmTransform(
191  int32_t utm_zone,
192  char utm_band);
193 
194  virtual void Transform(const tf::Vector3& v_in, tf::Vector3& v_out) const;
195  virtual TransformImplPtr Inverse() const;
196 
197  protected:
199  int32_t utm_zone_;
200  char utm_band_;
201  };
202 }
203 
204 #endif // TRANSFORM_UTIL_UTM_TRANSFORMER_H_
swri_transform_util::UtmToWgs84Transform
Class to implement transformation from UTM to WGS84.
Definition: utm_transformer.h:163
swri_transform_util::TfToUtmTransform::GetOrientation
virtual tf::Quaternion GetOrientation() const
Get the orientation of this transform.
transformer.h
swri_transform_util::UtmTransformer::utm_zone_
int32_t utm_zone_
Definition: utm_transformer.h:91
swri_transform_util::Wgs84ToUtmTransform::Transform
virtual void Transform(const tf::Vector3 &v_in, tf::Vector3 &v_out) const
Apply this transform to a 3D vector.
boost::shared_ptr
swri_transform_util::Wgs84ToUtmTransform::utm_band_
char utm_band_
Definition: utm_transformer.h:200
swri_transform_util::UtmTransformer::Initialize
virtual bool Initialize()
swri_transform_util::Wgs84ToUtmTransform::utm_util_
boost::shared_ptr< UtmUtil > utm_util_
Definition: utm_transformer.h:198
swri_transform_util::TransformImpl
Base class for Transform implementations.
Definition: transform.h:49
swri_transform_util::Wgs84ToUtmTransform::Inverse
virtual TransformImplPtr Inverse() const
swri_transform_util::UtmTransformer
Instantiation of Transformer to handle transforms to/from UTM.
Definition: utm_transformer.h:51
swri_transform_util::UtmToTfTransform::utm_util_
boost::shared_ptr< UtmUtil > utm_util_
Definition: utm_transformer.h:120
swri_transform_util::TfToUtmTransform::local_xy_util_
boost::shared_ptr< LocalXyWgs84Util > local_xy_util_
Definition: utm_transformer.h:151
swri_transform_util::UtmToTfTransform::UtmToTfTransform
UtmToTfTransform(const tf::StampedTransform &transform, boost::shared_ptr< UtmUtil > utm_util, boost::shared_ptr< LocalXyWgs84Util > local_xy_util, int32_t utm_zone, char utm_band)
swri_transform_util::UtmToWgs84Transform::Inverse
virtual TransformImplPtr Inverse() const
swri_transform_util::UtmToWgs84Transform::utm_util_
boost::shared_ptr< UtmUtil > utm_util_
Definition: utm_transformer.h:175
swri_transform_util::TfToUtmTransform::TfToUtmTransform
TfToUtmTransform(const tf::StampedTransform &transform, boost::shared_ptr< UtmUtil > utm_util, boost::shared_ptr< LocalXyWgs84Util > local_xy_util, int32_t utm_zone, char utm_band)
swri_transform_util::UtmToTfTransform::Transform
virtual void Transform(const tf::Vector3 &v_in, tf::Vector3 &v_out) const
Apply this transform to a 3D vector.
swri_transform_util::UtmTransformer::local_xy_frame_
std::string local_xy_frame_
Definition: utm_transformer.h:93
tf::StampedTransform
swri_transform_util::UtmTransformer::utm_util_
boost::shared_ptr< UtmUtil > utm_util_
Definition: utm_transformer.h:89
swri_transform_util::UtmTransformer::UtmTransformer
UtmTransformer()
swri_transform_util::UtmTransformer::GetTransform
virtual bool GetTransform(const std::string &target_frame, const std::string &source_frame, const ros::Time &time, Transform &transform)
Get a Transform from a non-UTM frame to UTM or vice-versa.
local_xy_util.h
swri_transform_util::TfToUtmTransform::utm_zone_
int32_t utm_zone_
Definition: utm_transformer.h:152
swri_transform_util::UtmTransformer::Supports
virtual std::map< std::string, std::vector< std::string > > Supports() const
Get a map of the transforms supported by this Transformer.
swri_transform_util::UtmTransformer::utm_band_
char utm_band_
Definition: utm_transformer.h:92
swri_transform_util
Definition: earth_constants.h:33
swri_transform_util::UtmToTfTransform::utm_zone_
int32_t utm_zone_
Definition: utm_transformer.h:122
swri_transform_util::TfToUtmTransform::Inverse
virtual TransformImplPtr Inverse() const
utm_util.h
swri_transform_util::Transform
An abstraction of the tf::Transform class to support transforms in addition to the rigid transforms s...
Definition: transform.h:105
swri_transform_util::UtmToTfTransform::transform_
tf::StampedTransform transform_
Definition: utm_transformer.h:119
swri_transform_util::UtmToTfTransform::Inverse
virtual TransformImplPtr Inverse() const
swri_transform_util::UtmToTfTransform::utm_band_
char utm_band_
Definition: utm_transformer.h:123
swri_transform_util::TfToUtmTransform::utm_util_
boost::shared_ptr< UtmUtil > utm_util_
Definition: utm_transformer.h:150
transform_listener.h
swri_transform_util::UtmToWgs84Transform::Transform
virtual void Transform(const tf::Vector3 &v_in, tf::Vector3 &v_out) const
Apply this transform to a 3D vector.
swri_transform_util::UtmToTfTransform::local_xy_util_
boost::shared_ptr< LocalXyWgs84Util > local_xy_util_
Definition: utm_transformer.h:121
transform_datatypes.h
ros::Time
swri_transform_util::UtmToWgs84Transform::utm_band_
char utm_band_
Definition: utm_transformer.h:177
swri_transform_util::TfToUtmTransform::Transform
virtual void Transform(const tf::Vector3 &v_in, tf::Vector3 &v_out) const
Apply this transform to a 3D vector.
swri_transform_util::Wgs84ToUtmTransform
Class to implement transformation from WGS84 to UTM.
Definition: utm_transformer.h:186
swri_transform_util::Wgs84ToUtmTransform::utm_zone_
int32_t utm_zone_
Definition: utm_transformer.h:199
swri_transform_util::UtmToWgs84Transform::UtmToWgs84Transform
UtmToWgs84Transform(boost::shared_ptr< UtmUtil > utm_util, int32_t utm_zone, char utm_band)
swri_transform_util::TfToUtmTransform::utm_band_
char utm_band_
Definition: utm_transformer.h:153
swri_transform_util::Wgs84ToUtmTransform::Wgs84ToUtmTransform
Wgs84ToUtmTransform(boost::shared_ptr< UtmUtil > utm_util, int32_t utm_zone, char utm_band)
swri_transform_util::TfToUtmTransform
Class to implement transformation from TF to UTM.
Definition: utm_transformer.h:133
swri_transform_util::UtmToTfTransform
Class to implement transformation from UTM to TF.
Definition: utm_transformer.h:103
tf::Quaternion
swri_transform_util::TfToUtmTransform::transform_
tf::StampedTransform transform_
Definition: utm_transformer.h:149
swri_transform_util::UtmToWgs84Transform::utm_zone_
int32_t utm_zone_
Definition: utm_transformer.h:176
swri_transform_util::Transformer
A base class for transformers.
Definition: transformer.h:53
swri_transform_util::UtmToTfTransform::GetOrientation
virtual tf::Quaternion GetOrientation() const
Get the orientation of this transform.


swri_transform_util
Author(s): Marc Alban
autogenerated on Tue Oct 3 2023 02:32:38