mirror of
https://github.com/triqs/dft_tools
synced 2024-12-27 06:43:40 +01:00
38d89e2d01
- introducing scalar_valued gf - Change Fourier routines to run on scalar_valued, and then use those routines to run on matrix_valued. - Tools for slices of 2 variables functions
40 lines
853 B
C++
40 lines
853 B
C++
#define TRIQS_ARRAYS_ENFORCE_BOUNDCHECK
|
|
|
|
|
|
#include <iostream>
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <fstream>
|
|
#include <triqs/gf/gf.hpp>
|
|
#include <triqs/gf/two_real_times.hpp>
|
|
#include <complex>
|
|
using namespace triqs::gf;
|
|
using namespace std;
|
|
using triqs::arrays::make_shape;
|
|
|
|
int main(){
|
|
|
|
double dt=0.001;
|
|
double tmax=0.005;
|
|
int nt=tmax/dt;
|
|
auto R= make_gf<two_real_times> (tmax,nt,make_shape(1,1));//results
|
|
|
|
for(auto point:R.mesh()) R(point)=0;
|
|
|
|
const auto rg = on_mesh(R);
|
|
R.on_mesh(1,1) = 10;
|
|
|
|
std::cout << rg (1,1)<< std::endl ;
|
|
std::cout << R.on_mesh(1,1)<< std::endl ;
|
|
std::cout << R(0.001,0.001)<< std::endl ;
|
|
|
|
auto R2 = R;
|
|
|
|
//on_mesh(R2)(1,1) = on_mesh(R)(1,1) * on_mesh(R)(1,1);
|
|
on_mesh(R2)(1,1)() = on_mesh(R)(1,1) * on_mesh(R)(1,1);
|
|
|
|
std::cout << on_mesh(R2)(1,1)<< std::endl;
|
|
return 0;
|
|
};
|