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/stl/shared_ptr.h> 17 : #include <nanobind/stl/string.h> 18 : #include <nanobind/stl/vector.h> 19 : #include <sstream> 20 : 21 : namespace nb = nanobind; 22 : using namespace pairinteraction; 23 : 24 2 : static void declare_ket(nb::module_ &m) { 25 2 : std::string pyclass_name = "Ket"; 26 2 : nb::class_<Ket> pyclass(m, pyclass_name.c_str()); 27 2 : pyclass.def("get_energy", &Ket::get_energy) 28 2 : .def("get_quantum_number_f", &Ket::get_quantum_number_f) 29 2 : .def("get_quantum_number_m", &Ket::get_quantum_number_m) 30 2 : .def("get_parity", &Ket::get_parity) 31 4 : .def("get_label", &Ket::get_label) 32 2 : .def("__str__", [](Ket const &self) { 33 0 : std::stringstream ss; 34 0 : ss << self; 35 0 : return ss.str(); 36 0 : }); 37 2 : } 38 : 39 2 : static void declare_ket_atom(nb::module_ &m) { 40 2 : std::string pyclass_name = "KetAtom"; 41 2 : nb::class_<KetAtom, Ket> pyclass(m, pyclass_name.c_str()); 42 2 : pyclass.def("get_species", &KetAtom::get_species) 43 2 : .def("get_quantum_number_n", &KetAtom::get_quantum_number_n) 44 2 : .def("get_quantum_number_nu", &KetAtom::get_quantum_number_nu) 45 2 : .def("get_quantum_number_nui", &KetAtom::get_quantum_number_nui) 46 2 : .def("get_quantum_number_l", &KetAtom::get_quantum_number_l) 47 2 : .def("get_quantum_number_s", &KetAtom::get_quantum_number_s) 48 2 : .def("get_quantum_number_j", &KetAtom::get_quantum_number_j) 49 2 : .def("get_quantum_number_l_ryd", &KetAtom::get_quantum_number_l_ryd) 50 2 : .def("get_quantum_number_j_ryd", &KetAtom::get_quantum_number_j_ryd) 51 2 : .def("get_quantum_number_nui_std", &KetAtom::get_quantum_number_nui_std) 52 2 : .def("get_quantum_number_l_std", &KetAtom::get_quantum_number_l_std) 53 2 : .def("get_quantum_number_s_std", &KetAtom::get_quantum_number_s_std) 54 2 : .def("get_quantum_number_j_std", &KetAtom::get_quantum_number_j_std) 55 2 : .def("get_quantum_number_l_ryd_std", &KetAtom::get_quantum_number_l_ryd_std) 56 2 : .def("get_quantum_number_j_ryd_std", &KetAtom::get_quantum_number_j_ryd_std) 57 2 : .def("is_j_total_momentum", &KetAtom::is_j_total_momentum) 58 2 : .def("is_calculated_with_mqdt", &KetAtom::is_calculated_with_mqdt) 59 : .def("get_underspecified_channel_contribution", 60 2 : &KetAtom::get_underspecified_channel_contribution); 61 2 : } 62 : 63 2 : static void declare_ket_atom_creator(nb::module_ &m) { 64 2 : std::string pyclass_name = "KetAtomCreator"; 65 4 : nb::class_<KetAtomCreator> pyclass(m, pyclass_name.c_str()); 66 2 : pyclass.def(nb::init<>()) 67 4 : .def(nb::init<std::string, int, double, double, double>()) 68 2 : .def("set_species", &KetAtomCreator::set_species) 69 2 : .def("set_energy", &KetAtomCreator::set_energy) 70 2 : .def("set_quantum_number_f", &KetAtomCreator::set_quantum_number_f) 71 2 : .def("set_quantum_number_m", &KetAtomCreator::set_quantum_number_m) 72 2 : .def("set_parity", &KetAtomCreator::set_parity) 73 2 : .def("set_quantum_number_n", &KetAtomCreator::set_quantum_number_n) 74 2 : .def("set_quantum_number_nu", &KetAtomCreator::set_quantum_number_nu) 75 2 : .def("set_quantum_number_nui", &KetAtomCreator::set_quantum_number_nui) 76 2 : .def("set_quantum_number_l", &KetAtomCreator::set_quantum_number_l) 77 2 : .def("set_quantum_number_s", &KetAtomCreator::set_quantum_number_s) 78 2 : .def("set_quantum_number_j", &KetAtomCreator::set_quantum_number_j) 79 2 : .def("set_quantum_number_l_ryd", &KetAtomCreator::set_quantum_number_l_ryd) 80 2 : .def("set_quantum_number_j_ryd", &KetAtomCreator::set_quantum_number_j_ryd) 81 2 : .def("create", &KetAtomCreator::create); 82 2 : } 83 : 84 : template <typename T> 85 4 : static void declare_ket_pair(nb::module_ &m, std::string const &type_name) { 86 4 : std::string pyclass_name = "KetPair" + type_name; 87 4 : nb::class_<KetPair<T>, Ket> pyclass(m, pyclass_name.c_str()); 88 4 : pyclass.def("get_atomic_states", &KetPair<T>::get_atomic_states); 89 4 : } 90 : 91 2 : void bind_ket(nb::module_ &m) { 92 2 : declare_ket(m); 93 2 : declare_ket_atom(m); 94 2 : declare_ket_atom_creator(m); 95 2 : declare_ket_pair<double>(m, "Real"); 96 2 : declare_ket_pair<std::complex<double>>(m, "Complex"); 97 2 : }