LCOV - code coverage report
Current view: top level - tests - test_starkmap.py (source / functions) Hit Total Coverage
Test: coverage.info Lines: 24 24 100.0 %
Date: 2025-12-08 07:47:12 Functions: 1 2 50.0 %

          Line data    Source code
       1             : # SPDX-FileCopyrightText: 2024 PairInteraction Developers
       2             : # SPDX-License-Identifier: LGPL-3.0-or-later
       3             : 
       4           1 : from __future__ import annotations
       5             : 
       6           1 : from typing import TYPE_CHECKING
       7             : 
       8           1 : import numpy as np
       9           1 : import pytest
      10             : 
      11           1 : from .utils import REFERENCE_PATHS, compare_eigensystem_to_reference
      12             : 
      13             : if TYPE_CHECKING:
      14             :     from .utils import PairinteractionModule
      15             : 
      16             : 
      17           1 : def test_starkmap(pi_module: PairinteractionModule, generate_reference: bool) -> None:
      18             :     """Test calculating a Stark map."""
      19             :     # Create a basis
      20           1 :     ket = pi_module.KetAtom("Rb", n=60, l=0, m=0.5)
      21           1 :     basis = pi_module.BasisAtom("Rb", n=(58, 62), l=(0, 2))
      22           1 :     print(f"Number of basis states: {basis.number_of_states}")
      23             : 
      24           1 :     electric_fields = np.linspace(0, 10, 11)
      25             :     # Create systems for different values of the electric field
      26           1 :     systems = [pi_module.SystemAtom(basis).set_electric_field([0, 0, e], unit="V/cm") for e in electric_fields]
      27             : 
      28             :     # Diagonalize the systems in parallel
      29           1 :     pi_module.diagonalize(systems, diagonalizer="eigen", sort_by_energy=True)
      30             : 
      31             :     # Get the overlap with |ket>
      32           1 :     overlaps = np.array([system.basis.get_overlaps(ket) for system in systems])
      33             : 
      34             :     # Compare to reference data
      35           1 :     kets = [ket.get_label("raw") for ket in systems[0].basis.kets]
      36           1 :     eigenenergies = np.array([system.get_eigenenergies(unit="GHz") for system in systems])
      37           1 :     eigenvectors = np.array([system.get_eigenbasis().get_coefficients().todense().A1 for system in systems])
      38             : 
      39           1 :     reference_path = REFERENCE_PATHS["stark_map"]
      40           1 :     if generate_reference:
      41           1 :         reference_path.mkdir(parents=True, exist_ok=True)
      42           1 :         np.savetxt(reference_path / "kets.txt", kets, fmt="%s", delimiter="\t")
      43           1 :         np.savetxt(reference_path / "eigenenergies.txt", eigenenergies)
      44           1 :         np.savetxt(reference_path / "overlaps.txt", overlaps)
      45           1 :         pytest.skip("Reference data generated, skipping comparison test")
      46             : 
      47           1 :     compare_eigensystem_to_reference(reference_path, eigenenergies, overlaps, eigenvectors, kets)

Generated by: LCOV version 1.16