From e1f5d47e9710c257728790694c09cd43351b179c Mon Sep 17 00:00:00 2001 From: Marina Moreira Date: Mon, 17 Jun 2024 10:32:40 -0700 Subject: [PATCH] running pano build using the docker images --- pano/docker/pano.Dockerfile | 13 ++++++++----- pano/pano_stitch/scripts/pano_image_meta.py | 7 ++++--- pano/pano_stitch/scripts/stitch_panorama.py | 16 ++++++++++++++-- 3 files changed, 26 insertions(+), 10 deletions(-) diff --git a/pano/docker/pano.Dockerfile b/pano/docker/pano.Dockerfile index 49f1c28b..1f84da54 100644 --- a/pano/docker/pano.Dockerfile +++ b/pano/docker/pano.Dockerfile @@ -14,16 +14,19 @@ RUN apt-get update \ hugin \ libvips-tools \ python3-pip \ + gfortran libopenblas-dev libfftw3-dev \ && rm -rf /var/lib/apt/lists/* # pandas: pulled in as pyshtools dependency but install breaks if not mentioned explicitly (?) # pyshtools: used during Pannellum multires generation # snakemake: modern build system based on Python, manages stitching workflows -RUN pip3 install --no-cache-dir --upgrade pip \ - && pip3 install --no-cache-dir \ - pandas \ - pyshtools \ - snakemake + +# Install Jupyter explicitly first +RUN pip3 install --no-cache-dir --upgrade pip && \ + pip3 install --no-cache-dir jupyter + +# Install other Python packages +RUN pip3 install --no-cache-dir pandas pyshtools snakemake pulp==2.7 --ignore-installed PyYAML # pannellum: library for viewing/navigating panorama tours RUN mkdir -p /opt \ diff --git a/pano/pano_stitch/scripts/pano_image_meta.py b/pano/pano_stitch/scripts/pano_image_meta.py index cd971636..b20934cd 100755 --- a/pano/pano_stitch/scripts/pano_image_meta.py +++ b/pano/pano_stitch/scripts/pano_image_meta.py @@ -26,7 +26,7 @@ import rosbag from tf.transformations import euler_from_quaternion -IMAGE_TOPIC = "/hw/cam_sci/compressed" +IMAGE_TOPIC = ["/hw/cam_sci/compressed", "/hw/cam_sci_info"] POSE_TOPIC = "/loc/pose" FIELD_NAMES = ( "timestamp", @@ -50,8 +50,9 @@ def get_image_meta(inbag_path, num_images=None): images = [] with rosbag.Bag(inbag_path) as bag: img_meta = None - for topic, msg, t in bag.read_messages([IMAGE_TOPIC, POSE_TOPIC]): - if topic == IMAGE_TOPIC: + topics = IMAGE_TOPIC + [POSE_TOPIC] + for topic, msg, t in bag.read_messages(topics): + if topic in IMAGE_TOPIC: if num_images is not None and len(images) == num_images: break diff --git a/pano/pano_stitch/scripts/stitch_panorama.py b/pano/pano_stitch/scripts/stitch_panorama.py index f19446b4..897f7fb1 100755 --- a/pano/pano_stitch/scripts/stitch_panorama.py +++ b/pano/pano_stitch/scripts/stitch_panorama.py @@ -427,12 +427,24 @@ def next(self): def read_pto(pano, pto_path): print("\nread_pto: %s" % pto_path) - pano.ReadPTOFile(pto_path) + try: + # Attempt the first method + ifs = hsi.ifstream(pto_path) + pano.readData(ifs) + except AttributeError: + # Fallback to the second method if the first method fails + pano.ReadPTOFile(pto_path) def write_pto(pano, pto_path): print("\nwrite_pto: %s" % pto_path) - pano.WritePTOFile(pto_path) + try: + # Attempt the first method + ofs = hsi.ofstream(pto_path) + pano.writeData(ofs) + except AttributeError: + # Fallback to the second method if the first method fails + pano.WritePTOFile(pto_path) def get_timestamp():