filter_utilities.cpp
Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2015, Charles River Analytics, Inc.
00003  * All rights reserved.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  *
00009  * 1. Redistributions of source code must retain the above copyright
00010  * notice, this list of conditions and the following disclaimer.
00011  * 2. Redistributions in binary form must reproduce the above
00012  * copyright notice, this list of conditions and the following
00013  * disclaimer in the documentation and/or other materials provided
00014  * with the distribution.
00015  * 3. Neither the name of the copyright holder nor the names of its
00016  * contributors may be used to endorse or promote products derived
00017  * from this software without specific prior written permission.
00018  *
00019  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00020  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00021  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00022  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00023  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00024  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00025  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00026  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00027  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00028  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00029  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00030  * POSSIBILITY OF SUCH DAMAGE.
00031  */
00032 
00033 #include "robot_localization/filter_utilities.h"
00034 #include "robot_localization/filter_common.h"
00035 
00036 std::ostream& operator<<(std::ostream& os, const Eigen::MatrixXd &mat)
00037 {
00038   os << "[";
00039 
00040   int rowCount = static_cast<int>(mat.rows());
00041 
00042   for (int row = 0; row < rowCount; ++row)
00043   {
00044     if (row > 0)
00045     {
00046       os << " ";
00047     }
00048 
00049     for (int col = 0; col < mat.cols(); ++col)
00050     {
00051       os << std::setiosflags(std::ios::left) << std::setw(12) << std::setprecision(5) << mat(row, col);
00052     }
00053 
00054     if (row < rowCount - 1)
00055     {
00056       os << "\n";
00057     }
00058   }
00059 
00060   os << "]\n";
00061 
00062   return os;
00063 }
00064 
00065 std::ostream& operator<<(std::ostream& os, const Eigen::VectorXd &vec)
00066 {
00067   os << "[";
00068   for (int dim = 0; dim < vec.rows(); ++dim)
00069   {
00070     os << std::setiosflags(std::ios::left) << std::setw(12) << std::setprecision(5) << vec(dim);
00071   }
00072   os << "]\n";
00073 
00074   return os;
00075 }
00076 
00077 std::ostream& operator<<(std::ostream& os, const std::vector<size_t> &vec)
00078 {
00079   os << "[";
00080   for (size_t dim = 0; dim < vec.size(); ++dim)
00081   {
00082     os << std::setiosflags(std::ios::left) << std::setw(12) << std::setprecision(5) << vec[dim];
00083   }
00084   os << "]\n";
00085 
00086   return os;
00087 }
00088 
00089 std::ostream& operator<<(std::ostream& os, const std::vector<int> &vec)
00090 {
00091   os << "[";
00092   for (size_t dim = 0; dim < vec.size(); ++dim)
00093   {
00094     os << std::setiosflags(std::ios::left) << std::setw(3) << (vec[dim] ? "t" : "f");
00095   }
00096   os << "]\n";
00097 
00098   return os;
00099 }
00100 
00101 namespace RobotLocalization
00102 {
00103   namespace FilterUtilities
00104   {
00105     double clampRotation(double rotation)
00106     {
00107       while(rotation > PI)
00108       {
00109         rotation -= TAU;
00110       }
00111 
00112       while(rotation < -PI)
00113       {
00114         rotation += TAU;
00115       }
00116 
00117       return rotation;
00118     }
00119   }
00120 }


robot_localization
Author(s): Tom Moore
autogenerated on Fri Aug 28 2015 12:26:20