mirror of
https://github.com/triqs/dft_tools
synced 2024-10-31 19:23:45 +01:00
f2c7d449cc
for earlier commits, see TRIQS0.x repository.
132 lines
3.4 KiB
Plaintext
132 lines
3.4 KiB
Plaintext
#include <triqs/parameters.hpp>
|
|
#include <iostream>
|
|
|
|
#include <vector>
|
|
#include <complex>
|
|
#include <string>
|
|
|
|
#include <boost/mpi.hpp>
|
|
#include <boost/mpi/environment.hpp>
|
|
#include <boost/mpi/communicator.hpp>
|
|
#include <boost/serialization/access.hpp>
|
|
#include <boost/serialization/complex.hpp>
|
|
|
|
#include <triqs/arrays.hpp>
|
|
|
|
using namespace triqs::utility;
|
|
namespace tqa=triqs::arrays;
|
|
|
|
|
|
|
|
void somefunc(parameters P){//pass by value
|
|
std::cout << P["a"] << std::endl;
|
|
}
|
|
|
|
|
|
//useful to change _object to param or parameter
|
|
//and define the concept of a parameter
|
|
//this way we can explicitly define functions of
|
|
//parameters instead of native types
|
|
|
|
void somefunc(param p){//pass a single parameter by value
|
|
std::cout << p << std::endl;
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char* argv[]) {
|
|
mpi::environment env(argc, argv);
|
|
mpi::communicator world;
|
|
|
|
parameters P;
|
|
|
|
if (mpi.rank() == 0) {
|
|
|
|
P ( "B", short(0), " short ")
|
|
( "C", unsigned short(1), " unsigned short ")
|
|
( "D", int(2), " int ")
|
|
( "E", unsigned int(3), " unsigned int ")
|
|
( "F", long(4), " long ")
|
|
( "G", long long(5), " long ")
|
|
( "H", float(6), " float ")
|
|
( "I", double(7.8), " doube ")
|
|
( "I", long double(9.10), " long double ")
|
|
( "J", std::complex<float>(11), " single complex ")
|
|
( "K", std::complex<double>(12), " double complex ")
|
|
( "L", std::string("13"), " string ")
|
|
( "M", std::vector<double> x{ 1,4 }, " vector ")
|
|
( "N", double(15))
|
|
( "W", int(16))
|
|
;
|
|
|
|
P.set_default("U", std::string("U"))
|
|
("V", std::string("V"));
|
|
|
|
P.set_default("W", std::string("W")); //warning: parameter has been set and will shadow default value
|
|
|
|
P.set_default("X", std::string("X"));
|
|
P.set_default("Y", std::string("Y"));
|
|
P.set_default("Z", std::string("Z"), " Z ");
|
|
|
|
std::cout << P["U"] << std::endl;
|
|
|
|
if(!P.is_default("X") throw TRIQS_RUNTIME_ERROR << "parameter " << P["X"] << " not a default parameter" << std::endl;
|
|
|
|
P["Y"] = 0.815; //must remove default status
|
|
if(P.is_default("Y")) throw TRIQS_RUNTIME_ERROR << "parameter " << P["X"] << " is still a default parameter" << std::endl;
|
|
|
|
}//rank=0
|
|
|
|
mpi::broadcast(world,P,0);
|
|
|
|
if (world.rank() == 0)
|
|
std::cout << "rank 0" << std::endl << P << std::endl ;
|
|
|
|
if (world.rank() == 1)
|
|
std::cout << "rank 1" << std::endl << P << std::endl ;
|
|
|
|
if (world.rank() == 0) {
|
|
|
|
somefunc(P); //check that copying works (pass by value)
|
|
|
|
param p(4.0); //declare a single parameter
|
|
somefunc(p); //check that copying works (pass by value)
|
|
|
|
param p2=P["A"]; //creation of a param from the type in P["A"]
|
|
|
|
P["T"] = p2; //this should not register the type as param but as the type of P["A"]
|
|
if(type_hash_code(P["T"]) != type_hash_code(P["A"])) throw TRIQS_RUNTIME_ERROR << "types don't match" << std::endl;
|
|
|
|
param p3 = p2; //no call of any cast operator
|
|
if(p2==p3) std::cout << "ok." << std::endl;
|
|
if(p2!=p3) throw TRIQS_RUNTIME_ERROR << "param value mismatch" << std::endl;
|
|
|
|
parameters P2(P);
|
|
parameters P3; //new parameter list
|
|
P3=P; //deep copy
|
|
|
|
if(P2==P) std::cout << "ok." << std::endl;
|
|
if(P2!=P) TRIQS_RUNTIME_ERROR << "parameter lists are not equal" << std::endl;
|
|
if(P3!=P) TRIQS_RUNTIME_ERROR << "parameter lists are not equal" << std::endl;
|
|
|
|
P2["ABC"]=5.0;
|
|
if(P2==P) TRIQS_RUNTIME_ERROR << "parameter lists shouldn't be equal" << std::endl;
|
|
|
|
tqa::array<double,2> A(2,2);
|
|
P2["ArrayA"] = A;
|
|
P2["ArrayB"] = tqa::array<double,2> B(3,3);
|
|
P2["ArrayC"] = P2["ArrayA"] + P2["ArrayB"];
|
|
|
|
} // rank==0
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|