mirror of
https://github.com/triqs/dft_tools
synced 2025-01-12 22:18:23 +01:00
588dd6e50a
- does not use view - determinant not lazy any more
133 lines
3.9 KiB
C++
133 lines
3.9 KiB
C++
#include <triqs/det_manip/det_manip.hpp>
|
|
#include <triqs/mc_tools/random_generator.hpp>
|
|
#include <triqs/arrays/linalg/det_and_inverse.hpp>
|
|
#include <triqs/arrays/asserts.hpp>
|
|
#include <iostream>
|
|
#include <triqs/utility/complex_ops.hpp>
|
|
|
|
struct fun {
|
|
|
|
typedef std::complex<double> result_type;
|
|
typedef double argument_type;
|
|
|
|
/*double f(double eps, double tau, double beta) const {
|
|
bool s = (tau>0);
|
|
tau = (s ? tau : beta + tau);
|
|
return (s ? 1 : -1 ) * exp( - eps* (tau)) / (1 + exp(- beta *eps));
|
|
}*/
|
|
|
|
std::complex<double> operator()(double x, double y) const {
|
|
const double pi = acos(-1);
|
|
const double beta = 10.0;
|
|
const double epsi = 0.1;
|
|
double tau = x-y;
|
|
bool s = (tau>0);
|
|
tau = (s ? tau : beta + tau);
|
|
double r = epsi + tau/beta *(1-2*epsi);
|
|
std::complex<double> I(0,1);
|
|
return - 2*I*(pi/beta)/ std::sin ( pi *r);
|
|
|
|
//return - 0.5*(f(0.12, x-y, beta) + f(0.43,x-y,beta) ); //+ f(-0.7,x-y,beta));
|
|
}
|
|
|
|
};
|
|
|
|
template<class T1, class T2 >
|
|
void assert_close( T1 const & A, T2 const & B, double precision) {
|
|
std::cerr << " assert_close "<< A << " "<< B<< " "<< std::abs(A-B) <<" "<< precision << std::endl;
|
|
if ( std::abs(A-B) > precision) TRIQS_RUNTIME_ERROR<<"assert_close error : "<<A<<"\n"<<B;
|
|
}
|
|
const double PRECISION = 1.e-6;
|
|
|
|
struct test {
|
|
|
|
fun f;
|
|
triqs::det_manip::det_manip<fun> D;
|
|
std::complex<double> det_old,detratio;
|
|
|
|
test() : f(), D(f,100) {}
|
|
|
|
void check() {
|
|
#ifndef PRINT_ALL
|
|
std::cerr << "det = " << D.determinant() << " == " << std::complex<double>(determinant(D.matrix()))<< std::endl;
|
|
#else
|
|
std::cerr << "det = " << D.determinant() << " == " << std::complex<double>(determinant(D.matrix()))<< std::endl <<
|
|
D.inverse_matrix() << D.matrix() << triqs::arrays::matrix<std::complex<double>>(inverse(D.matrix()))<< std::endl;
|
|
std::cerr << "det_old = " << det_old << "detratio = "<< detratio<< " determin "<< D.determinant() <<std::endl;
|
|
#endif
|
|
assert_close(D.determinant() , long(1)/determinant(D.inverse_matrix()), PRECISION);
|
|
triqs::arrays::assert_all_close( inverse(D.matrix()) , D.inverse_matrix(), PRECISION, true);
|
|
assert_close( det_old * detratio , D.determinant(), PRECISION);
|
|
}
|
|
|
|
void run() {
|
|
triqs::mc_tools::random_generator RNG("mt19937", 23432);
|
|
for (size_t i =0; i< 100; ++i) {
|
|
std::cerr<<" ------------------------------------------------"<<std::endl;
|
|
std::cerr <<" i = "<< i << " size = "<< D.size() << std::endl;
|
|
// choose a move
|
|
int mn = RNG(4);
|
|
size_t s = D.size();
|
|
size_t i0,j0,i1,j1;
|
|
det_old = D.determinant();
|
|
detratio=1;
|
|
double x,y,x1,y1;
|
|
bool do_something = true;
|
|
|
|
switch(RNG(( i>10 ? 4 : 1))) {
|
|
case 0 :
|
|
std::cerr << " insert1" << std::endl;
|
|
x = RNG(10.0), y = RNG(10.0);
|
|
std::cerr << " x,y = "<< x << " "<< y << std::endl;
|
|
detratio = D.try_insert(RNG(s),RNG(s), x,y);
|
|
break;
|
|
case 1 :
|
|
std::cerr << " remove1" << std::endl;
|
|
if (s>0) detratio = D.try_remove(RNG(s),RNG(s));
|
|
break;
|
|
case 2:
|
|
std::cerr << " Insert2" << std::endl;
|
|
x = RNG(10.0); x1 = RNG(10.0);
|
|
y = RNG(10.0); y1 = RNG(10.0);
|
|
i0 = RNG(s); i1 = RNG(s+1);
|
|
j0 = RNG(s); j1 = RNG(s+1);
|
|
if ((i0 !=i1)&& (j0!=j1))
|
|
{
|
|
detratio = D.try_insert2(i0,i1,j0,j1, x,x1,y,y1);
|
|
}
|
|
else do_something = false;
|
|
|
|
break;
|
|
case 3:
|
|
std::cerr << " Remove2" << std::endl;
|
|
if (D.size()>=2) {
|
|
i0 = RNG(s); i1 = RNG(s);
|
|
j0 = RNG(s); j1 = RNG(s);
|
|
if ((i0 !=i1)&& (j0!=j1)) {
|
|
detratio = D.try_remove2(i0,i1,j0,j1);
|
|
}
|
|
else do_something = false;
|
|
}
|
|
break;
|
|
default :
|
|
TRIQS_RUNTIME_ERROR <<" TEST INTERNAL ERROR" ;
|
|
};
|
|
|
|
if (do_something) {
|
|
if (std::abs(detratio*det_old)> PRECISION) {
|
|
D.complete_operation();
|
|
if (D.size() >0) check();
|
|
}
|
|
else { std::cerr << " reject since new det is = " << std::abs(detratio*det_old)<<std::endl;}
|
|
}
|
|
}
|
|
}
|
|
|
|
};
|
|
|
|
int main(int argc, char **argv) {
|
|
test().run();
|
|
}
|
|
|
|
|