Line data Source code
1 : // SPDX-FileCopyrightText: 2024 Pairinteraction Developers 2 : // SPDX-License-Identifier: LGPL-3.0-or-later 3 : 4 : #include "./Ket.py.hpp" 5 : 6 : #include "pairinteraction/basis/BasisAtom.hpp" 7 : #include "pairinteraction/database/Database.hpp" 8 : #include "pairinteraction/ket/Ket.hpp" 9 : #include "pairinteraction/ket/KetAtom.hpp" 10 : #include "pairinteraction/ket/KetAtomCreator.hpp" 11 : #include "pairinteraction/ket/KetPair.hpp" 12 : #include "pairinteraction/utils/traits.hpp" 13 : 14 : #include <complex> 15 : #include <nanobind/nanobind.h> 16 : #include <nanobind/operators.h> 17 : #include <nanobind/stl/shared_ptr.h> 18 : #include <nanobind/stl/string.h> 19 : #include <nanobind/stl/vector.h> 20 : #include <sstream> 21 : 22 : namespace nb = nanobind; 23 : using namespace pairinteraction; 24 : 25 2 : static void declare_ket(nb::module_ &m) { 26 2 : std::string pyclass_name = "Ket"; 27 2 : nb::class_<Ket> pyclass(m, pyclass_name.c_str()); 28 2 : pyclass.def("get_energy", &Ket::get_energy) 29 2 : .def("get_quantum_number_f", &Ket::get_quantum_number_f) 30 2 : .def("get_quantum_number_m", &Ket::get_quantum_number_m) 31 2 : .def("get_parity", &Ket::get_parity) 32 4 : .def("get_label", &Ket::get_label) 33 2 : .def("__str__", [](Ket const &self) { 34 0 : std::stringstream ss; 35 0 : ss << self; 36 0 : return ss.str(); 37 0 : }); 38 2 : } 39 : 40 2 : static void declare_ket_atom(nb::module_ &m) { 41 2 : std::string pyclass_name = "KetAtom"; 42 2 : nb::class_<KetAtom, Ket> pyclass(m, pyclass_name.c_str()); 43 2 : pyclass.def("get_species", &KetAtom::get_species) 44 2 : .def("get_quantum_number_n", &KetAtom::get_quantum_number_n) 45 2 : .def("get_quantum_number_nu", &KetAtom::get_quantum_number_nu) 46 2 : .def("get_quantum_number_nui", &KetAtom::get_quantum_number_nui) 47 2 : .def("get_quantum_number_l", &KetAtom::get_quantum_number_l) 48 2 : .def("get_quantum_number_s", &KetAtom::get_quantum_number_s) 49 2 : .def("get_quantum_number_j", &KetAtom::get_quantum_number_j) 50 2 : .def("get_quantum_number_l_ryd", &KetAtom::get_quantum_number_l_ryd) 51 2 : .def("get_quantum_number_j_ryd", &KetAtom::get_quantum_number_j_ryd) 52 2 : .def("get_quantum_number_nui_std", &KetAtom::get_quantum_number_nui_std) 53 2 : .def("get_quantum_number_l_std", &KetAtom::get_quantum_number_l_std) 54 2 : .def("get_quantum_number_s_std", &KetAtom::get_quantum_number_s_std) 55 2 : .def("get_quantum_number_j_std", &KetAtom::get_quantum_number_j_std) 56 2 : .def("get_quantum_number_l_ryd_std", &KetAtom::get_quantum_number_l_ryd_std) 57 2 : .def("get_quantum_number_j_ryd_std", &KetAtom::get_quantum_number_j_ryd_std) 58 2 : .def("is_j_total_momentum", &KetAtom::is_j_total_momentum) 59 2 : .def("is_calculated_with_mqdt", &KetAtom::is_calculated_with_mqdt) 60 2 : .def("get_underspecified_channel_contribution", 61 2 : &KetAtom::get_underspecified_channel_contribution) 62 2 : .def(nb::self == nb::self) // NOLINT(misc-redundant-expression) 63 0 : .def("__hash__", [](const KetAtom &self) { return KetAtom::hash{}(self); }); 64 2 : } 65 : 66 2 : static void declare_ket_atom_creator(nb::module_ &m) { 67 2 : std::string pyclass_name = "KetAtomCreator"; 68 4 : nb::class_<KetAtomCreator> pyclass(m, pyclass_name.c_str()); 69 2 : pyclass.def(nb::init<>()) 70 4 : .def(nb::init<std::string, int, double, double, double>()) 71 2 : .def("set_species", &KetAtomCreator::set_species) 72 2 : .def("set_energy", &KetAtomCreator::set_energy) 73 2 : .def("set_quantum_number_f", &KetAtomCreator::set_quantum_number_f) 74 2 : .def("set_quantum_number_m", &KetAtomCreator::set_quantum_number_m) 75 2 : .def("set_parity", &KetAtomCreator::set_parity) 76 2 : .def("set_quantum_number_n", &KetAtomCreator::set_quantum_number_n) 77 2 : .def("set_quantum_number_nu", &KetAtomCreator::set_quantum_number_nu) 78 2 : .def("set_quantum_number_nui", &KetAtomCreator::set_quantum_number_nui) 79 2 : .def("set_quantum_number_l", &KetAtomCreator::set_quantum_number_l) 80 2 : .def("set_quantum_number_s", &KetAtomCreator::set_quantum_number_s) 81 2 : .def("set_quantum_number_j", &KetAtomCreator::set_quantum_number_j) 82 2 : .def("set_quantum_number_l_ryd", &KetAtomCreator::set_quantum_number_l_ryd) 83 2 : .def("set_quantum_number_j_ryd", &KetAtomCreator::set_quantum_number_j_ryd) 84 2 : .def("create", &KetAtomCreator::create); 85 2 : } 86 : 87 : template <typename T> 88 4 : static void declare_ket_pair(nb::module_ &m, std::string const &type_name) { 89 4 : std::string pyclass_name = "KetPair" + type_name; 90 4 : nb::class_<KetPair<T>, Ket> pyclass(m, pyclass_name.c_str()); 91 4 : pyclass.def("get_atomic_states", &KetPair<T>::get_atomic_states) 92 4 : .def(nb::self == nb::self) // NOLINT(misc-redundant-expression) 93 4 : .def("__hash__", [](const KetPair<T> &self) { return typename KetPair<T>::hash{}(self); }); 94 4 : } 95 : 96 2 : void bind_ket(nb::module_ &m) { 97 2 : declare_ket(m); 98 2 : declare_ket_atom(m); 99 2 : declare_ket_atom_creator(m); 100 2 : declare_ket_pair<double>(m, "Real"); 101 2 : declare_ket_pair<std::complex<double>>(m, "Complex"); 102 2 : }