probly.representation.credal_set.torch.TorchProbabilityIntervalsCredalSet

class probly.representation.credal_set.torch.TorchProbabilityIntervalsCredalSet(lower_bounds: Tensor, upper_bounds: Tensor)[source]

Bases: TorchAxisProtected[Any], TorchCategoricalCredalSet, ProbabilityIntervalsCredalSet

Credal set represented by lower/upper categorical bounds.

property T: Self

Inverts the order of the dimensions of the underlying array.

property barycenter: TorchCategoricalDistribution

Return the barycenter of the credal set.

clone(*, memory_format: memory_format = torch.preserve_format) Self[source]

Return a copy of the array.

contains(probabilities: Tensor) Tensor[source]

Check whether probabilities are inside the intervals.

cpu(memory_format: memory_format = torch.preserve_format) Self[source]

Move the array to the CPU.

cuda(device: device | str | None = None, non_blocking: bool = False, memory_format: memory_format = torch.preserve_format) Self[source]

Move the array to the GPU.

detach() Self[source]

Return a detached version of the array.

property device: device

Device of the array.

property dtype: dtype

Data type of the array.

classmethod from_sample(sample: Sample[TorchCategoricalDistribution]) Self[source]

Create a credal set from a finite sample.

Parameters:

sample – The sample to create the credal set from.

Returns:

The created credal set.

classmethod from_torch_sample(sample: TorchSample[TorchCategoricalDistribution]) Self[source]

Create a credal set from categorical distribution samples.

lower_bounds: torch.Tensor
property mH: Self

The adjoint (conjugate) transposed version of the underlying array.

property mT: Self

The transposed version of the underlying array.

property ndim: int

Number of dimensions.

property num_classes: int

Get the number of classes.

numpy(*, force: bool = False) NDArray[Any][source]

Convert to a numpy array.

permitted_functions = {}
permute(*dims: Size | int | tuple[int] | list[int]) Self[source]

Return a permuted version of the array.

classmethod primary_protected_name() str[source]

Return the first protected field (dict order).

protected_axes: ClassVar[dict[str, int]] = {'lower_bounds': 1, 'upper_bounds': 1}
property protected_shape: tuple[int, ...]

Protected trailing shape of the primary field.

protected_value() TorchProtectedValue[source]

Return the primary protected value.

protected_values(func: Callable | None = None) dict[str, TorchProtectedValue] | None[source]

Return all protected field values as-is.

Optionally takes the torch function that triggered the call for context. This can be used to conditionally modify the returned values or prevent them from being accessed.

reshape(*shape: int | tuple[int, ...]) Self[source]

Return a copy with reshaped protected values.

resolve_conj() Self[source]

Return a version of the array with any conjugate operations resolved.

resolve_neg() Self[source]

Return a version of the array with any negation operations resolved.

property shape: tuple[int, ...]

Shape of the array.

size(dim: int | None = None) int | Size[source]

Return the size of the array along the given dimension.

to(*args: Any, **kwargs: Any) Self[source]

Move and/or cast the tensor, mirroring torch.Tensor.to.

to_device(device: Literal['cpu'], /, *, stream: int | Any | None = None) Self[source]

Move the array to a device.

transpose(dim0: int, dim1: int) Self[source]

Return a transposed version of the array.

type = 'categorical'
upper_bounds: torch.Tensor
width() Tensor[source]

Compute interval width for each class.

with_protected_value(value: TorchProtectedValue) Self[source]

Return a copy with a replaced primary protected value.

with_protected_values(values: dict[str, TorchProtectedValue]) Self[source]

Return a copy with updated protected field values.