16#include <doctest/doctest.h>
26 .restrict_quantum_number_n(60, 60)
27 .restrict_quantum_number_l(0, 2)
29 for (
const auto &ket : *basis) {
30 DOCTEST_CHECK(ket->get_species() ==
"Sr88_singlet");
31 DOCTEST_MESSAGE(
"Ket: ", *ket);
39 .restrict_quantum_number_nu(59, 61)
40 .restrict_quantum_number_l(0, 0)
42 for (
const auto &ket : *basis) {
43 DOCTEST_CHECK(ket->get_species() ==
"Sr87_mqdt");
44 DOCTEST_MESSAGE(
"Ket: ", *ket);
56 for (
const auto &ket : *basis) {
57 DOCTEST_CHECK(ket->get_species() ==
"Sr88_singlet");
58 DOCTEST_MESSAGE(
"Ket: ", *ket);
66 .restrict_quantum_number_n(60, 60)
67 .restrict_quantum_number_l(0, 3)
68 .restrict_quantum_number_m(-0.5, 0.5)
72 auto sorter = basis_unsorted->get_sorter(
74 auto basis = basis_unsorted->transformed(sorter);
78 auto quantum_number_m = std::numeric_limits<double>::lowest();
79 for (
size_t i = 0; i < basis->get_number_of_states(); ++i) {
80 DOCTEST_MESSAGE(
"State ", i,
": Parity = ", basis->get_parity(i),
81 ", M = ", basis->get_quantum_number_m(i));
82 DOCTEST_CHECK(basis->get_parity(i) >= parity);
83 if (basis->get_parity(i) != parity) {
84 parity = basis->get_parity(i);
85 quantum_number_m = std::numeric_limits<double>::lowest();
87 DOCTEST_CHECK(basis->get_quantum_number_m(i) >= quantum_number_m);
88 quantum_number_m = basis->get_quantum_number_m(i);
92 auto blocks = basis->get_indices_of_blocks(
94 std::vector<size_t> expected_start = {0, 4, 8, 11};
96 DOCTEST_CHECK(blocks.size() == expected_start.size());
99 for (
const auto &block : blocks) {
100 DOCTEST_MESSAGE(
"Block ", idx,
" starts at ", block.start);
101 DOCTEST_CHECK(block.start == expected_start[idx]);
106 size_t dim = basis->get_number_of_states();
107 Eigen::SparseMatrix<double, Eigen::RowMajor> matrix(
static_cast<long>(dim),
108 static_cast<long>(dim));
109 matrix.setIdentity();
110 auto transformed = basis->transformed(matrix);
111 auto transformation = transformed->get_transformation();
136 .restrict_quantum_number_n(59, 61)
137 .restrict_quantum_number_l(0, 1)
138 .restrict_quantum_number_m(0.5, 0.5)
143 DOCTEST_SUBCASE(
"calculate energy") {
144 auto m1 = basis->get_canonical_state_from_ket(ket_s)->get_matrix_elements(
146 DOCTEST_CHECK(m1.size() == 1);
147 double energy1 = m1[0];
150 DOCTEST_CHECK(m2.size() == basis->get_number_of_states());
151 double energy2 = m2[
static_cast<int>(basis->get_corresponding_state_index(ket_s))];
153 double reference = ket_s->get_energy();
154 DOCTEST_CHECK(std::abs(energy1 - reference) < 1e-11);
155 DOCTEST_CHECK(std::abs(energy2 - reference) < 1e-11);
158 DOCTEST_SUBCASE(
"calculate electric dipole matrix element") {
160 DOCTEST_CHECK(m.size() == basis->get_number_of_states());
161 double dipole = m[
static_cast<int>(basis->get_corresponding_state_index(ket_s))];
163 DOCTEST_CHECK(std::abs(dipole - 1247.5985544327215848) < 1e-6);
166 DOCTEST_SUBCASE(
"calculate electric dipole matrix element with and without an induced dipole") {
168 auto state = basis->get_corresponding_state(ket_s);
171 DOCTEST_CHECK(m.rows() == 1);
172 DOCTEST_CHECK(m.cols() == 1);
173 double dipole = m.coeff(0, 0);
175 DOCTEST_CHECK(std::abs(dipole - 0) < 1e-6);
181 auto state = system.
get_eigenbasis()->get_corresponding_state(ket_s);
184 DOCTEST_CHECK(m.rows() == 1);
185 DOCTEST_CHECK(m.cols() == 1);
186 double dipole = m.coeff(0, 0);
188 DOCTEST_CHECK(std::abs(dipole - 135.01903532588247003) < 1e-6);
Builder class for creating BasisAtom objects.
BasisAtomCreator< Scalar > & append_ket(const std::shared_ptr< const ket_t > &ket)
BasisAtomCreator< Scalar > & set_species(const std::string &value)
static Database & get_global_instance()
Builder class for creating KetAtom objects.
KetAtomCreator & set_quantum_number_n(int value)
std::shared_ptr< const KetAtom > create(Database &database) const
KetAtomCreator & set_quantum_number_j(double value)
KetAtomCreator & set_quantum_number_l(double value)
KetAtomCreator & set_species(const std::string &value)
KetAtomCreator & set_quantum_number_m(double value)
Type & set_electric_field(const std::array< real_t, 3 > &field)
System< Derived > & diagonalize(const DiagonalizerInterface< scalar_t > &diagonalizer, std::optional< real_t > min_eigenenergy={}, std::optional< real_t > max_eigenenergy={}, double rtol=1e-6)
std::shared_ptr< const basis_t > get_eigenbasis() const
DOCTEST_TEST_CASE("create a basis for strontium 88")
constexpr double VOLT_PER_CM_IN_ATOMIC_UNITS
@ SORT_BY_QUANTUM_NUMBER_M