-
Notifications
You must be signed in to change notification settings - Fork 121
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
How to find 5 labels using Dice Loss Layer #46
Comments
You can change the network to output a 4D array that has 6 channels (one for each of the 5 labels and one for background) and do a softmax across 6 labels. You can then change the dice calculation to calculate the dice for each of the 6 labels and sum those.
I forget if VNET maximizes the loss or if they take the negative of dice and minimize that… you’ll have to deal with that appropriately.
… On Nov 21, 2017, at 4:17 PM, Sajid Iqbal ***@***.***> wrote:
Hi,
I am working on BRATS data that need 5 labels. but dice loss layer outputs 2 labels, how to get 5 labels using dice loss layer.
Best
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub <#46>, or mute the thread <https://github.com/notifications/unsubscribe-auth/AKLnc3xveYo_XddTspAAoWz53ZHl2OQvks5s4z3OgaJpZM4Qmf7->.
|
Hi, gattia, |
Argmax isn’t differentiable so it won’t work.
… On Nov 21, 2017, at 4:37 PM, Sajid Iqbal ***@***.***> wrote:
Hi, gattia,
Thanks for reply. If if get 6 channels at the end and then apply argmax to get the maximum of each channel to get one image and then use that image to calculate Dice loss, will it be fine?
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub <#46 (comment)>, or mute the thread <https://github.com/notifications/unsubscribe-auth/AKLnc3vTAAiWTo4JjO43gGC-UIYarZ_jks5s40KDgaJpZM4Qmf7->.
|
Have a look at generalized dice in niftynet.
… On Nov 21, 2017, at 1:43 PM, Anthony ***@***.***> wrote:
Argmax isn’t differentiable so it won’t work.
> On Nov 21, 2017, at 4:37 PM, Sajid Iqbal ***@***.***> wrote:
>
> Hi, gattia,
> Thanks for reply. If if get 6 channels at the end and then apply argmax to get the maximum of each channel to get one image and then use that image to calculate Dice loss, will it be fine?
>
> —
> You are receiving this because you commented.
> Reply to this email directly, view it on GitHub <#46 (comment)>, or mute the thread <https://github.com/notifications/unsubscribe-auth/AKLnc3vTAAiWTo4JjO43gGC-UIYarZ_jks5s40KDgaJpZM4Qmf7->.
>
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub <#46 (comment)>, or mute the thread <https://github.com/notifications/unsubscribe-auth/AMtsvvqNKxE6hPIjO5cz6cXQSu_2uckzks5s40QagaJpZM4Qmf7->.
|
Hi,
|
Hi faustomilletari, |
Im not responding about nifty net but instead about your other post. We can't know much about the prediction you printed without a scale attached. I assume black is 0s and red and blue are different numbers completely. But that doesnt matter too much. Here are my suggestions: For your loss. I dont use caffe, so im not sure about the forward/backward pass code you've written and if you know something I dont know about differentiating losses.... but as far as I'm aware you can't use argmax because it is not differentiable. Your loss function must be differentiable to be able to propagate the error back through the network and learn properly. From your actual loss function, it looks like dimension 1 is the dimension with the different labels. If you want to predict all 5 of your labels, you first need to:
Here is a link to a repository I just added with some code to do: 1) hot encoding, 2) softmax, 3) multi-label dice. These are rough adaptations of code I had written for a different purpose that used Keras/Tensorflow. So they might not work immediately but are pretty close. They assume you have 4D stacks of images with the first dimension being different images, and the remaining three dimensions being the 3-dimensions of the actual MRI or CT or whatever. The codes will then assume you are turning these 4d images into 5 dimensions with the second dimension (dimension 1) being the different labels. As @faustomilletari said, there are other published ways to deal with multiple labels at a time using specific dice measures, but this is a method that I found reasonable and it worked in some testing that I did. You could advance it by adding weights that are associated with each label. Higher weights would be associated with more important labels in the segmentation process. |
Hi, @gattia |
I'm not sure if you are confused about the actual one-hot-encoding or about the fact that the dice is calculated using integer values from ground-truth data and a decimal of some sort from the prediction of the network. If it's the one-hot-encoding, the first thing you should be doing is to one-hot-encoding the ground truth. After you run the one-hot-encoding function I included, each channel should have only 0's and 1's. And the channel number should coincide with the label of interest. So, instead of you having 2's wherever there is a tumour (I'm making this example up) you will have 1's on the second channel. Everywhere that there isn't a tumour should be 0s (on that same second channel). If it's the fact that the network outputs a decimal (between 0 and 1) while the ground truth is either a 0 or 1. This is how it learns. As the decimal gets closer and closer to the correct value (0 or 1 depending on the case) the dice score get's better and better. So, when you are done creating a segmentation, you will have to decide at what threshold a pixel should be considered to be part of a particular tissue of interest. Typically, if the prediction is >0.5 I make it that tissue, If it's neither of these, you'll have to re-specify the problem because I dont understand. |
Hi,
I am working on BRATS data that need 5 labels. but dice loss layer outputs 2 labels, how to get 5 labels using dice loss layer.
Best
The text was updated successfully, but these errors were encountered: