Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F99240834
svector.h
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Wed, Jan 22, 16:54
Size
3 KB
Mime Type
text/x-c++
Expires
Fri, Jan 24, 16:54 (2 d)
Engine
blob
Format
Raw Data
Handle
23749070
Attached To
rSYMKIT symkit
svector.h
View Options
#ifndef __STATIC_VECTOR_H__
#define __STATIC_VECTOR_H__
#include <array>
template<std::size_t N>
class SVector
{
public:
typedef std::size_t size_t;
/* Constructors */
SVector(const double &value = 0);
SVector(const std::initializer_list<double> &init);
SVector(const SVector& init);
/* For auto implementation */
/* it allows to loop through components
*
* for (auto comp : v)
* {
* // loop content
* }
*/
typedef typename std::array<double, N>::iterator iterator;
typedef typename std::array<double, N>::const_iterator const_iterator;
iterator begin();
iterator end();
const_iterator begin() const;
const_iterator end() const;
/*
* Reduce to module = 1
*/
SVector& unit();
/* Set the module to a specific value keeping the direction */
SVector& normalize(const double &value);
/* Same as unit, be it returns another vector */
SVector directional() const;
/* Returns the dimension, in this case it is fixed */
size_t size() const;
/* Access operators */
double& operator[](size_t i);
const double& operator[](size_t i) const;
/* Comparison operators */
bool operator==(const SVector& v) const;
bool operator!=(const SVector& v) const;
/* Implicit module comparison operators */
bool operator<=(const SVector& v) const;
bool operator>=(const SVector& v) const;
bool operator<=(double) const;
bool operator>=(double) const;
bool operator<(const SVector& v) const;
bool operator>(const SVector& v) const;
bool operator<(double) const;
bool operator>(double) const;
/* Plus / minus operators */
SVector& operator+=(const SVector& v);
SVector& operator-=(const SVector& v);
/* Scalar multiplication / division */
SVector& operator*=(double k);
SVector& operator/=(double k);
/* Dot product */
double operator*(const SVector& v) const;
SVector& operator~(); // inversion without copy
/* Return the module */
double module() const;
/* Squared module */
double sq_module() const;
/* reset the vector to null vector */
SVector& null();
/* obtain array raw data */
double * rawdata();
const double * rawdata() const;
/* null vector constant */
static const SVector nullv;
private:
std::array<double, N> components;
};
/*
* External operators overloading
*/
/*
* Sum or subtraction
*/
template<std::size_t N>
const SVector<N> operator+(SVector<N> v, const SVector<N>& w);
template<std::size_t N>
const SVector<N> operator-(SVector<N> v, const SVector<N>& w);
/*
* Scalar multiplication
*/
template<std::size_t N>
const SVector<N> operator*(SVector<N> v, double k);
template<std::size_t N>
const SVector<N> operator/(SVector<N> v, double k);
template<std::size_t N>
const SVector<N> operator*(double k, SVector<N> v);
template<std::size_t N>
const SVector<N> operator/(double k, SVector<N> v);
/*
* Inversion operator
*/
template<std::size_t N>
const SVector<N> operator-(SVector<N> v);
/*
* Prototipe for cross product
* Implementation in "vector.cpp"
*/
const SVector<3> operator^(const SVector<3>& v, const SVector<3>& w);
/*
* Macro of use of vectors
* Useful in some qt functions for the opengl
*/
#define ARRAY_3D_FLOAT_ARGS(v) (float)v[0], (float)v[1], (float)v[2]
/*
* Output stream << operator overloading
* Define this macro before including svector.h if you want
* to use this function.
*
* For example:
*
* #define _USE_SVECTOR_OSTREAM
* #include "svector.h"
*
*/
#ifdef _USE_SVECTOR_OSTREAM
#include <ostream>
template <std::size_t N>
std::ostream& operator<<(std::ostream& os, const SVector<N> &v);
#endif
/*
* Include definitions file
*/
#define __SVECTOR_CPP__
#include "svector.tpp"
#undef __SVECTOR_CPP__
#endif // __SVECTOR_H__
Event Timeline
Log In to Comment