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

Render-Based Tracking #1467

Merged
merged 120 commits into from
Dec 19, 2024
Merged
Changes from 1 commit
Commits
Show all changes
120 commits
Select commit Hold shift + click to select a range
7a507b3
Merge remote-tracking branch 'upstream/master'
SamFlt Jun 20, 2023
b15541c
Render based tracking module
SamFlt Sep 17, 2024
6affb4b
Add guards for openmp usage, add guards for vpRBKltTracker
SamFlt Sep 18, 2024
aee5e20
Stopped using initClick from vpMbTracker
SamFlt Sep 18, 2024
c604448
Working on visp openmp directive
SamFlt Sep 18, 2024
c5ffc86
Make copy and move assignment operators default for vpRGBa and vpRGBf…
SamFlt Sep 19, 2024
dd16fdc
Removed pragma omp macro as it cannot be reliably used and messes wit…
SamFlt Sep 19, 2024
25635f9
Fix most warnings from the initial commit
SamFlt Sep 19, 2024
635acf8
Added C++17 checks to ensure that vpRGBa and vpRGBf are trivially cop…
SamFlt Sep 19, 2024
9e5c1b7
Moved klt parameters json serialization to vpKltOpencv, working on be…
SamFlt Sep 19, 2024
f14d375
Group classes in doxygen, settings for klt tracker~
SamFlt Sep 19, 2024
90e288f
Update panda3D install documentation
SamFlt Sep 19, 2024
61856bf
Add namespace guards so that compiling with namespace is supported
SamFlt Sep 19, 2024
1ca277f
Try to fix include guards for trivially copyable in vprgba/vprgbf
SamFlt Sep 19, 2024
bf8b14c
Fix serialization issue with klt tracker
SamFlt Sep 19, 2024
f8308a0
More settings getters and setters
SamFlt Sep 19, 2024
2c12e9c
Fix build issues, compiling with Python bindings on
SamFlt Sep 20, 2024
8839bc3
Merge branch 'master' into module_rbt_fs
fspindle Sep 20, 2024
924019a
Merge branch 'cmake_system_include_dirs' into module_rbt_fs
fspindle Sep 20, 2024
b2fb0a0
Fix warning: field 'enableRenderProfiling' will be initialized after …
fspindle Sep 20, 2024
be51bd2
Fix warnings: unused variable and comparison of integers of different…
fspindle Sep 20, 2024
87f4958
Fix warning: delete called on non-final 'vpColorHistogramMask' that h…
fspindle Sep 20, 2024
af259d6
Fix warning: 'loadJsonConfiguration' overrides a member function but …
fspindle Sep 20, 2024
50ab251
Fix warning: private field 'm_normalAcceptanceThresholdDeg' is not used
fspindle Sep 20, 2024
3938d71
Fix warning: delete called on non-final 'vpRBDenseDepthTracker, vpRBF…
fspindle Sep 20, 2024
f2e907b
Update with new headers
fspindle Sep 20, 2024
718ffa3
Covariance computation initial pass
SamFlt Sep 20, 2024
682190e
Remove prints related to covariance
SamFlt Sep 20, 2024
a8bc61f
Introduce plane initialization from a point and the normal of the plane
fspindle Sep 20, 2024
4c85624
Fix doxygen warnings and clean code
fspindle Sep 20, 2024
85d5203
Merge branch 'module_rbt' into module_rbt_fs
fspindle Sep 20, 2024
c6201ab
setup vs code for json formatting
SamFlt Sep 20, 2024
13d596b
Merge pull request #1 from SamFlt/module_rbt_fs
SamFlt Sep 20, 2024
7487929
cleanup ccd tracker
SamFlt Sep 20, 2024
dab15b8
cleanup silhouette point
SamFlt Sep 20, 2024
161d97e
mestimator setting for silhouetteMe
SamFlt Sep 20, 2024
5afaf5b
Merge branch 'master' into module_rbt
fspindle Sep 21, 2024
57793f3
Cleanup klt tracker
SamFlt Sep 23, 2024
52267a9
Fix virtual destructor being private, non const argument in vpColorHi…
SamFlt Sep 23, 2024
c6b4f4a
Python bindings: rbt config, enable parallel LTO when supported by co…
SamFlt Sep 23, 2024
8192170
Trampoline class for feature tracker, initial version
SamFlt Sep 23, 2024
b09b6f1
working on python example
SamFlt Sep 23, 2024
8cbee82
Setup testing rbt module, testing basic configuration/user api
SamFlt Sep 24, 2024
da11d4d
Realsense example works in Python
SamFlt Sep 24, 2024
dff31fd
Fix lto optimization generating cmake errors
SamFlt Sep 24, 2024
4dfd6f3
Fixed trampoline class to avoid copying frames, fixed rendering extra…
SamFlt Sep 24, 2024
d4ecd40
Fix display having wrong override name
SamFlt Sep 24, 2024
86681cf
more testing of json serialization
SamFlt Sep 24, 2024
ba06f4b
Optimize klt by introducing roi
SamFlt Sep 25, 2024
027ca12
working on testing rbt on synthetic sequences, there is an issue with…
SamFlt Sep 26, 2024
60d9a40
Some more cleanup for python
SamFlt Sep 27, 2024
26469c7
Fixed python members export to Python bindings
SamFlt Oct 1, 2024
8d9c56a
Fixed indexing issue in python bindings, Silhouette ccd tracker inver…
SamFlt Oct 1, 2024
45044a2
working on numpy indexing for images (setitem)
SamFlt Oct 2, 2024
004f626
Testing basic setitem
SamFlt Oct 3, 2024
27d9e88
Merge branch 'master' into module_rbt
fspindle Oct 3, 2024
51771ff
Indexing for arrays
SamFlt Oct 3, 2024
3a01432
Merge branch 'module_rbt' of github.com:SamFlt/visp into module_rbt
SamFlt Oct 3, 2024
56fd3fd
remove commented test
SamFlt Oct 3, 2024
5b2bfe5
1D indexing for vectors
SamFlt Oct 3, 2024
a77bc79
Revert changes
fspindle Oct 4, 2024
be6ad2f
Rename rbt test with catch prefix
fspindle Oct 4, 2024
c4bf9c4
Link catch2 only to the tests
fspindle Oct 4, 2024
32a571c
Link dnn module to nlohman json 3rd party
fspindle Oct 4, 2024
62a372f
Remove empty lines
fspindle Oct 4, 2024
0123000
Make shaders as std::string instead of char *
fspindle Oct 4, 2024
f47dabe
Fix wrong catch2 header
fspindle Oct 4, 2024
9d199e9
Create object using std::string
fspindle Oct 4, 2024
2b4106b
Fix wrong indexing exception
SamFlt Oct 4, 2024
8d0a4f2
Update border in ccd tracker
SamFlt Oct 4, 2024
ce86309
Setup trampoline class for visual odometry interface
SamFlt Oct 8, 2024
4b3a38a
Change base settings for dragon, init image
SamFlt Oct 8, 2024
45cf1b6
Merge branch 'module_rbt' of github.com:SamFlt/visp into module_rbt
SamFlt Oct 8, 2024
5aef239
Add VO pointer and call to RBT main class
SamFlt Oct 8, 2024
8c2f966
Fix VO trampoline class
SamFlt Oct 11, 2024
80261ed
Debugging odometry usage, logging times
SamFlt Oct 11, 2024
ff763b8
Move call to odometry
SamFlt Oct 14, 2024
3c7942f
Merge branch 'master' into module_rbt
fspindle Oct 15, 2024
d7c674f
Revert changes related to buildFrom()
fspindle Oct 15, 2024
dc306ad
Add missing visp_sensor module
fspindle Oct 15, 2024
656d4c9
Add missing trampolines
SamFlt Oct 15, 2024
52dbbb0
re enable rendering after call to odometry
SamFlt Oct 15, 2024
d7e577a
remove debug print
SamFlt Oct 15, 2024
c1cf355
Fix warning: ‘void* memset(void*, int, size_t)’ clearing an object of…
fspindle Oct 16, 2024
87ba32d
Restore default ostream precision
fspindle Oct 16, 2024
600bfd2
Fix comment alignment
fspindle Oct 16, 2024
02b4911
Introduce getter/setter/json serialization to handle a verbose mode
fspindle Oct 16, 2024
87f23e3
Fix weighting to reflect what's in Antoine's thesis
SamFlt Oct 23, 2024
1b9e49d
add early return in dense depth tracker
SamFlt Oct 29, 2024
890bc28
Add mask filtering for CCD tracking
SamFlt Oct 30, 2024
d15369d
update histogram mask computation, per feature display toggling in se…
SamFlt Oct 30, 2024
5f27e95
Improve histogram mask, compute only on bb if asked
SamFlt Oct 31, 2024
b91e493
Merge branch 'master' into module_rbt
fspindle Nov 3, 2024
16769e1
Use std::string instead of char * to create shaders
fspindle Nov 3, 2024
193dcc3
Introduce VISP_NLOHMANN_JSON macro to include json headers
fspindle Nov 3, 2024
01a5a20
Optimize ccd tracker
SamFlt Nov 6, 2024
633aeeb
Merge remote-tracking branch 'upstream/master'
fspindle Nov 7, 2024
c132177
Merge branch 'master' into module_rbt
fspindle Nov 7, 2024
9ce4c50
Remove empty lines
fspindle Nov 7, 2024
6352ee9
Remove unused var
fspindle Nov 7, 2024
ae34fcd
Adding raw string parsing in factories for Python side clients, still…
SamFlt Nov 12, 2024
ca6638c
Fix vpPanda3DRGBRenderer::setBackgroundImage() removing BGRA conversi…
fspindle Nov 12, 2024
ef3380f
Some progress on factory usage in python
SamFlt Nov 13, 2024
a9caed8
Merge branch 'module_rbt' of github.com:SamFlt/visp into module_rbt
SamFlt Nov 13, 2024
8b4ed72
Fixed segfault issue by adding virtual destructor
SamFlt Nov 15, 2024
a5e6973
Update vpPanda3DRendererSet class
fspindle Nov 15, 2024
df9feee
Allow for the usage of computePose on the Python side
SamFlt Nov 19, 2024
4a88af8
Introduce display helpers for python to display multiple points and l…
SamFlt Nov 19, 2024
e8c6ee6
April detection wrapper method for python bindings
SamFlt Nov 20, 2024
f7c0ce8
Add bindings for computePlanarObjectPoseFromRGBD
SamFlt Nov 25, 2024
a7de02e
Merge branch 'master' into module_rbt
fspindle Dec 5, 2024
8dde5ea
Bump cmake min version to 3.10
fspindle Dec 5, 2024
8ac4800
Merge remote-tracking branch 'upstream/master' into module_rbt
SamFlt Dec 11, 2024
3684e5d
Merge branch 'module_rbt' of github.com:SamFlt/visp into module_rbt
SamFlt Dec 11, 2024
9a5d92d
Introduce cMo in render data
SamFlt Dec 13, 2024
f2d2375
Merge remote-tracking branch 'upstream/master' into module_rbt
fspindle Dec 17, 2024
24c4ffd
Harmonize usage of render cMo instead of previous_cMo variable
SamFlt Dec 17, 2024
b9e0dd1
Replace .obj dragon with .bam model
SamFlt Dec 17, 2024
20203be
Remove display type parameter in display
SamFlt Dec 18, 2024
bc9a67e
Merge branch 'master' into module_rbt
fspindle Dec 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
working on python example
  • Loading branch information
SamFlt committed Sep 23, 2024
commit b09b6f1cba06e589ca4506aa5d169ee3309ce98e
190 changes: 190 additions & 0 deletions modules/python/examples/realsense-rbt.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,190 @@
#############################################################################
#
# ViSP, open source Visual Servoing Platform software.
# Copyright (C) 2005 - 2023 by Inria. All rights reserved.
#
# This software is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
# See the file LICENSE.txt at the root directory of this source
# distribution for additional information about the GNU GPL.
#
# For using ViSP with software that can not be combined with the GNU
# GPL, please contact Inria about acquiring a ViSP Professional
# Edition License.
#
# See https://visp.inria.fr for more information.
#
# This software was developed at:
# Inria Rennes - Bretagne Atlantique
# Campus Universitaire de Beaulieu
# 35042 Rennes Cedex
# France
#
# If you have questions regarding the use of this file, please contact
# Inria at visp@inria.fr
#
# This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
# WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
#
# Description:
# ViSP Python bindings example
#
#############################################################################

import argparse
from dataclasses import dataclass
from pathlib import Path
from typing import List, Optional, Tuple
import numpy as np
import time
import faulthandler
faulthandler.enable()


from visp.core import CameraParameters, HomogeneousMatrix
from visp.core import Color, Display, ImageConvert
from visp.core import ImageGray, ImageUInt16, ImageRGBa, ImageFloat
from visp.io import ImageIo
from visp.rbt import RBTracker
from visp.display_utils import get_display
import pyrealsense2 as rs


try:
import cv2
except:
print('Could not import opencv-python! make sure that it is installed as it is required')
import sys
sys.exit(1)

import matplotlib.pyplot as plt




@dataclass
class FrameData:
I: ImageGray
IRGB: ImageRGBa
I_depth: Optional[ImageFloat]


def read_data(depth_scale: Optional[float], IRGB: ImageRGBa, I: ImageGray, pipe: rs.pipeline):
use_depth = depth_scale is not None
iteration = 1
while True:
frames = pipe.wait_for_frames()
I_np = np.asanyarray(frames.get_color_frame().as_frame().get_data())
I_np = np.concatenate((I_np, np.ones_like(I_np[..., 0:1], dtype=np.uint8)), axis=-1)
IRGB.resize(I_np.shape[0], I_np.shape[1])
I_rgba_ref = IRGB.numpy()
I_rgba_ref[...] = I_np
ImageConvert.convert(IRGB, I, 0)
I_depth_float = None
if use_depth:
I_depth_raw = np.asanyarray(frames.get_depth_frame().as_frame().get_data())
I_depth_float = I_depth_raw.astype(np.float32) * depth_scale
iteration += 1
yield FrameData(I, IRGB, ImageFloat(I_depth_float))


def cam_from_rs_profile(profile) -> Tuple[CameraParameters, int, int]:
intr = profile.as_video_stream_profile().get_intrinsics() # Downcast to video_stream_profile and fetch intrinsics
return CameraParameters(intr.fx, intr.fy, intr.ppx, intr.ppy), intr.height, intr.width

if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--tracker', type=str, required=True,
help='Path to the json file containing the tracker configuration.')


args = parser.parse_args()
tracker_path = args.tracker
assert Path(tracker_path).exists(), 'Tracker file not found'


# Initialize realsense2
pipe = rs.pipeline()
config = rs.config()
config.enable_stream(rs.stream.depth, 640, 480, rs.format.z16, 60)
config.enable_stream(rs.stream.color, 640, 480, rs.format.rgb8, 60)

cfg = pipe.start(config)
depth_scale = cfg.get_device().first_depth_sensor().get_depth_scale()


tracker = RBTracker()

tracker.loadConfigurationFile(tracker_path)


cam_color, color_height, color_width = cam_from_rs_profile(cfg.get_stream(rs.stream.color))
cam_depth, depth_height, depth_width = cam_from_rs_profile(cfg.get_stream(rs.stream.depth))


# Camera intrinsics

print('Color intrinsics:', cam_color)
print('Depth intrinsics:', cam_depth)
I = ImageGray()
IRGB = ImageRGBa()
I_depth_display = ImageGray()
data_generator = read_data(depth_scale, IRGB, I, pipe)
frame_data = next(data_generator) # Get first frame for init

# Initialize displays
dI = get_display()
dI.init(I, 0, 0, 'Color image')

I_depth = ImageGray()
dDepth = get_display()

ImageConvert.createDepthHistogram(frame_data.I_depth, I_depth)
dDepth.init(I_depth, I.getWidth(), 0, 'Depth')

for frame in data_generator:
Display.display(I)
Display.displayText(I, 50, 0, 'Click to initialize tracking', Color.red)
Display.flush(I)
event = Display.getClick(I, blocking=False)
if event:
break

tracker.initClick(I, str(mbt_model.init_file))
start_time = time.time()
for frame_data in data_generator:
if frame_data.I_depth is not None:
ImageConvert.createDepthHistogram(frame_data.I_depth, I_depth)

Display.display(I)
if not args.disable_depth:
Display.display(I_depth)

if args.disable_depth:
tracker.track(I=I)
else:
pc = frame_data.point_cloud
image_dict = {
'Camera1': I
}
t = time.time()
tracker.track(image_dict, {'Camera2': pc.reshape(depth_height, depth_width, 3)})
cMo = HomogeneousMatrix()
tracker.getPose(cMo)

Display.displayFrame(I, cMo, cam_color, 0.05, Color.none, 2)
tracker.display(I, cMo, cam_color, Color.red, 2)
Display.flush(I)
if not args.disable_depth:
Display.flush(I_depth)

if args.step_by_step:
Display.getKeyboardEvent(I, blocking=True)
else:
event = Display.getClick(I, blocking=False)
if event:
break
end_time = time.time()
print(f'total time = {end_time - start_time}s')
Loading