# Original implementation: https://github.com/abaisero/asym-rlpo
#
####
#
# Extended to informed POMDPs by anonymous authors (2025)
#
####

from typing import Sequence

import torch

# Compute the mean value within a sequence
def average(data: Sequence[torch.Tensor]) -> torch.Tensor:
    return sum(data, start=torch.tensor(0.0)) / len(data)

# Compute the variance within a sequence
def variance(data: Sequence[torch.Tensor]) -> torch.Tensor:
    mean = average(data)
    return sum((x - mean).pow(2) for x in data) / (len(data) - 1)