RBComb Simulation Framework
This project aims at developing a framework that can be used to simulate any project that is to be undertaken on the RBComb platform. It is designed in modular fashion, such that it is flexible enough to adapt easily to any given situation.
Structure
The code is structured in an object oriented approach. The classes that likely will
not need to be adapted for a new situation are found in the lib
folder. They are
described in the following. Note that qualifiers, references and the like are discarded
where it improves legibility. Consult the source files for more information.
Vec2
(vec2.hpp
), 2-vector utility class
Template Type - Template parameters
-
value_t
: type of vector entries
-
- Members
- Access
-
value_t x()
- returns x entry
-
value_t y()
- returns y entry
-
Vec2 normalized()
- returns normalized version of vector
-
value_t r()
- returns length
-
value_t phi()
- returns angle (
std::atan2
version of it)
- returns angle (
-
- Member functions
-
value_t r_wrt(Vec2)
- returns length with origin at argument
-
value_t phi_wrt(Vec2)
- returns angle with origin at argument
-
value_t norm()
- returns norm
-
value_t norm_sq()
- returns square of norm
-
- Modifiers
-
Vec2 normalize()
- normalizes the vector and returns it
-
Vec2 rotate(Vec2, value_t)
- rotates the vector and returns it
-
- Supported Operators, All of these work as one would expect
-
*
withVec2
(inner product) andvalue_t
-
/
withvalue_t
-
+, -
withVec2
- All versions of
op=
of the above -
[]
withstd::size_t
-
<<
withstd::ostream
-
- Access
Diagonalizer
(diagonalizer.hpp
), class to diagonalize symmetric Matrices
Type - Members
-
std::vector<double> ev(std::vector<double> mat, size_t N)
- returns eigenvalues of the symmetric matrix mat of linear size N
- throws upon diagonalization failure
-
std::pair<std::vector<double>, std::vector<double> > evv(std::vector<double> mat, size_t N)
- returns pair of (eigenvalues, eigenvectors) of the symmetric matrix mat of size N
- throws upon diagonalization failure
-
- Further developments
- Only finding eigenvectors and -values in a certain range may be added later on