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
consist of the following:
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)
-
- 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()
: normalize the vector -
Vec2 rotate(Vec2, value_t)
: rotate the vector
-
- 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
-