I am working on a binary segmentation problem for which I have to segment the lesions using an automated breast ultrasound system (ABUS) data set. I am using binary cross entropy as loss function with U-Net CNN model. The resultant images got blurry effects. The more number of epochs I run the experiment, the more blurriness occurs. What leads to result such blurry effect and what change should I make to my model to get rid of that?
@dknurfaizah Welcome to Tensorflow Forum!
The blurry effect in your binary segmentation results using the U-Net CNN model is likely due to overfitting. Overfitting occurs when the model learns the training data too well and fails to generalize to new data. This can lead to overly smooth and inaccurate predictions, especially at object boundaries.
To mitigate overfitting and improve the sharpness of your segmentation results, you can consider the following strategies:
- Data Augmentation: Expand your training dataset by applying data augmentation techniques, such as random cropping, flipping, and rotating the images. This will provide the model with more diverse training examples and help it learn more generalizable features.
- L2 Regularization: Add L2 regularization to the loss function to penalize large weights in the model. This will discourage the model from overfitting to the training data and encourage it to learn more robust features.
- Early Stopping: Implement early stopping to halt training when the validation loss stops improving. This will prevent the model from overfitting on the training data and improve its generalization performance.
- Dropout: Apply dropout regularization to the network architecture. Dropout randomly drops neurons during training, forcing the model to learn redundant features and reducing overfitting.
- Sharpen Predictions: Post-process the segmentation results to sharpen the boundaries. Techniques like morphological operations, edge detection, and conditional random fields can help refine the segmentation masks.
- Optimize Hyperparameters: Carefully tune the hyperparameters, such as learning rate, batch size, and optimizer settings, to find the optimal combination that balances training accuracy with generalization performance.
By implementing these strategies, you can effectively address the blurry effect in your binary segmentation results and obtain sharper, more accurate predictions from your U-Net CNN model.
Let us know if this helps!
got unet
Fitting model…
Train on 120 samples, validate on 30 samples
Epoch 1/5
120/120 [==============================] - 32s 263ms/step - loss: 0.6921 - acc: 0.9622 - val_loss: 0.6903 - val_acc: 0.9790
Epoch 00001: loss improved from inf to 0.69209, saving model to unet.hdf5
Epoch 2/5
120/120 [==============================] - 22s 187ms/step - loss: 0.6889 - acc: 0.9751 - val_loss: 0.6874 - val_acc: 0.9790
Epoch 00002: loss improved from 0.69209 to 0.68893, saving model to unet.hdf5
Epoch 3/5
120/120 [==============================] - 23s 191ms/step - loss: 0.6861 - acc: 0.9751 - val_loss: 0.6846 - val_acc: 0.9790
Epoch 00003: loss improved from 0.68893 to 0.68609, saving model to unet.hdf5
Epoch 4/5
120/120 [==============================] - 23s 194ms/step - loss: 0.6833 - acc: 0.9751 - val_loss: 0.6818 - val_acc: 0.9790
Epoch 00004: loss improved from 0.68609 to 0.68327, saving model to unet.hdf5
Epoch 5/5
120/120 [==============================] - 24s 197ms/step - loss: 0.6805 - acc: 0.9751 - val_loss: 0.6789 - val_acc: 0.9790
Epoch 00005: loss improved from 0.68327 to 0.68047, saving model to unet.hdf5
predict test data
150/150 [==============================] - 12s 80ms/step
hello there, i want to ask why my segmentation result keep maintaining the accuracy result?