You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

34 lines
1.2 KiB

11 months ago
import torch
def weighted_loss(inputs, outputs, alpha):
# Calculate RGB Norm (Perceptual Difference)
rgb_norm = torch.norm(inputs[:, None, :] - inputs[None, :, :], dim=-1)
# Calculate 1D Space Norm
transformed_norm = torch.norm(outputs[:, None] - outputs[None, :], dim=-1)
# Weighted Loss
loss = alpha * rgb_norm + (1 - alpha) * transformed_norm
return torch.mean(loss)
def enhanced_loss(inputs, outputs, alpha, distinct_threshold):
# Calculate RGB Norm
rgb_norm = torch.norm(inputs[:, None, :] - inputs[None, :, :], dim=-1)
# Calculate 1D Space Norm
transformed_norm = torch.norm(outputs[:, None] - outputs[None, :], dim=-1)
# Identify Distinct Colors (based on a threshold in RGB space)
distinct_colors = rgb_norm > distinct_threshold
# Penalty for Distinct Colors being too close in the transformed space
11 months ago
# Here we do not take the mean yet, to avoid double averaging
distinct_penalty = (1.0 / (transformed_norm + 1e-6)) * distinct_colors
11 months ago
# Combined Loss
11 months ago
# The mean is taken here, once, after all components are combined
loss = alpha * rgb_norm + (1 - alpha) * transformed_norm + distinct_penalty
11 months ago
return torch.mean(loss)