import os
import random
import tempfile
import numpy as np
import matplotlib.pyplot as plt


def generate_polyline(num_vertices):
    y_values = np.linspace(0, 1, num_vertices)
    x_values = np.random.uniform(0.2, 0.8, num_vertices)
    return np.array(list(zip(x_values, y_values)))


def generate_fake_polyline(original_polyline, min_distance=0.3):
    while True:
        fake_polyline = original_polyline.copy()
        for i in range(len(fake_polyline)):
            perturbation = random.uniform(-0.3, 0.3)
            fake_polyline[i, 0] = max(0.1, min(0.9, fake_polyline[i, 0] + perturbation))

        total_distance = np.sum(np.abs(fake_polyline[:, 0] - original_polyline[:, 0]))
        if total_distance > min_distance:
            return fake_polyline


def render_2d_polyline(ax, polyline):
    ax.plot(polyline[:, 0], polyline[:, 1], "k-", linewidth=3.5)
    ax.plot([0, 0], [0, 1], "k--", linewidth=1.5)
    ax.set_xlim(0, 1)
    ax.set_ylim(0, 1)
    ax.set_aspect("equal")
    ax.axis("off")


def render_3d_revolution(ax, polyline, cmap_name):
    theta = np.linspace(0, 2 * np.pi, 30)
    x_values = polyline[:, 0]
    y_values = polyline[:, 1]

    cmap = plt.colormaps[cmap_name]

    for i in range(len(x_values) - 1):
        r1, z1 = x_values[i], y_values[i]
        r2, z2 = x_values[i + 1], y_values[i + 1]

        y_norm = (z1 + z2) / 2
        color = cmap(y_norm)
        color = (color[0], color[1], color[2], 0.7)

        for j in range(len(theta) - 1):
            t1, t2 = theta[j], theta[j + 1]

            x = np.array(
                [[r1 * np.cos(t1), r1 * np.cos(t2)], [r2 * np.cos(t1), r2 * np.cos(t2)]]
            )
            y = np.array(
                [[r1 * np.sin(t1), r1 * np.sin(t2)], [r2 * np.sin(t1), r2 * np.sin(t2)]]
            )
            z = np.array([[z1, z1], [z2, z2]])

            ax.plot_surface(x, y, z, color=color, linewidth=0, antialiased=True)

    ax.plot(x_values, np.zeros_like(x_values), y_values, "k-", linewidth=3.5)

    ax.plot([0, 0], [0, 0], [0, 1], "k--", linewidth=1.5)


def generate(variables):
    num_vertices = variables.get("NUM_VERTICES", 6)
    color_map = variables.get("COLOR_MAP", "viridis")

    original_polyline = generate_polyline(num_vertices)
    fake_polylines = [generate_fake_polyline(original_polyline) for _ in range(5)]

    labels = ["A", "B", "C", "D", "E", "F"]
    correct_idx = random.randint(0, 5)
    correct_label = labels[correct_idx]

    all_polylines = [original_polyline]
    all_polylines.extend(fake_polylines)

    correct_polyline = all_polylines[0]
    all_polylines[0] = all_polylines[correct_idx]
    all_polylines[correct_idx] = correct_polyline

    fig = plt.figure(figsize=(18, 12))
    gs = fig.add_gridspec(2, 4)

    ax_2d = fig.add_subplot(gs[:, 3])
    render_2d_polyline(ax_2d, original_polyline)
    ax_2d.set_title("2D Profile", fontsize=20)

    positions = [(0, 0), (0, 1), (0, 2), (1, 0), (1, 1), (1, 2)]

    for i, (row, col) in enumerate(positions):
        ax = fig.add_subplot(gs[row, col], projection="3d")
        render_3d_revolution(ax, all_polylines[i], color_map)
        ax.set_title(labels[i], fontsize=20)

        ax.view_init(elev=20, azim=30)
        ax.set_xlim(-1, 1)
        ax.set_ylim(-1, 1)
        ax.set_zlim(0, 1)
        ax.set_box_aspect([2, 2, 1])
        ax.set_axis_off()

    temp_dir = tempfile.mkdtemp()
    output_pattern = os.path.join(temp_dir, "render.png")

    plt.tight_layout()
    plt.savefig(output_pattern)
    plt.close()

    return {"IMAGE": output_pattern, "CORRECT": correct_label}


if __name__ == "__main__":
    variables = {"NUM_VERTICES": 6}
    result = generate(variables)
    print(f"Generated image: {result['IMAGE']}")
    print(f"Correct answer: {result['CORRECT']}")
