/usr/include/visp/vpColVector.h is in libvisp-dev 2.8.0-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 | /****************************************************************************
*
* $Id: vpColVector.h 4056 2013-01-05 13:04:42Z fspindle $
*
* This file is part of the ViSP software.
* Copyright (C) 2005 - 2013 by INRIA. All rights reserved.
*
* This software is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* ("GPL") version 2 as published by the Free Software Foundation.
* See the file LICENSE.txt at the root directory of this source
* distribution for additional information about the GNU GPL.
*
* For using ViSP with software that can not be combined with the GNU
* GPL, please contact INRIA about acquiring a ViSP Professional
* Edition License.
*
* See http://www.irisa.fr/lagadic/visp/visp.html for more information.
*
* This software was developed at:
* INRIA Rennes - Bretagne Atlantique
* Campus Universitaire de Beaulieu
* 35042 Rennes Cedex
* France
* http://www.irisa.fr/lagadic
*
* If you have questions regarding the use of this file, please contact
* INRIA at visp@inria.fr
*
* This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
* WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
*
*
* Description:
* Provide some simple operation on column vectors.
*
* Authors:
* Eric Marchand
*
*****************************************************************************/
#ifndef vpColVector_H
#define vpColVector_H
#include <visp/vpMatrix.h>
#include <visp/vpRowVector.h>
#include <visp/vpMath.h>
class vpMatrix;
class vpRotationVector;
/*!
\file vpColVector.h
\brief definition of column vector class as well
as a set of operations on these vector
*/
/*!
\class vpColVector
\ingroup Matrix
\brief Class that provides a data structure for the column vectors
as well as a set of operations on these vectors.
the vpColVector is derived from vpMatrix.
\author Eric Marchand (Eric.Marchand@irisa.fr) Irisa / Inria Rennes
\warning Note the vector in the class (*this) will be noted A in the comment
*/
class VISP_EXPORT vpColVector : public vpMatrix
{
friend class vpMatrix;
protected:
vpColVector (vpMatrix &m, unsigned int j);
vpColVector (vpColVector &m, unsigned int r, unsigned int nrows) ;
public:
//! basic constructor
vpColVector() : vpMatrix() {};
//! constructor of vector of size n
vpColVector(unsigned int nn) : vpMatrix(nn,1){};
//! copy constructor
vpColVector (const vpColVector &v);
//! constructor initialize a vpColVector from a vpRotationVector
vpColVector (const vpRotationVector &v);
/*! Set the size of the column vector.
\param i : Column vector size.
\param flagNullify : If true, set the data to zero.
*/
void resize(const unsigned int i, const bool flagNullify = true)
{ vpMatrix::resize(i, 1, flagNullify); }
//! Access V[i] = x
inline double &operator [](unsigned int n) { return *(data + n); }
//! Access x = V[i]
inline const double &operator [](unsigned int n) const { return *(data+n); }
//! Copy operator. Allow operation such as A = v
vpColVector &operator=(const vpColVector &v);
//! Copy operator. Allow operation such as A = v
vpColVector &operator<<(const vpColVector &v);
//! Assigment operator. Allow operation such as A = *v
vpColVector &operator<<(double *);
//! copy from a matrix
vpColVector &operator=(const vpMatrix &m);
//! initialisation each element of the vector is x
vpColVector &operator=(double x);
//! operator addition of two vectors V = A+v
vpColVector operator+(const vpColVector &v) const;
//! operator substraction of two vectors V = A-v
vpColVector operator-(const vpColVector &v) const;
//! operator dot product
double operator*(const vpColVector &x) const;
//! operator dot product
vpMatrix operator*(const vpRowVector &x) const;
//! operator multiplication by a scalar V = A * x
vpColVector operator*(const double x) const;
//! operator A = -A
vpColVector operator-() ;
vpColVector rows(unsigned int first_row, unsigned int last_row)
{
return vpColVector(*this, first_row-1, last_row-first_row+1);
}
//! Reshape methods
void reshape(vpMatrix & m,
const unsigned int &nrows, const unsigned int &ncols);
vpMatrix reshape(const unsigned int &nrows, const unsigned int &ncols);
void stack(const double &b);
void stack(const vpColVector &B);
static vpColVector stack(const vpColVector &A, const vpColVector &B);
static void stack(const vpColVector &A, const vpColVector &B, vpColVector &C);
//! transpose of Vector
vpRowVector t() const;
//! normalise the vector
vpColVector &normalize() ;
//! normalise the vector
// vpColVector &normalize(vpColVector &x) const ;
//! compute the cross product of two vectors C = a x b
static vpColVector crossProd(const vpColVector &a, const vpColVector &b) ;
// compute the cross product of two vectors C = a x b
inline static vpColVector cross(const vpColVector &a, const vpColVector &b){
return crossProd(a,b);}
// compute the skew matrix [v]x
static vpMatrix skew(const vpColVector &v);
//! Dot Product
static double dotProd(const vpColVector &a, const vpColVector &b) ;
//! sort the elements of vector v
static vpColVector sort(const vpColVector &v) ;
//! reverse sorting of the elements of vector v
static vpColVector invSort(const vpColVector &v) ;
//! compute the median
static double median(const vpColVector &v) ;
//! compute the mean
static double mean(const vpColVector &v) ;
/*!
Convert a column vector containing angles in radians into
degrees.
*/
inline void rad2deg() {
double rad2deg = 180.0/M_PI;
for (unsigned int i=0; i < rowNum; i++)
(*this)[i] *= rad2deg;
}
/*!
Convert a column vector containing angles in degrees into radians.
*/
inline void deg2rad() {
double deg2rad = M_PI/180.0;
for (unsigned int i=0; i < rowNum; i++)
(*this)[i] *= deg2rad;
}
/*!
Return the size of the vector in term of number of rows.
*/
inline unsigned int size() const
{
return getRows();
}
};
#endif
/*
* Local variables:
* c-basic-offset: 2
* End:
*/
|