import numpy as onp

BOHR_TO_ANGSTROM = 0.52917721092  # taken from pyscf.data.nist
ANGSTROM_TO_BOHR = 1 / BOHR_TO_ANGSTROM
HATREE_TO_KCAL_PER_MOL = 627.509474
KCAL_PER_MOL_TO_HATREE = 1 / HATREE_TO_KCAL_PER_MOL
HATREE_TO_EV = 27.211386245981
EV_TO_HATREE = 1 / HATREE_TO_EV

# Value used to pad the diagonal of the EVP matrices (e.g. Fock matrix)
# to avoid numerical issues with the diagonalization and ensure differentiability.
# This value is chosen to be large enough to not affect the selection of the smallest EV,
# but small enough to maintain numeric stability https://en.wikipedia.org/wiki/Condition_number
MIN_EVP_DIAGONAL_PADDING = 200

L_MAX = 3

# fmt: off
_UNKNOWN = 1.999999
# JCP 41, 3199 (1964); DOI:10.1063/1.1725697.
BRAGG_RADII = ANGSTROM_TO_BOHR * onp.array((_UNKNOWN,  # Ghost atom
        0.35,                                     1.40,             # 1s
        1.45, 1.05, 0.85, 0.70, 0.65, 0.60, 0.50, 1.50,             # 2s2p
        1.80, 1.50, 1.25, 1.10, 1.00, 1.00, 1.00, 1.80,             # 3s3p
        2.20, 1.80,                                                 # 4s
        1.60, 1.40, 1.35, 1.40, 1.40, 1.40, 1.35, 1.35, 1.35, 1.35, # 3d
                    1.30, 1.25, 1.15, 1.15, 1.15, 1.90,             # 4p
        2.35, 2.00,                                                 # 5s
        1.80, 1.55, 1.45, 1.45, 1.35, 1.30, 1.35, 1.40, 1.60, 1.55, # 4d
                    1.55, 1.45, 1.45, 1.40, 1.40, 2.10,             # 5p
        2.60, 2.15,                                                 # 6s
        1.95, 1.85, 1.85, 1.85, 1.85, 1.85, 1.85,                   # La, Ce-Eu
        1.80, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75,             # Gd, Tb-Lu
              1.55, 1.45, 1.35, 1.35, 1.30, 1.35, 1.35, 1.35, 1.50, # 5d
                    1.90, 1.80, 1.60, 1.90, 1.45, 2.10,             # 6p
        1.80, 2.15,                                                 # 7s
        1.95, 1.80, 1.80, 1.75, 1.75, 1.75, 1.75,
        1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75,
        1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75,
                    1.75, 1.75, 1.75, 1.75, 1.75, 1.75,
        1.75, 1.75,
        1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75, 1.75))
#                Period    1   2   3   4   5   6   7       # level
RAD_GRIDS = onp.array(( ( 10, 15, 20, 30, 35, 40, 50),     # 0
                        ( 30, 40, 50, 60, 65, 70, 75),     # 1
                        ( 40, 60, 65, 75, 80, 85, 90),     # 2
                        ( 50, 75, 80, 90, 95,100,105),     # 3
                        ( 60, 90, 95,105,110,115,120),     # 4
                        ( 70,105,110,120,125,130,135),     # 5
                        ( 80,120,125,135,140,145,150),     # 6
                        ( 90,135,140,150,155,160,165),     # 7
                        (100,150,155,165,170,175,180),     # 8
                        (200,200,200,200,200,200,200),))   # 9
#               Period    1   2   3   4   5   6   7        # level
ANG_ORDER = onp.array(( (11, 15, 17, 17, 17, 17, 17 ),     # 0
                        (17, 23, 23, 23, 23, 23, 23 ),     # 1
                        (23, 29, 29, 29, 29, 29, 29 ),     # 2
                        (29, 29, 35, 35, 35, 35, 35 ),     # 3
                        (35, 41, 41, 41, 41, 41, 41 ),     # 4
                        (41, 47, 47, 47, 47, 47, 47 ),     # 5
                        (47, 53, 53, 53, 53, 53, 53 ),     # 6
                        (53, 59, 59, 59, 59, 59, 59 ),     # 7
                        (59, 59, 59, 59, 59, 59, 59 ),     # 8
                        (65, 65, 65, 65, 65, 65, 65 ),))   # 9
# fmt: on
PSE_ROW_START = onp.array((2, 10, 18, 36, 54, 86, 118))


# Individually optimized Treutler/Ahlrichs radius parameter.
# H - Kr are taken from the original paper JCP 102, 346 (1995)
# Other elements are copied from Psi4 source code
# fmt: off
TREUTLER_AHLRICHS_XI = [1.0, # Ghost
    0.8,                               0.9,           # 1s
    1.8, 1.4, 1.3, 1.1, 0.9, 0.9, 0.9, 0.9,           # 2s2p
    1.4, 1.3, 1.3, 1.2, 1.1, 1.0, 1.0, 1.0,           # 3s3p
    1.5, 1.4,                                         # 4s
    1.3, 1.2, 1.2, 1.2, 1.2, 1.2, 1.2, 1.1, 1.1, 1.1, # 3d
              1.1, 1.0, 0.9, 0.9, 0.9, 0.9,           # 4p
    2.000, 1.700,                                                         # 5s
    1.500, 1.500, 1.350, 1.350, 1.250, 1.200, 1.250, 1.300, 1.500, 1.500, # 4d
                  1.300, 1.200, 1.200, 1.150, 1.150, 1.150,               # 5p
    2.500, 2.200,                                                         # 6s
           2.500, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500,               # La, Ce-Eu
           1.500, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500,        # Gd, Tb-Lu
           1.500, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500, # 5d
                  1.500, 1.500, 1.500, 1.500, 1.500, 1.500,               # 6p
    2.500, 2.100,                                                         # 7s
           3.685, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500,
           1.500, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500, 1.500,
] # noqa: E124
# fmt: on
