3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-07 20:03:08 +01:00
dft_tools/c++/app4triqs/app4triqs.hpp

79 lines
1.7 KiB
C++
Raw Normal View History

#pragma once
#include <triqs/gfs.hpp>
#include <h5/h5.hpp>
namespace app4triqs {
/**
* A very useful and important class
*
* @note A Useful note
* @include app4triqs/app4triqs.hpp
*/
class toto {
2018-11-21 22:52:55 +01:00
int i = 0;
public:
toto() = default;
/**
* Construct from integer
*
2019-04-23 19:33:57 +02:00
* @param i_ a scalar :math:`G(\tau)`
*/
explicit toto(int i_) : i(i_) {}
~toto() = default;
// Copy/Move construction
toto(toto const &) = default;
toto(toto &&) = default;
/// Copy/Move assignment
toto &operator=(toto const &) = default;
toto &operator=(toto &&) = default;
/// Simple accessor
2019-09-13 23:10:35 +02:00
[[nodiscard]] int get_i() const { return i; }
2019-04-23 19:33:57 +02:00
/**
* A simple function with :math:`G(\tau)`
*
* @param u Nothing useful
*/
int f(int u) { return u; }
2019-04-23 19:33:57 +02:00
/// Arithmetic operations
toto operator+(toto const &b) const;
toto &operator+=(toto const &b);
/// Comparison
bool operator==(toto const &b) const;
/// HDF5
static std::string hdf5_format() { return "Toto"; }
friend void h5_write(h5::group grp, std::string subgroup_name, toto const &m);
friend void h5_read(h5::group grp, std::string subgroup_name, toto &m);
/// Serialization
2019-04-25 19:52:22 +02:00
template <class Archive> void serialize(Archive &ar, const unsigned int) { ar &i; }
};
/**
* Chain digits of two integers
*
2019-04-25 21:48:21 +02:00
* @head A set of functions that implement chaining
*
* @tail Do I really need to explain more ?
*
2019-04-23 19:33:57 +02:00
* @param i The first integer
* @param j The second integer
* @return An integer containing the digits of both i and j
*
*/
int chain(int i, int j);
} // namespace app4triqs