import numpy as np


def voxel_project(voxel_array, projection: str = "front"):
    arr = voxel_array.copy()

    if projection == "right":
        arr_flipped = arr[::-1, :, :]
        return np.transpose(arr_flipped, (1, 2, 0))
    elif projection == "right_noise":
        return voxel_project_noise(arr, "right")
    elif projection == "front":
        return np.transpose(arr, (0, 2, 1))
    elif projection == "front_noise":
        return voxel_project_noise(arr, "front")
    elif projection == "top":
        return np.flip(np.transpose(np.transpose(arr, (2, 1, 0)), (0, 2, 1)), axis=1)
    elif projection == "top_noise":
        return voxel_project_noise(arr, "top")


def voxel_project_noise(
    voxel_array,
    projection: str = "front",
    max_attempts=30,
    noise_prob=0.05,
):
    arr = voxel_project(voxel_array, projection)
    normal_projections = [
        voxel_project(voxel_array, "top"),
        voxel_project(voxel_array, "front"),
        voxel_project(voxel_array, "right"),
    ]

    for _ in range(max_attempts):
        noise = np.zeros(arr.shape, dtype=int)
        random_values = np.random.random(arr.shape)
        noise[random_values < noise_prob] = -1
        noise[random_values > (1 - noise_prob)] = 1
        nosiy_projection = np.clip(arr + noise, 0, 1)

        projection_diffs = [
            np.array_equal(nosiy_projection, normal_projection)
            for normal_projection in normal_projections
        ]
        if not any(projection_diffs):
            return nosiy_projection

    return nosiy_projection


def voxel_depth(voxel_array, projection: str = "front"):
    voxel_array = voxel_project(voxel_array, projection)

    mask = voxel_array != 0
    mask_flipped = np.flip(mask, axis=0)
    idx_flipped = mask_flipped.argmax(axis=0)
    any_nonzero = mask.any(axis=0)
    original_idx = (voxel_array.shape[0] - 1) - idx_flipped
    result = np.where(any_nonzero, original_idx, -1)

    return np.array(result)
