__version__ = "0.9.0"
# import os
# import multiprocessing

# # 1. 获取系统可用的 CPU 核心数（也可手动指定，如 8、16 等）
# num_cores = multiprocessing.cpu_count()  # 自动获取所有核心（如 64 核就返回 64）
# # num_cores = 8  # 若不想用全部核心，可手动指定线程数（如 8 核）

# # 2. 设置 OpenBLAS 线程数（核心步骤：强制开启多线程）
# os.environ["OPENBLAS_NUM_THREADS"] = str(num_cores)
# os.environ["OPENBLAS_VERBOSE"] = "1"  # 可选：开启 verbose 模式，验证多线程是否生效（会打印日志

import sys

from .base import unfold, fold
from .base import tensor_to_vec, vec_to_tensor
from .base import partial_unfold, partial_fold
from .base import partial_tensor_to_vec, partial_vec_to_tensor
from .cp_tensor import (
    cp_to_tensor,
    cp_to_unfolded,
    cp_to_vec,
    cp_norm,
    cp_mode_dot,
    cp_normalize,
    validate_cp_rank,
)
from .tucker_tensor import (
    tucker_to_tensor,
    tucker_to_unfolded,
    tucker_to_vec,
    tucker_mode_dot,
    validate_tucker_rank,
)
from .tt_tensor import (
    tt_to_tensor,
    tt_to_unfolded,
    tt_to_vec,
    validate_tt_rank,
    pad_tt_rank,
)
from .tt_matrix import (
    tt_matrix_to_tensor,
    tt_matrix_to_tensor,
    validate_tt_matrix_rank,
    tt_matrix_to_unfolded,
    tt_matrix_to_vec,
    tt_matrix_to_matrix,
)
from .tr_tensor import tr_to_tensor, tr_to_unfolded, tr_to_vec, validate_tr_rank
from .tenalg import SVD_FUNS, svd_interface, truncated_svd

from .backend import (
    set_backend,
    get_backend,
    # backend_context,
    # backend_manager,
    #    _get_backend_dir, _get_backend_method,
)

# from . import backend as backend_manager
from .backend import (
    context,
    tensor,
    is_tensor,
    shape,
    ndim,
    to_numpy,
    copy,
    float64,
    concatenate,
    reshape,
    transpose,
    moveaxis,
    arange,
    any,
    ones,
    zeros,
    zeros_like,
    eye,
    where,
    conj,
    index,
    index_update,
    clip,
    max,
    min,
    argmax,
    argmin,
    all,
    mean,
    sum,
    prod,
    sign,
    abs,
    sqrt,
    norm,
    dot,
    kron,
    einsum,
    solve,
    lstsq,
    qr,
    kr,
    stack,
    maximum,
    eps,
    finfo,
    matmul,
    index_update,
    check_random_state,
    randn,
    log,
    log2,
    exp,
    sin,
    cos,
    tan,
    asin,
    acos,
    atan,
    arcsin,
    arccos,
    arctan,
    sinh,
    sort,
    cosh,
    tanh,
    arcsinh,
    arccosh,
    arctanh,
    asinh,
    acosh,
    atanh,
    e,
    pi,
    inf,
    nan,
    int32,
    int64,
)

from . import backend
from . import decomposition
from . import plugins
from . import metrics
from . import regression
from . import tenalg
from . import random
from . import datasets
from . import solvers


# Add Backend functions, dynamically dispatched
def __dir__():
    """Returns the module's __dir__, including the local variables
    and augmenting it with the dynamically dispatched variables from backend.
    """
    static_items = list(sys.modules[__name__].__dict__.keys())
    return backend.get_backend_dir() + static_items
    # return _get_backend_dir() + static_items


__getattr__ = backend.__getattribute__


# override_module_dispatch(__name__,
#                          backend_manager.__getattribute__,
#                          full_dir)
# # override_module_dispatch(__name__, _get_backend_method, full_dir)
# del override_module_dispatch, full_dir#, _get_backend_method
