from sympy import symbols, sin, asin, cos, acos, exp, log, sqrt

def parse_expression(tokens):
    """
    将符号列表转换为 SymPy 表达式。
    :param tokens: 符号列表，例如 ['*', '/', 'x_1', 'sin', 'x_1', 'x_1']
    :return: SymPy 表达式
    """
    # 定义操作符映射
    operators = {
        '+': lambda x, y: x + y,
        '-': lambda x, y: x - y,
        '*': lambda x, y: x * y,
        '/': lambda x, y: x / y,
        'sin': lambda x: sin(x),
        'asin': lambda x: asin(x),
        'cos': lambda x: cos(x),
        'acos': lambda x: acos(x),
        'exp': lambda x: exp(x),
        'sqrt': lambda x: sqrt(x),
        'log': lambda x: log(x),  # 自然对数
    }

    # 定义别名到标准操作符的映射
    alias_to_operator = {
        'add': '+',
        'sub': '-',
        'mul': '*',
        'div': '/',
    }

    # 定义变量映射
    variables = {}

    def preprocess(tokens):
        """
        预处理 tokens 列表，将别名操作符替换为标准操作符。
        """
        return [alias_to_operator.get(token, token) for token in tokens]

    def helper(tokens):
        # 如果当前 token 是操作符
        if tokens[0] in operators:
            op = tokens.pop(0)  # 取出操作符
            if op in ['sin', 'asin', 'cos', 'acos', 'exp', 'log', 'sqrt']:
                # 单目操作符
                return operators[op](helper(tokens))
            else:
                # 双目操作符
                left = helper(tokens)
                right = helper(tokens)
                return operators[op](left, right)
        # 如果当前 token 是变量或 const
        elif tokens[0].startswith('x_') or tokens[0] == 'const':
            var_name = tokens.pop(0)  # 取出变量名或 const
            if var_name not in variables:
                variables[var_name] = symbols(var_name)  # 创建 SymPy 符号
            return variables[var_name]
        # 如果是其他情况（如无效 token），抛出错误
        else:
            raise ValueError(f"无法解析 token: {tokens[0]}")

    # 预处理 tokens
    tokens = preprocess(tokens)

    # 开始解析
    return helper(tokens)

# 测试用例
def run_tests():
    test_cases = [
        # 示例 1: 基本加法和乘法
        (['+', 'x_1', 'x_2'], "x_1 + x_2"),
        (['add', 'x_1', 'x_2'], "x_1 + x_2"),  # 使用 add 别名
        # 示例 2: 包含 sin 和 const
        (['*', 'sin', 'x_1', 'const'], "const*sin(x_1)"),
        # 示例 3: 包含 exp 和 log
        (['-', 'exp', 'x_1', 'log', 'const'], "exp(x_1) - log(const)"),
        # 示例 4: 包含 arcsin 和 arccos
        (['+', 'asin', 'x_1', 'acos', 'const'], "asin(x_1) + acos(const)"),
        # 示例 5: 嵌套表达式
        (['/', '*', 'x_1', 'x_2', '+', 'x_1', 'const'], "(x_1*x_2)/(x_1 + const)"),
        (['div', 'mul', 'x_1', 'x_2', 'add', 'x_1', 'const'], "(x_1*x_2)/(x_1 + const)"),  # 使用 div 和 mul 别名
        # 示例 6: 包含复杂嵌套
        (['+', 'exp', 'log', 'x_1', 'const'], "exp(log(x_1)) + const"),
    ]

    for i, (tokens, expected) in enumerate(test_cases):
        print(f"测试用例 {i+1}:")
        print("输入 tokens:", tokens)
        expression = parse_expression(tokens.copy())
        print("解析后的表达式:", expression)
        print("期望的表达式:", expected)
        print("-" * 50)

if __name__ == "__main__":
    run_tests()