Average#
- 
class ignite.metrics.Average(output_transform=<function Average.<lambda>>, device=device(type='cpu'))[source]#
- Helper class to compute arithmetic average of a single variable. - updatemust receive output of the form x.
- x can be a number or torch.Tensor. 
 - Note - Number of samples is updated following the rule: - +1 if input is a number 
- +1 if input is a 1D torch.Tensor 
- +batch_size if input is an ND torch.Tensor. Batch size is the first dimension (shape[0]). 
 - For input x being an ND torch.Tensor with N > 1, the first dimension is seen as the number of samples and is summed up and added to the accumulator: accumulator += x.sum(dim=0) - Examples: - evaluator = ... custom_var_mean = Average(output_transform=lambda output: output['custom_var']) custom_var_mean.attach(evaluator, 'mean_custom_var') state = evaluator.run(dataset) # state.metrics['mean_custom_var'] -> average of output['custom_var'] - Parameters
- output_transform (Callable) – a callable that is used to transform the - Engine’s- process_function’s output into the form expected by the metric. This can be useful if, for example, you have a multi-output model and you want to compute the metric with respect to one of the outputs.
- device (Union[str, torch.device]) – specifies which device updates are accumulated on. Setting the metric’s device to be the same as your - updatearguments ensures the- updatemethod is non-blocking. By default, CPU.
 
 - Methods - Attaches current metric to provided engine. - Helper method to compute metric’s value and put into the engine. - Computes the metric based on it’s accumulated state. - Detaches current metric from the engine and no metric’s computation is done during the run. - Checks if current metric is attached to provided engine. - Helper method to update metric’s computation. - Resets the metric to it’s initial state. - Helper method to start data gathering for metric’s computation. - Updates the metric’s state using the passed batch output. - 
attach(engine, name, usage=<ignite.metrics.metric.EpochWise object>)#
- Attaches current metric to provided engine. On the end of engine’s run, engine.state.metrics dictionary will contain computed metric’s value under provided name. - Parameters
- engine (ignite.engine.engine.Engine) – the engine to which the metric must be attached 
- name (str) – the name of the metric to attach 
- usage (Union[str, ignite.metrics.metric.MetricUsage]) – the usage of the metric. Valid string values should be - ignite.metrics.metric.EpochWise.usage_name(default) or- ignite.metrics.metric.BatchWise.usage_name.
 
- Return type
 - Example: - metric = ... metric.attach(engine, "mymetric") assert "mymetric" in engine.run(data).metrics assert metric.is_attached(engine) - Example with usage: - metric = ... metric.attach(engine, "mymetric", usage=BatchWise.usage_name) assert "mymetric" in engine.run(data).metrics assert metric.is_attached(engine, usage=BatchWise.usage_name) 
 - 
completed(engine, name)#
- Helper method to compute metric’s value and put into the engine. It is automatically attached to the engine with - attach(). If metrics’ value is torch tensor, it is explicitly sent to CPU device.- Parameters
- engine (ignite.engine.engine.Engine) – the engine to which the metric must be attached 
- name (str) – the name of the metric used as key in dict engine.state.metrics 
 
- Return type
 - Changed in version 0.4.3: Added dict in metrics results. - Changed in version 0.4.5: metric’s value is put on CPU if torch tensor. 
 - 
compute()[source]#
- Computes the metric based on it’s accumulated state. - By default, this is called at the end of each epoch. - Returns
- the actual quantity of interest. However, if aMappingis returned, it will be (shallow) flattened into engine.state.metrics whencompleted()is called.
- Return type
- Any 
- Raises
- NotComputableError – raised when the metric cannot be computed. 
 
 - 
detach(engine, usage=<ignite.metrics.metric.EpochWise object>)#
- Detaches current metric from the engine and no metric’s computation is done during the run. This method in conjunction with - attach()can be useful if several metrics need to be computed with different periods. For example, one metric is computed every training epoch and another metric (e.g. more expensive one) is done every n-th training epoch.- Parameters
- engine (ignite.engine.engine.Engine) – the engine from which the metric must be detached 
- usage (Union[str, ignite.metrics.metric.MetricUsage]) – the usage of the metric. Valid string values should be ‘epoch_wise’ (default) or ‘batch_wise’. 
 
- Return type
 - Example: - metric = ... engine = ... metric.detach(engine) assert "mymetric" not in engine.run(data).metrics assert not metric.is_attached(engine) - Example with usage: - metric = ... engine = ... metric.detach(engine, usage="batch_wise") assert "mymetric" not in engine.run(data).metrics assert not metric.is_attached(engine, usage="batch_wise") 
 - 
is_attached(engine, usage=<ignite.metrics.metric.EpochWise object>)#
- Checks if current metric is attached to provided engine. If attached, metric’s computed value is written to engine.state.metrics dictionary. - Parameters
- engine (ignite.engine.engine.Engine) – the engine checked from which the metric should be attached 
- usage (Union[str, ignite.metrics.metric.MetricUsage]) – the usage of the metric. Valid string values should be ‘epoch_wise’ (default) or ‘batch_wise’. 
 
- Return type
 
 - 
iteration_completed(engine)#
- Helper method to update metric’s computation. It is automatically attached to the engine with - attach().- Note - engine.state.outputis used to compute metric values. The majority of implemented metrics accepts the following formats for- engine.state.output:- (y_pred, y)or- {'y_pred': y_pred, 'y': y}.- y_predand- ycan be torch tensors or list of tensors/numbers if applicable.- Parameters
- engine (ignite.engine.engine.Engine) – the engine to which the metric must be attached 
- Return type
 - Changed in version 0.4.5: - y_predand- ycan be torch tensors or list of tensors/numbers
 - 
reset()#
- Resets the metric to it’s initial state. - By default, this is called at the start of each epoch. - Return type
 
 - 
started(engine)#
- Helper method to start data gathering for metric’s computation. It is automatically attached to the engine with - attach().- Parameters
- engine (ignite.engine.engine.Engine) – the engine to which the metric must be attached 
- Return type
 
 - 
update(output)#
- Updates the metric’s state using the passed batch output. - By default, this is called once for each batch. - Parameters
- output (Union[float, torch.Tensor]) – the is the output from the engine’s process function. 
- Return type