3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-12 14:08:24 +01:00
dft_tools/doc/tutorials/det_manip_tutorial_3.cpp
tayral edd1ff4529 Restructuring documentation.
A first general restructuration of the doc according to the pattern [tour|tutorial|reference].
In the reference part, objects are documented per topic.
In each topic, [definition|c++|python|hdf5] (not yet implemented)
2014-10-18 12:21:08 +01:00

25 lines
1.1 KiB
C++

#include <triqs/det_manip/det_manip.hpp>
struct fun {
typedef double result_type;
typedef double argument_type;
double operator()(double x, double y) const { return (exp(x) - y * y); }
};
int main() {
triqs::det_manip::det_manip<fun> D(fun(), std::vector<double>{1, 2, 2.5}, std::vector<double>{3, 4, 9});
std::cout << std::endl << "After construction, D.matrix()=" << D.matrix() << std::endl << std::endl;
double x0 = 2.1, y0 = 7;
int i = 2, j = 0; // number of the added line and column
std::cout << "We want to add a line and a column for i=" << i << ", j=" << j << ", x=" << x0 << ", y=" << y0 << "." << std::endl;
// (try of) insertion of a line and a column at position (3,1) in the matrix
// with x[i]=x0, y[j]=y0.
double detratio = D.try_insert(i, j, x0, y0); // the ratio between new and old determinants
// while the operation is not complete, the matrix stays unchanged
std::cout << "After try_insert, D.matrix()=" << D.matrix() << std::endl;
// here we validate the insertion: the (inverse) matrix and determinant are updated
D.complete_operation();
std::cout << "After complete_operation, D.matrix()=" << D.matrix() << std::endl << std::endl;
}