I am working on a project for object tracking, where I am getting data (distance in mm and amplitude) from a Lidar sensor(Pepperl-Fuchs R2000).
Using OpenGL and C++ I am displaying data in linux machine.
Now I want to group the points in clusters based on distance.
I don't know how to put all the clusters in separate containers in c++?
Is there any possibility that I can use output data from OpenGL as an input data in OpenCV for object tracking?
相关问题
- Sorting 3 numbers without branching [closed]
- How to get the background from multiple images by
- How to compile C++ code in GDB?
- Why does const allow implicit conversion of refere
- Is GLFW designed to use without LWJGL (in java)?
相关文章
- Class layout in C++: Why are members sometimes ord
- How to mock methods return object with deleted cop
- Which is the best way to multiply a large and spar
- C++ default constructor does not initialize pointe
- Selecting only the first few characters in a strin
- What exactly do pointers store? (C++)
- Converting glm::lookat matrix to quaternion and ba
- What is the correct way to declare and use a FILE
You should transform the OpenGL data into OpenCV structures. There are some built-in functions in OpenCV to share data, look here. You also may copy the OpenGL points into a OpenCV
Mat
, or a vector of OpenCVcv::Point3f
. How to do it depends on the OpenGL structure your points are represented in. If you have to convert matrices from OpenGL into OpenCV, take into account that OpenGL stores matrices in column-major order, whereas OpenCV does row-major order.Then, OpenCV provides some (limited) clustering solutions. Depending on your application, k-means may work, but I'd suggest you also look at other clustering techniques, such as QuickShift or DBSCAN.
You can easily map all those data in OpenCV using Map (or [Point_] or [KeyPoint] according to your use 2) function.
After that I would suggest to use DBSCAN because it works based on density and doesn't need number of cluster (because I don't think you can pre-defined number of cluster here) like K-Means.
Note: You may easily find c++ code for DBSCAN on internet.