Skip to content
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

Allow ByteTrack to track detections without IDs #1582

Closed
LinasKo opened this issue Oct 9, 2024 · 15 comments
Closed

Allow ByteTrack to track detections without IDs #1582

LinasKo opened this issue Oct 9, 2024 · 15 comments
Assignees
Labels
enhancement New feature or request hacktoberfest Open for contributions during the annual Hacktoberfest event, aimed at encouraging open-source parti help wanted Extra attention is needed

Comments

@LinasKo
Copy link
Contributor

LinasKo commented Oct 9, 2024

Allow ByteTrack to track detections without IDs

Tip

Hacktoberfest is calling! Whether it's your first PR or your 50th, you’re helping shape the future of open source. Help us build the most reliable and user-friendly computer vision library out there! 🌱

For a long time, all of models we support would return a class_id which we set inside Detections (class_id is an array of N integers). However, we've seen more and more models where that isn't provided.

ByteTrack allows you to track objects in the scene. It uses the class and location of the detection to figure out where it is. It can track objects where all class IDs are the same. However, if you try passing something without an ID, it will fail. See this Colab.

Let's change ByteTrack so it can track detections, even if they didn't have a class_id. I see two ways of doing this:

  1. Change the algorithm such that class_ids are not required
  2. Set an internal class ID such as -1.

As a result, I expect the videos produced in the Colab to be visually indistinguishable.

It would also be useful to test on a video where some frames feature no detections (you can simulate with detections = sv.Detections.empty())

Also, check what happens when some detections have class_id and some do not.


Helpful links:

@LinasKo LinasKo added help wanted Extra attention is needed hacktoberfest Open for contributions during the annual Hacktoberfest event, aimed at encouraging open-source parti labels Oct 9, 2024
@LinasKo
Copy link
Contributor Author

LinasKo commented Oct 9, 2024

Contribution guidelines

If you would like to make a contribution, please check that no one else is assigned already. Then leave a comment such as "Hi, I would like to work on this issue". We're happy to answer any questions about the task even if you choose not to contribute.

Testing

Please share a Google Colab with minimal code to test the new feature. We know it's additional work, but it will speed up the review process. You may use the Starter Template. The reviewer must test each change. Setting up a local environment to do this is time-consuming. Please ensure that Google Colab can be accessed without any issues (make it public). Thank you! 🙏

@Kadermiyanyedi
Copy link
Contributor

Hi, I would like to work on this issue. :)

@LinasKo LinasKo added the enhancement New feature or request label Oct 9, 2024
@onuralpszr
Copy link
Collaborator

@Kadermiyanyedi task is yours, good luck ;)

@Kadermiyanyedi
Copy link
Contributor

Hi,

I apologize for the delay. I couldn't work on the issue last week due to a busy schedule, but I've started it now. I'll submit a PR in a few days.

Thank you for your patience!

@LinasKo
Copy link
Contributor Author

LinasKo commented Oct 14, 2024

Hi @Kadermiyanyedi 👋

Thanks for letting me know! Feel free to take your time.

Your submissions are always of a very high quality so I'm happy either way, even if it takes longer :)

@AyuK03
Copy link

AyuK03 commented Oct 16, 2024

Hi, I would like to work on this issue

@onuralpszr
Copy link
Collaborator

Hi, I would like to work on this issue

This issue has taken already and if something changed we can but for now @Kadermiyanyedi is going the task, thank you for understanding

@LinasKo
Copy link
Contributor Author

LinasKo commented Oct 18, 2024

Hi @Kadermiyanyedi,

Quick note, there's been a few updates on the tracker today:

I expect some merge conflicts; I'l leave it up to you if you want to handle them. If it proves beyond what you planned for this PR - feel free to complete the task with the current base, and I'll resolve any clashes.

@LinasKo
Copy link
Contributor Author

LinasKo commented Oct 18, 2024

Another update: It may be possible to just remove class_ids from STracks entirely. I didn't see it being used anywhere, nor does it appear in the original ByteTrack implementation.

@Kadermiyanyedi
Copy link
Contributor

If it's not used anywhere, we can remove it.

I initialized a new NumPy array filled with -1 values in case the detections.class_id is None. The new array has the same length as detections.xyxy. The code runs correctly, but I'm not seeing the detected objects in the output, and I'm currently investigating this issue.

If we don't need the class id, I will remove and open PR quickly.

def detections2boxes(detections: Detections) -> np.ndarray:
    num_rows = detections.xyxy.shape[0]

    class_ids = np.full(num_rows, -1)
    if detections.class_id is not None:
        class_ids = detections.class_id
    return np.hstack(
        (
            detections.xyxy,
            detections.confidence[:, np.newaxis],
            class_ids[:, np.newaxis],
        )
    )

@LinasKo
Copy link
Contributor Author

LinasKo commented Oct 18, 2024

I recall seeing -1 as a special temporary value somewhere.
Are detections also gone when you use -2, or some large positive integer?

@Kadermiyanyedi
Copy link
Contributor

I recall seeing -1 as a special temporary value somewhere. Are detections also gone when you use -2, or some large positive integer?

unfortunately it is same

@Kadermiyanyedi
Copy link
Contributor

@LinasKo Hi, I hope you're doing well.

The changes I made worked. I noticed an error in the test code later and confirmed the changes were working before opening the PR. I also fixed the code conflicts.

I was excitedly waiting for your feedback!

@LinasKo
Copy link
Contributor Author

LinasKo commented Oct 23, 2024

Thank you @Kadermiyanyedi!

I'm away at the moment and will be back around next Wednesday; I'll review it then.

Thank you for your contribution!

@LinasKo
Copy link
Contributor Author

LinasKo commented Nov 4, 2024

This is now completed. Thanks @Kadermiyanyedi!

@LinasKo LinasKo closed this as completed Nov 4, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request hacktoberfest Open for contributions during the annual Hacktoberfest event, aimed at encouraging open-source parti help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

4 participants