import numpy as np
import torch

def normalize_shap_values(shap_values):
    """
    Normalize the SHAP values to the range [-1, 1].

    Parameters:
    shap_values (numpy array): SHAP values to be normalized.

    Returns:
    numpy array: Normalized SHAP values in the range [-1, 1].
    """
    # Find the min and max values across all elements of shap_values
    min_val = np.min(shap_values)
    max_val = np.max(shap_values)
    
    # Normalize to range [0, 1]
    normalized_values = (shap_values - min_val) / (max_val - min_val)
    
    # Scale to range [-1, 1]
    normalized_values = 2 * normalized_values - 1
    
    return normalized_values

# Example usage:
# Assuming `shap




# Create a synthetic background dataset
def create_diverse_background(image_size, num_samples=10):
    """
    Create a diverse background dataset with solid colors and random noise.
    
    Args:
        image_size: Tuple (height, width) of the synthetic image.
        num_samples: Number of synthetic images to create.

    Returns:
        Tensor of synthetic images with shape (num_samples, 3, height, width).
    """
    backgrounds = []
    
    # Add solid colors (white, black, gray, etc.)
    solid_colors = [
        (1.0, 1.0, 1.0),  # White
        (0.0, 0.0, 0.0),  # Black
        (0.5, 0.5, 0.5),  # Gray
        (1.0, 0.0, 0.0),  # Red
        (0.0, 1.0, 0.0),  # Green
        (0.0, 0.0, 1.0)   # Blue
    ]
    for color in solid_colors:
        background = torch.tensor(color, dtype=torch.float32).view(3, 1, 1)
        background = background.expand(3, image_size[0], image_size[1])
        backgrounds.append(background)
    
    # Add random noise-based images
    for _ in range(num_samples - len(solid_colors)):
        random_background = torch.rand(3, image_size[0], image_size[1])
        backgrounds.append(random_background)
    
    # Stack all backgrounds into a single tensor
    background_tensor = torch.stack(backgrounds)
    return background_tensor