strawlab / flydra

live, low-latency markerless multi-camera 3D animal tracking system
Apache License 2.0
58 stars 18 forks source link

camnode launch file fails #34

Closed llorban closed 6 years ago

llorban commented 6 years ago

I created the following launch file:

<launch> <rosparam command="load" file="$(find freemoovr_arena)/launch/flydra.yaml" /> <node name="AVT-02-2020C-07056" pkg="ros_flydra" type="camnode2-pylon" args="--camera-name=AVT-02-2020C-07056 --http-server-addr=127.0.0.1:4011 --ros-tracking-start-delay=30"> </node> <node name="AVT-02-2020C-07058" pkg="ros_flydra" type="camnode2-pylon" args="--camera-name=AVT-02-2020C-07058 --http-server-addr=127.0.0.1:4011 --ros-tracking-start-delay=30"> </node> </launch>

which results in the following error:

flightlab@ubuntu:~$ roslaunch /home/flightlab/ros/flydra-kinetic/src/ros_flydra/launch/prosilica1.launch ... logging to /home/flightlab/.ros/log/f1867084-65f2-11e8-b48b-000c2967883e/roslaunch-ubuntu-95368.log Checking log directory for disk usage. This may take awhile. Press Ctrl-C to interrupt Done checking log file disk usage. Usage is <1GB.

Traceback (most recent call last): File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/__init__.py", line 306, in main p.start() File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/parent.py", line 268, in start self._start_infrastructure() File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/parent.py", line 217, in _start_infrastructure self._load_config() File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/parent.py", line 132, in _load_config roslaunch_strs=self.roslaunch_strs, verbose=self.verbose) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/config.py", line 451, in load_config_default loader.load(f, config, verbose=verbose) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/xmlloader.py", line 748, in load self._load_launch(launch, ros_config, is_core=core, filename=filename, argv=argv, verbose=verbose) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/xmlloader.py", line 720, in _load_launch self._recurse_load(ros_config, launch.childNodes, self.root_context, None, is_core, verbose) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/xmlloader.py", line 680, in _recurse_load self._rosparam_tag(tag, context, ros_config, verbose=verbose) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/xmlloader.py", line 95, in call return f(*args, **kwds) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/xmlloader.py", line 228, in _rosparam_tag cmd, ns, file, param, subst_value = self.opt_attrs(tag, context, (XmlLoader.ROSPARAM_OPT_ATTRS)) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/xmlloader.py", line 202, in opt_attrs return [self.resolve_args(tag_value(tag,a), context) for a in attrs] File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/xmlloader.py", line 183, in resolve_args return substitution_args.resolve_args(args, context=context.resolve_dict, resolve_anon=self.resolve_anon) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/substitution_args.py", line 370, in resolve_args resolved = _resolve_args(resolved, context, resolve_anon, commands) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/substitution_args.py", line 383, in _resolve_args resolved = commands[command](resolved, a, args, context) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/substitution_args.py", line 151, in _find source_path_to_packages=source_path_to_packages) File "/opt/ros/kinetic/lib/python2.7/dist-packages/roslaunch/substitution_args.py", line 197, in _find_executable full_path = _get_executable_path(rp.get_path(args[0]), path) File "/usr/lib/python2.7/dist-packages/rospkg/rospack.py", line 203, in get_path raise ResourceNotFound(name, ros_paths=self._ros_paths) ResourceNotFound: freemoovr_arena ROS path [0]=/opt/ros/kinetic/share/ros ROS path [1]=/home/flightlab/ros/flydra-kinetic/src ROS path [2]=/opt/ros/kinetic/share

astraw commented 6 years ago

It looks to me like the problem is this line: <rosparam command="load" file="$(find freemoovr_arena)/launch/flydra.yaml" />. You are telling ROS to look for the yaml file in the freemoovr_arena ROS package, which is not found.