-
Notifications
You must be signed in to change notification settings - Fork 101
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
Training centered_instance model with input_scaling < 1.0 #1993
Comments
Hi! (I also worked with autocrop, tried changing that, scaling the input and it still didn't work.)
...
|
Hi @BenjaminBo, We are working to fix this. In the mean time, what happens when you only use input scaling for the centroid model? """ The centroid model will always result in cropping around the animal instance. Are the features on your animal very small compared to the animal itself? This would be the only time when the centered-instance model needs input scaling < 1. Best, Elizabeth |
Hey @eberrigan,
as I wrote in my bug description:
But since I can't (at least not that I am aware of) chain the centroid and centered instance models together, so as to have the centorid output be the centered instance input during training, it isn't really helping me for centered instance. I have also tried this in one of the configs:
, but that doesn't work either. Other than that I wrote the following function, the goal of which it is to scale a labels dataset. I am not sure I understood the whole
This works! It runs through and I am generating an output When trying to load the data though, I get the following issue:
, which I don't know what to do with. |
Hey @eberrigan ,
The answer is yes, they are pretty small. I really think being able to scale my input images down a bit would really help. As as an addition to my code in my message before and the Thank you for your help :) |
Hi @BenjaminBo, Apologies for the delay! We are working on fixing the 1. Error while visualizing the results during trainingThank you for your analysis! The error isn't because of scaling being applied twice.
2. Error during inference after training is done
We've created a PR #2054 to fix both the above errors! Let us know if you have any more questions! Thanks, Divya |
Hi all, I just discovered this issue. I think I'm struggling with similar problems but currently for the single animal case. I used the approach linked below to attempt to downsize the input images but it occurs to me that the labels need to be downsized as well now. I see that this is being discouraged above. Is there a timeline for when a streamlined in-house SLEAP fix is planned to be released? This is currently bottlenecking my usage of the library. Here's a link to my approach: #2085 (comment) |
Bug description
I am training the topdown model remotely on a cluster server, since I don't have a local GPU to properly train a sleap model on.
My videos are pretty high in dimensionalilty (2160, 3840, 3), not allowing me to train in their original size. Which brings me to the
input_size
parameter:For the centroid model everything works fine. I can set the input scale to <1.0 and it runs without issues.
Running the centered_instance model though, is when I get the following error (here with
input_scale = 0.4
):This is interesting, because the non-scaled input size, with
auto_crop
on, is 3840.Assumption 1
What seems to be happening is that
input_scaling
is applied twice, since3840 * 0,4 = 1536 and
1536 * 0,4 = 614 (rounded).
So I try to find the section where it is applied repetitively.
Following the error message above I looked at the following code section in #sleap/nn/training.py, line 1315-1340:
, more specifically:
Assumption 2
This might be the section that applies the scaling factor repetitively.
It also seems to be "less relevant", since I understand it to be a section handling visualization only.
I adjust line 1318 in the following way:
As opposed to before, the training runs through now. But I get the following error next:
This is where I get confused.
This suggest that the section before might've not only been handling visual issues? Or that the problem runs deeper? But the error above only happens after training, not in between epochs.
At this point there, must've been images from both the training- and validation-set of size 1536 running through the model, unless I understand something wrong. Why did I not get errors then? Also: are the assumptions that I made above incorrect?
Scaling
Also at this point I am not sure if I am addressing my core issue. I want to scale the input data down. I do not want to crop it (which works with an input_scale of 1.0). The reason being that I need all of the information in the frames.
input_scaling
. I will try to further understand the error above and maybe adjust your code in a way to make it work for me, but I am not sure if I can. Can you help me with the issues that I described above?Labels()
-object. My problem is that I am a bit overwhelmed and not quite sure where to start, since the object looks like this:Meaning, there are quite a few attributes in this object, some containing frames, instances and bounding_boxes. I am just not sure which I'd have to scale and which I shouldn't touch. Do you have a function/ a simpler way for me to use to scale the dataset?
3. There doesn't seem to be a way to scale the data in sleap-label (which is where I created my ground truth and where I created and exported my dataset). I want to avoid to go all the way back to the original videos and scale them down, because I'd have to relable all of the hundreds of instances I have now.
The text was updated successfully, but these errors were encountered: