From a4e071c3d9aa9b5a45e9eaf5461cafa18e9ebcfa Mon Sep 17 00:00:00 2001 From: coolteemf Date: Thu, 15 Feb 2024 14:45:02 +0100 Subject: [PATCH 1/2] Projector: use members camera_intrinsics and source_to_detector_distance directly instead of using members from device --- deepdrr/projector/projector.py | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/deepdrr/projector/projector.py b/deepdrr/projector/projector.py index 21742231..22030e11 100644 --- a/deepdrr/projector/projector.py +++ b/deepdrr/projector/projector.py @@ -859,7 +859,7 @@ def _setup_pyrender_scene(self, proj: geo.CameraProjection): self.cam.cx = proj.intrinsic.cx self.cam.cy = proj.intrinsic.cy self.cam.znear = 1 # self.device.source_to_detector_distance / 1000 - self.cam.zfar = self.device.source_to_detector_distance * 4 + self.cam.zfar = self.source_to_detector_distance * 4 deepdrr_to_opengl_cam = np.array( [ @@ -872,7 +872,7 @@ def _setup_pyrender_scene(self, proj: geo.CameraProjection): self.cam_node.matrix = np.array(proj.extrinsic.inv) @ deepdrr_to_opengl_cam - zfar = self.device.source_to_detector_distance * 2 * 4 # TODO (liam) + zfar = self.source_to_detector_distance * 2 * 4 # TODO (liam) return zfar @@ -1166,7 +1166,7 @@ def _render_mesh_subtractive_single( * NUMBYTES_INT8 ), np.int32(total_pixels), - np.float32(self.device.source_to_detector_distance * 2), + np.float32(self.source_to_detector_distance * 2), ), block=(32, 1, 1), # TODO (liam) grid=(2048, 1), # TODO (liam) @@ -1363,8 +1363,8 @@ def initialize(self): log.debug(f"beginning call to Projector.initialize") init_tick = time.perf_counter() - width = self.device.sensor_width - height = self.device.sensor_height + width = self.camera_intrinsics.sensor_width + height = self.camera_intrinsics.sensor_height total_pixels = width * height device_id = int(os.environ.get("EGL_DEVICE_ID", "0")) @@ -1469,16 +1469,16 @@ def initialize(self): self.mesh_nodes.append(node) self.scene.add(drrmesh.mesh, parent_node=node) - cam_intr = self.device.camera_intrinsics + cam_intr = self.camera_intrinsics self.cam = IntrinsicsCamera( fx=cam_intr.fx, fy=cam_intr.fy, cx=cam_intr.cx, cy=cam_intr.cy, - znear=self.device.source_to_detector_distance + znear=self.source_to_detector_distance / 1000, # TODO (liam) near clipping plane parameter - zfar=self.device.source_to_detector_distance, + zfar=self.source_to_detector_distance, ) self.cam_node = self.scene.add(self.cam) From 2ff55ca6caef69c49c6ff9bb6f35198516406c6c Mon Sep 17 00:00:00 2001 From: coolteemf Date: Thu, 15 Feb 2024 14:46:01 +0100 Subject: [PATCH 2/2] fix logging --- deepdrr/utils/image_utils.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/deepdrr/utils/image_utils.py b/deepdrr/utils/image_utils.py index 61b5321e..59a2d9a1 100644 --- a/deepdrr/utils/image_utils.py +++ b/deepdrr/utils/image_utils.py @@ -40,18 +40,18 @@ def _neglog(image: np.ndarray, epsilon: float = 0.01) -> np.ndarray: image_min = image.min(axis=(1, 2), keepdims=True) image_max = image.max(axis=(1, 2), keepdims=True) if np.any(image_max == image_min): - logger.debug( + log.debug( f"mapping constant image to 0. This probably indicates the projector is pointed away from the volume." ) # TODO(killeen): for multiple images, only fill the bad ones image[:] = 0 if image.shape[0] > 1: - logger.error("TODO: zeroed all images, even though only one might be bad.") + log.error("TODO: zeroed all images, even though only one might be bad.") else: image = (image - image_min) / (image_max - image_min) if np.any(np.isnan(image)): - logger.warning(f"got NaN values from negative log transform.") + log.warning(f"got NaN values from negative log transform.") if len(shape) == 2: return image[0]