"""
Constants for the GTO basis.
- L_TO_LXLYLZ: mapping from l to cartesian angular momentum tuples (lx, ly, lz)
- CART_SPH_CONTRACTIONS: contraction factors for the cartesian to spherical harmonics transformation
    consistent with the ordering of the basis functions in L_TO_LXLYLZ
"""

import numpy as onp

# mapping from l to cartesian angular momentum tuples (lx, ly, lz)
L_TO_LXLYLZ = {
    0: [(0, 0, 0)],
    1: [(1, 0, 0), (0, 1, 0), (0, 0, 1)],  # p
    2: [(1, 1, 0), (0, 1, 1), (1, 0, 1), (2, 0, 0), (0, 2, 0), (0, 0, 2)],  # d
    3: [  # f
        (3, 0, 0),  # 0     x^3
        (1, 2, 0),  # 1     x   y^2
        (1, 0, 2),  # 2     x       z^2
        (2, 1, 0),  # 3     x^2 y
        (0, 3, 0),  # 4         y^3
        (0, 1, 2),  # 5         y   z^2
        (2, 0, 1),  # 6     x^2     z
        (0, 2, 1),  # 7         y^2 z
        (0, 0, 3),  # 8             z^3
        (1, 1, 1),  # 9     x   y   z
    ],
}

# fmt: off
# follows the same ordering as https://en.wikipedia.org/wiki/Table_of_spherical_harmonics#Real_spherical_harmonics
CART_SPH_CONTRACTIONS = {
    0: onp.eye(1),
    1: onp.eye(3) * 0.707106781186547524, # type: ignore
    2: onp.array([
            # factors from: https://github.com/sunqm/libcint/blob/master/src/cart2sph.c
            [1.092548430592079070, 0, 0, 0, 0, 0],  # d_xy
            [0, 1.092548430592079070, 0, 0, 0, 0],  # d_yz
            [0, 0, 0, -0.315391565252520002, -0.315391565252520002, 0.630783130505040012],  # d_z^2
            [0, 0, 1.092548430592079070, 0, 0, 0],  # d_xz
            [0, 0, 0, 0.546274215296039535, -0.546274215296039535, 0],  # d_(x^2 - y^2)
        ]) / 2.1850968611841584 ,
    3: onp.array([
            # factors from: https://github.com/sunqm/libcint/blob/master/src/cart2sph.c
            [0, 0, 0, 1.770130769779930531, -0.590043589926643510, 0, 0, 0, 0, 0,], # f_y(3x^2 - y^2)
            [0, 0, 0, 0, 0, 0, 0, 0, 0, 2.890611442640554055], # f_xyz
            [0, 0, 0, -0.457045799464465739, -0.457045799464465739, 1.828183197857862944, 0, 0, 0, 0], # f_yz^2
            [0, 0, 0, 0, 0, 0, -1.119528997770346170, -1.119528997770346170, 0.746352665180230782, 0],
            [-0.457045799464465739, -0.457045799464465739, 1.828183197857862944, 0, 0, 0, 0, 0, 0, 0],
            [0, 0, 0, 0, 0, 0, 1.445305721320277020, -1.445305721320277020, 0, 0],
            [0.590043589926643510, -1.770130769779930530, 0, 0, 0, 0, 0, 0, 0, 0,],
        ]) / 8.17588381146625823
}
# fmt: on
