From ebe662d476e8a6f56ff220c4729d38e51932ad1f Mon Sep 17 00:00:00 2001 From: Diego Ferigo Date: Tue, 9 Feb 2021 14:02:08 +0100 Subject: [PATCH 1/4] Force loading tensorflow shared libraries to prevent segfault --- bindings/__init__.py | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/bindings/__init__.py b/bindings/__init__.py index d19cc6b3c..27a910fb0 100644 --- a/bindings/__init__.py +++ b/bindings/__init__.py @@ -42,12 +42,48 @@ def setup_gazebo_environment() -> None: os.environ["IGN_GAZEBO_SYSTEM_PLUGIN_PATH"] = ign_gazebo_system_plugin_path +def preload_tensorflow_shared_libraries() -> None: + + # Check if tensorflow is installed + import importlib.util + spec = importlib.util.find_spec("tensorflow") + + if spec is None: + return + + # Get the tensorflow __init__ location + import pathlib + init = pathlib.Path(spec.origin) + + # Get the tensorflow top-level folder + tensorflow_dir = init.parent + assert tensorflow_dir.is_dir() + + # Get the tensorflow/python folder + tensorflow_python_dir = tensorflow_dir / "python" + assert tensorflow_python_dir.is_dir() + + # Load the main shared library + for lib in tensorflow_dir.glob("*tensorflow*.so*"): + import ctypes + ctypes.CDLL(str(lib)) + + # Load all the shared libraries inside tensorflow/python + for lib in tensorflow_python_dir.glob("_*.so"): + import ctypes + ctypes.CDLL(str(lib)) + + def import_gazebo() -> None: # Check the the module was never loaded by someone else if "scenario.bindings._gazebo" in sys.modules: raise ImportError("Failed to load ScenarI/O Gazebo with custom dlopen flags") + # Preload the shared libraries of tensorflow if the package is installed. + # If tensorflow is imported after scenario.bindings.gazebo, the application segfaults. + preload_tensorflow_shared_libraries() + # Import SWIG bindings # See https://github.com/robotology/gym-ignition/issues/7 # https://stackoverflow.com/a/45473441/12150968 From f44022320a85cd09da6d2fb8d9f0acf335b2d741 Mon Sep 17 00:00:00 2001 From: Diego Ferigo Date: Tue, 9 Feb 2021 15:36:20 +0100 Subject: [PATCH 2/4] Allow disabling tensorflow preload via env variable --- bindings/__init__.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/bindings/__init__.py b/bindings/__init__.py index 27a910fb0..9f9819824 100644 --- a/bindings/__init__.py +++ b/bindings/__init__.py @@ -82,7 +82,8 @@ def import_gazebo() -> None: # Preload the shared libraries of tensorflow if the package is installed. # If tensorflow is imported after scenario.bindings.gazebo, the application segfaults. - preload_tensorflow_shared_libraries() + if os.environ.get("SCENARIO_DISABLE_TENSORFLOW_PRELOAD") != "1": + preload_tensorflow_shared_libraries() # Import SWIG bindings # See https://github.com/robotology/gym-ignition/issues/7 From 21becc532bb36ec2e3366d098af452aadb1395ee Mon Sep 17 00:00:00 2001 From: Diego Ferigo Date: Tue, 9 Feb 2021 16:32:25 +0100 Subject: [PATCH 3/4] Install numpy from PyPI and not apt in CI --- .github/workflows/cicd.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/cicd.yml b/.github/workflows/cicd.yml index ff4a1a673..0e44ae267 100644 --- a/.github/workflows/cicd.yml +++ b/.github/workflows/cicd.yml @@ -130,7 +130,7 @@ jobs: run: | apt-get update apt-get install -y --no-install-recommends \ - python3-numpy libxml2-dev coinor-libipopt-dev libeigen3-dev libassimp-dev swig + libxml2-dev coinor-libipopt-dev libeigen3-dev libassimp-dev swig # ============= # Build project From cba57f6200ffe58ea8b31e429dec24885ff017bf Mon Sep 17 00:00:00 2001 From: Diego Ferigo Date: Tue, 9 Feb 2021 17:07:16 +0100 Subject: [PATCH 4/4] Remove usage of kwargs in the IK NLP --- python/gym_ignition/rbd/idyntree/inverse_kinematics_nlp.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/python/gym_ignition/rbd/idyntree/inverse_kinematics_nlp.py b/python/gym_ignition/rbd/idyntree/inverse_kinematics_nlp.py index 82bb3bc62..1173b617c 100644 --- a/python/gym_ignition/rbd/idyntree/inverse_kinematics_nlp.py +++ b/python/gym_ignition/rbd/idyntree/inverse_kinematics_nlp.py @@ -187,8 +187,7 @@ def set_current_robot_configuration(self, q = rbd.idyntree.numpy.FromNumPy.to_idyntree_dyn_vector(array=joint_configuration) - if not self._ik.setCurrentRobotConfiguration(baseConfiguration=H, - jointConfiguration=q): + if not self._ik.setCurrentRobotConfiguration(H, q): raise RuntimeError("Failed to set the current robot configuration") if not self._floating_base: