source: src/LinearAlgebra/Matrix.hpp@ 7e37a3

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since 7e37a3 was 5b4605, checked in by Frederik Heber <heber@…>, 15 years ago

operator[+-*] return const instance [Meyer, "Effective C++", item 21].

  • class Vector had this correct, class Matrix not (also for *=,+=).
  • Property mode set to 100644
File size: 3.3 KB
RevLine 
[325390]1/*
2 * Matrix.hpp
3 *
4 * Created on: Jun 25, 2010
5 * Author: crueger
6 */
7
8#ifndef MATRIX_HPP_
9#define MATRIX_HPP_
10
[986ed3]11#include <iosfwd>
[325390]12#include "defs.hpp"
13
[cd82ec]14/**
15 * Simple class to store matrices with a few extra functions
16 */
17
[325390]18class Vector;
[fee079]19class MatrixContent;
[325390]20
21class Matrix
22{
23 friend Vector operator*(const Matrix&,const Vector&);
24public:
25 Matrix();
[cd82ec]26
27 /**
28 * construct a matrix from a 3x3 double array that contains all Elements.
29 *
30 * The elements are laid out in the following way:
31 * array -> matrix
32 * 0 -> (0,0)
33 * 1 -> (1,0)
34 * 2 -> (2,0)
35 * 3 -> (0,1)
36 * 4 -> (1,1)
37 * 5 -> (2,1)
38 * 6 -> (0,2)
39 * 7 -> (1,2)
40 * 8 -> (2,2)
41 *
42 */
[325390]43 Matrix(const double*);
44 Matrix(const Matrix&);
45 virtual ~Matrix();
46
[cd82ec]47 /**
48 * Set the matrix to a unit matrix.
49 */
[1da5f5]50 void one();
51
[a439e5]52 /**
53 * Set all matrix entries to zero.
54 */
55 void zero();
56
[cd82ec]57 /**
58 * Access the matrix at index (i,j)
59 */
[325390]60 double &at(size_t i, size_t j);
[cd82ec]61 /**
62 * Access the matrix at index (i,j)
63 */
[436f04]64 const double at(size_t i, size_t j) const;
65
[cd82ec]66 /**
67 * Set the matrix at index (i,j).
68 *
69 * Slightly faster than at(i,j)=x
70 */
[436f04]71 void set(size_t i, size_t j, const double value);
[325390]72
[3dbb9d]73 /**
74 * get the ith row of the matrix as a vector
75 */
76 Vector &row(size_t);
77 const Vector &row(size_t) const;
78
79 /**
80 * get the ith column of the matrix as a vector
81 */
82 Vector &column(size_t);
83 const Vector &column(size_t) const;
84
85 /**
86 * get the diagonal of the matrix as a vector
87 */
88 Vector &diagonal();
89 const Vector &diagonal() const;
90
[cd82ec]91 /**
92 * Calculate the determinant of the matrix
93 */
[cadbc1]94 double determinant() const;
[325390]95
[cd82ec]96 /**
97 * Calculate the inverse of the matrix.
98 *
99 * Rather costly, so use precomputation as often as possible.
100 */
[cadbc1]101 Matrix invert() const;
[325390]102
[a439e5]103 /**
104 * Diagonalizes a matrix and sets its rows to the resulting eigenvalues.
105 * The eigenvalues are returned as a vector.
106 *
107 * Rather costly, so use precomputation as often as possible.
108 */
109 Vector transformToEigenbasis();
110
111 /**
112 * Calculate the transpose of the matrix.
113 */
114 Matrix transpose() const;
115 void transpose();
116
[325390]117 // operators
118 Matrix &operator=(const Matrix&);
119
[5b4605]120 const Matrix &operator+=(const Matrix&);
121 const Matrix &operator-=(const Matrix&);
122 const Matrix &operator*=(const Matrix&);
[325390]123
[5b4605]124 const Matrix &operator*=(const double);
[325390]125
[5b4605]126 const Matrix operator+(const Matrix&) const;
127 const Matrix operator-(const Matrix&) const;
128 const Matrix operator*(const Matrix&) const;
[325390]129
[0eb2dc]130 bool operator==(const Matrix&) const;
131
[325390]132private:
[fee079]133 Matrix(MatrixContent*);
[3dbb9d]134 void createViews();
[fee079]135 MatrixContent *content;
[8e17d6]136 // we keep around some Vector views of the matrix, to return references
[3dbb9d]137 Vector* rows_ptr[NDIM];
138 Vector* columns_ptr[NDIM];
139 Vector* diagonal_ptr;
[325390]140};
141
[5b4605]142const Matrix operator*(const double,const Matrix&);
143const Matrix operator*(const Matrix&,const double);
[325390]144
[cd82ec]145/**
146 * Takes a symmetric matrix that stores the lower diagonal and produces a
147 * full matrix.
148 *
149 * The array is laid out as follows:
150 *
151 * array -> matrix
152 * 0 -> (0,0)
153 * 1 -> (1,0);(0,1)
154 * 2 -> (1,1)
155 * 3 -> (2,0);(0,2)
156 * 4 -> (2,1);(1,2)
157 * 5 -> (2,2)
158 */
[d10eb6]159Matrix ReturnFullMatrixforSymmetric(const double * const cell_size);
160
[c49c96]161std::ostream &operator<<(std::ostream&,const Matrix&);
[4b94bb]162Vector operator*(const Matrix&,const Vector&);
163Vector& operator*=(Vector&,const Matrix&);
[c49c96]164
[325390]165#endif /* MATRIX_HPP_ */
Note: See TracBrowser for help on using the repository browser.