darts_ensemble.EnsembleV1¶
DARTS v1 ensemble based on a list of models.
Initialize the ensemble.
Parameters:
-
model_dict
(dict
) –The paths to model checkpoints to ensemble, the key is should be a model identifier to be written to outputs.
-
device
(torch.device
, default:darts_ensemble.ensemble_v1.DEFAULT_DEVICE
) –The device to run the model on. Defaults to torch.device("cuda") if cuda is available, else torch.device("cpu").
Source code in darts-ensemble/src/darts_ensemble/ensemble_v1.py
models
instance-attribute
¶
models = {
k: darts_segmentation.segment.SMPSegmenter(
v,
device=darts_ensemble.ensemble_v1.EnsembleV1(
device
),
)
for (k, v) in model_paths.items()
}
__call__
¶
__call__(
input: xarray.Dataset | list[xarray.Dataset],
patch_size: int = 1024,
overlap: int = 16,
batch_size: int = 8,
reflection: int = 0,
keep_inputs: bool = False,
) -> xarray.Dataset
Run the ensemble on the given tile.
Parameters:
-
input
(xarray.Dataset | list[xarray.Dataset]
) –A single tile or a list of tiles.
-
patch_size
(int
, default:1024
) –The size of the patches. Defaults to 1024.
-
overlap
(int
, default:16
) –The size of the overlap. Defaults to 16.
-
batch_size
(int
, default:8
) –The batch size for the prediction, NOT the batch_size of input tiles. Tensor will be sliced into patches and these again will be infered in batches. Defaults to 8.
-
reflection
(int
, default:0
) –Reflection-Padding which will be applied to the edges of the tensor. Defaults to 0.
-
keep_inputs
(bool
, default:False
) –Whether to keep the input probabilities in the output. Defaults to False.
Returns:
Raises:
-
ValueError
–in case the input is not an xr.Dataset or a list of xr.Dataset
Source code in darts-ensemble/src/darts_ensemble/ensemble_v1.py
segment_tile
¶
segment_tile(
tile: xarray.Dataset,
patch_size: int = 1024,
overlap: int = 16,
batch_size: int = 8,
reflection: int = 0,
keep_inputs: bool = False,
) -> xarray.Dataset
Run inference on a tile.
Parameters:
-
tile
(xarray.Dataset
) –The input tile, containing preprocessed, harmonized data.
-
patch_size
(int
, default:1024
) –The size of the patches. Defaults to 1024.
-
overlap
(int
, default:16
) –The size of the overlap. Defaults to 16.
-
batch_size
(int
, default:8
) –The batch size for the prediction, NOT the batch_size of input tiles. Tensor will be sliced into patches and these again will be infered in batches. Defaults to 8.
-
reflection
(int
, default:0
) –Reflection-Padding which will be applied to the edges of the tensor. Defaults to 0.
-
keep_inputs
(bool
, default:False
) –Whether to keep the input probabilities in the output. Defaults to False.
Returns:
-
xarray.Dataset
–Input tile augmented by a predicted
probabilities
layer with type float32 and range [0, 1].
Source code in darts-ensemble/src/darts_ensemble/ensemble_v1.py
segment_tile_batched
¶
segment_tile_batched(
tiles: list[xarray.Dataset],
patch_size: int = 1024,
overlap: int = 16,
batch_size: int = 8,
reflection: int = 0,
keep_inputs: bool = False,
) -> list[xarray.Dataset]
Run inference on a list of tiles.
Parameters:
-
tiles
(list[xarray.Dataset]
) –The input tiles, containing preprocessed, harmonized data.
-
patch_size
(int
, default:1024
) –The size of the patches. Defaults to 1024.
-
overlap
(int
, default:16
) –The size of the overlap. Defaults to 16.
-
batch_size
(int
, default:8
) –The batch size for the prediction, NOT the batch_size of input tiles. Tensor will be sliced into patches and these again will be infered in batches. Defaults to 8.
-
reflection
(int
, default:0
) –Reflection-Padding which will be applied to the edges of the tensor. Defaults to 0.
-
keep_inputs
(bool
, default:False
) –Whether to keep the input probabilities in the output. Defaults to False.
Returns:
-
list[xarray.Dataset]
–A list of input tiles augmented by a predicted
probabilities
layer with type float32 and range [0, 1].