
# © 2021 Copyright claimant to remain anonymous during evaluation period. All rights reserved. May be used only pursuant to Software Evaluation Terms of Use.  CONFIDENTIAL – MAY CONTAIN TRADE SECRETS


from .basis import EmptyBasisException, KernelBasis, AdjointBasis, UnionBasis

from .spaces import *

from .steerable_basis import SteerableKernelBasis

from .polar_basis import GaussianRadialProfile, SphericalShellsBasis

from .wignereckart_solver import WignerEckartBasis, RestrictedWignerEckartBasis
from .sparse_basis import SparseSteerableBasis

from .r2 import *
from .r3 import *


import package.group


def kernels_on_point(in_repr: package.group.Representation, out_repr: package.group.Representation) -> KernelBasis:
    r"""

    Args:
        in_repr (Representation): the representation specifying the transformation of the input feature field
        out_repr (Representation): the representation specifying the transformation of the output feature field
        
    """
    assert in_repr.group == out_repr.group
    
    group = in_repr.group
    
    basis = SteerableKernelBasis(
        PointRn(1, group), in_repr, out_repr,
        WignerEckartBasis,
        harmonics=[group.trivial_representation.id]
    )
    
    return basis


__all__ = [
    "EmptyBasisException",
    "KernelBasis",
    # General Bases
    'SteerableKernelBasis',
    "WignerEckartBasis",
    "RestrictedWignerEckartBasis",
    "SparseSteerableBasis",
    "AdjointBasis",
    "UnionBasis",
    # Specific Bases
    "SphericalShellsBasis",
    'GaussianRadialProfile',
    # Space Isomorphisms
    'SpaceIsomorphism',
    'CircleO2',
    'CircleSO2',
    'SphereO3',
    'SphereSO3',
    'PointRn',
    'Icosidodecahedron',
    'Dodecahedron',
    'Icosahedron',
    # Generic group acting on R^0
    "kernels_on_point",
    # R2 bases
    "kernels_Flip_act_R2",
    "kernels_DN_act_R2",
    "kernels_O2_act_R2",
    "kernels_Trivial_act_R2",
    "kernels_CN_act_R2",
    "kernels_SO2_act_R2",
    "kernels_SO2_subgroup_act_R2",
    "kernels_O2_subgroup_act_R2",
    # R3 bases
    "kernels_O3_act_R3",
    "kernels_SO3_act_R3",
    "kernels_SO3_subgroup_act_R3",
    "kernels_O3_subgroup_act_R3",
    "kernels_Ico_act_R3",
    "kernels_Octa_act_R3",
    "kernels_Tetra_act_R3",
    "kernels_FullIco_act_R3",
    "kernels_FullOcta_act_R3",
    "kernels_FullTetra_act_R3",
    "kernels_Pyrito_act_R3",
    "kernels_SO2_act_R3",
    "kernels_CN_act_R3",
    "kernels_O2_conical_act_R3",
    "kernels_DN_conical_act_R3",
    "kernels_O2_dihedral_act_R3",
    "kernels_DN_dihedral_act_R3",
    "kernels_Inv_act_R3",
    "kernels_Trivial_act_R3",
    'kernels_aliased_Ico_act_R3_dodecahedron',
    'kernels_aliased_Ico_act_R3_icosidodecahedron',
    'kernels_aliased_Ico_act_R3_icosahedron',
]
