-
Notifications
You must be signed in to change notification settings - Fork 117
Metrics
A loss function or metric (or objective function, or optimization score function) is a scoring function to evaluate the current predictive power and performance of a model.
A loss function is required for training and have to be decreasing, if the model performance is increasing. During the training process, the neural network model varies weights of its neurons and tries to optimize the loss function to be as small as possible. A model can only use one loss function.
Metrics are for user evaluation in order to give insights on the training process or the current performance status of the model. It is possible to pass multiple metrics to the model.
MIScnn loss functions and metrics are based on Keras loss/metric functions.
Any loss or metric function defined in Keras, in miscnn.neural_network.metrics or any custom function, which follows the Keras metric guidelines, can be used in MIScnn.
The loss function and metrics can be defined at the neural network model class initialization.
It is possible to pass the desired loss function with the 'loss' tag and the metrics within a standard python list with the 'metrics' tag.
# Import desired loss functions or metrics
from miscnn.neural_network.metrics import tversky_loss, dice_soft
import keras
# Add the loss function & metrics to the neural network model
model = Neural_Network(preprocessor=pp,
loss=tversky_loss,
metrics=[dice_soft, keras.losses.categorical_crossentropy])
If no loss or metrics are provided, MIScnn uses the Tversky loss function and no metrics as default.
A generalized loss function based on the Tversky index to address the issue of data imbalance and achieve much better trade-off between precision and recall in training 3D fully convo- lutional deep neural networks.
Reference: https://arxiv.org/abs/1706.05721
from miscnn.neural_network.metrics import tversky_loss
model = Neural_Network(preprocessor=pp, loss=tversky_loss)
Based on the idea of Fabian Isensee et al. for using the sum of the Dice Similarity Coefficient and the Cross-Entropy, MIScnn implemented a loss function based on the sum of the Tversky loss & Cross-Entropy loss function.
Reference Fabian Isensee et al: http://arxiv.org/abs/1809.10486
from miscnn.neural_network.metrics import tversky_crossentropy
model = Neural_Network(preprocessor=pp, loss=tversky_crossentropy)
The Dice Similarity Coefficient is one the most popular loss functions for training deep learning models in medical image segmentation. It has the ability the handle strong class imbalance which is common in medical imaging. The standard Dice Similarity Coefficient is suited for binary medical image segmentation problems.
Reference: -> add wikipedia link
from miscnn.neural_network.metrics import dice_coefficient_loss
model = Neural_Network(preprocessor=pp, loss=dice_coefficient_loss)
The Soft Dice Similarity Coefficient is an extension of the standard Dice Similarity Coeffcient. The only difference is, that the soft DSC is normalized on the number of classes. Therefore, the soft Dice Similarity Coefficient is more suited for multi-class (>2 classes) medical image segmentation problems.
Reference: -> add wikipedia link
from miscnn.neural_network.metrics import dice_soft_loss
model = Neural_Network(preprocessor=pp, loss=dice_soft_loss)
In diverse medical image segmentation challenges, the winner Fabian Isensee et al. is always using the sum of the soft Dice Similarity Coeffcient and the Cross-Entropy in order to achieve the best performance. Additionally, Fabian Isensee et al. also uses this loss function in his powerful software nnUnet.
Reference: http://arxiv.org/abs/1809.10486
from miscnn.neural_network.metrics import dice_crossentropy
model = Neural_Network(preprocessor=pp, loss=dice_crossentropy)
The authors Yeung et al. implemented various common and widely used loss functions as well as proposed the Unified Focal loss, a new hierarchical framework that generalises Dice and cross entropy-based losses for handling class imbalance.
List of loss functions:
- Combo loss
- Focal Tversky loss (symmetric and asymmetric)
- Focal loss (symmetric and asymmetric)
- Unified Focal loss (symmetric and asymmetric)
Authors: Michael Yeung, Evis Sala, Carola-Bibiane Schönlieb, Leonardo Rundo
Implementation: https://github.com/mlyg/unified-focal-loss
Reference: https://arxiv.org/abs/2102.04525
from miscnn.neural_network.metrics import *
metric_list = [combo_loss,
focal_tversky_loss,
symmetric_focal_loss,
symmetric_focal_tversky_loss,
asymmetric_focal_loss,
asymmetric_focal_tversky_loss,
sym_unified_focal_loss,
asym_unified_focal_loss]
model = Neural_Network(preprocessor=pp, loss=combo_loss,
metrics=metric_list)
Home | Installation | Usage | Examples | Contact
Getting Started
Documentation - Core
Documentation - Interfaces
Documentation - Extras
Other