import numpy as np

def verify_masking_logic():
    # 1. Create a dummy attribution map [Time=10, Channels=1]
    # We include some duplicate values (0.2) to test robustness
    attr_map = np.array([0.1, 0.9, 0.2, 0.2, 0.3, 0.7, 0.4, 0.6, 0.5, 1.0])
    print(f"Original Map: {attr_map}")

    # 2. Define k (20% for this example)
    k_percent = 0.5
    flat_attr = attr_map.flatten()
    num_to_mask = int(len(flat_attr) * k_percent) # 20% of 10 elements = 2

    # 3. Use np.argpartition to find the INDICES of the smallest elements
    # argpartition returns an array where the element at index num_to_mask 
    # is in its sorted position, and all elements to the left are smaller.
    low_importance_indices = np.argpartition(flat_attr, num_to_mask)[:num_to_mask]
    # print(low_importance_indices)
    # exit()

    print(f"Number of elements to mask: {num_to_mask}")
    print(f"Indices chosen for masking: {low_importance_indices}")
    print(f"Values being masked: {flat_attr[low_importance_indices]}")

    # 4. Generate the Mask
    mask_flat = np.ones_like(flat_attr, dtype=np.float32)
    mask_flat[low_importance_indices] = 0.0
    mask = mask_flat.reshape(attr_map.shape)

    print(f"Generated Mask: {mask}")
    
    # 5. Final Verification
    masked_count = int(np.sum(mask == 0))
    print(f"Verification: {masked_count} elements were masked (Goal: {num_to_mask}).")

if __name__ == "__main__":
    verify_masking_logic()
