"""
The module contains auxiliary global variables.
"""
import numpy as np


PI = 3.14159

# The codes for labeling the orbitals

ORBITAL_QN = {0: 's', 1: 'p', 2: 'd'}

M_QN = {0: 'sigma', 1: 'pi', 2: 'delta'}

# Coordinates of high-symmetry points in the Brillouin zone
# of the diamond-type crystal lattice

a_si = 5.50

SPECIAL_K_POINTS_SI = {
    'GAMMA': [0, 0, 0],
    'X': [0, 2 * PI / a_si, 0],
    'L': [PI / a_si,  PI / a_si,  PI / a_si],
    'W': [PI / a_si,  2 * PI / a_si,  0],
    'U': [PI / (2 * a_si), 2 * PI / a_si, PI / (2 * a_si)],
    'K': [3 * PI / (2 * a_si), 3 * PI / (2 * a_si), 0]
}

a_bi = 4.5332
c_bi = 11.7967
b_bi = a_bi / c_bi
gamma_bi = 0.2303

recip_lat_basis = np.array([[-1, -np.sqrt(3.0)/3.0, b_bi],
                             [1, -np.sqrt(3.0)/3.0, b_bi],
                             [0, 2*np.sqrt(3.0)/3.0, b_bi]]) * 2 * PI / a_bi

SPECIAL_K_POINTS_BI = {
    'GAMMA': (recip_lat_basis * np.array([0, 0, 0]).T).tolist(),
    'X': (recip_lat_basis * np.array([0.5, 0.5, 0.0]).T).tolist(),
    'T': (recip_lat_basis * np.array([0.5, 0.5, 0.5]).T).tolist(),
    'L': (recip_lat_basis * np.array([0.0, 0.5, 0.0]).T).tolist(),
    'W': (recip_lat_basis * np.array([gamma_bi, 1.0-gamma_bi, 0.5]).T).tolist(),
    'K': (recip_lat_basis * np.array([1.0/4+0.5*gamma_bi, 3.0/4-0.5*gamma_bi, 0.0]).T).tolist(),
    'U': (recip_lat_basis * np.array([0.5*gamma_bi+0.25, 1.0-gamma_bi, 0.5*gamma_bi+0.25]).T).tolist()
}

# aaa = 3.289
#
# SPECIAL_K_POINTS_BI = {
#     'GAMMA': [0, 0, 0],
#     'X': [0.5 * PI/aaa, 0.5 * PI/aaa, 0.5 * PI/aaa],
#     'T': (recip_lat_basis * np.array([0.5, 0.5, 0.5]).T).tolist(),
#     'L': (recip_lat_basis * np.array([0.0, 0.5, 0.0]).T).tolist(),
#     'W': (recip_lat_basis * np.array([gamma_bi, 1.0-gamma_bi, 0.5]).T).tolist(),
#     'K': (recip_lat_basis * np.array([1.0/4+0.5*gamma_bi, 3.0/4-0.5*gamma_bi, 0.0]).T).tolist(),
#     'U': (recip_lat_basis * np.array([0.5*gamma_bi+0.25, 1.0-gamma_bi, 0.5*gamma_bi+0.25]).T).tolist()
# }