Skip to content

Commit

Permalink
Replace upsert with add point of interest
Browse files Browse the repository at this point in the history
  • Loading branch information
Afonso-2403 committed Oct 24, 2023
1 parent 3f9b67a commit 6fe8a0a
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 28 deletions.
1 change: 1 addition & 0 deletions src/isar_exr/api/models/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ class PointOfInterestActionVideoInput(BaseModel):

class AddPointOfInterestInput(BaseModel):
name: str
customerTag: Optional[str] = None
site: str
frame: str
type: PointOfInterestTypeEnum = Field(default=PointOfInterestTypeEnum.GENERIC)
Expand Down
92 changes: 64 additions & 28 deletions src/isar_exr/robotinterface.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
RobotCommunicationException,
RobotInitializeException,
RobotMissionStatusException,
RobotInfeasibleStepException,
)
from robot_interface.models.initialize import InitializeParams
from robot_interface.models.inspection.inspection import Inspection
Expand All @@ -48,13 +49,14 @@
from isar_exr.api.energy_robotics_api import EnergyRoboticsApi
from isar_exr.api.models.models import (
Point3DInput,
PointOfInterestProducerInput,
PointOfInterestProducerTypeEnum,
PointOfInterestActionPhotoInput,
PointOfInterestActionVideoInput,
PointOfInterestTypeEnum,
Pose3DInput,
Pose3DStampedInput,
QuaternionInput,
RobotTypeEnum,
UpsertPointOfInterestInput,
AddPointOfInterestInput,
)
from isar_exr.config.settings import settings
from isar_exr.models.exceptions import NoMissionRunningException
Expand Down Expand Up @@ -92,9 +94,11 @@ def initiate_mission(self, mission: Mission) -> None:
poi_ids: List[str] = []
for task in mission.tasks:
for step in task.steps:
if isinstance(step, DriveToPose):
robot_pose: Pose = step.pose
if isinstance(step, InspectionStep):
poi_id: str = self._upsert_and_add_poi(
task=task, step=step, stage_id=stage_id
poi_id: str = self._create_and_add_poi(
task=task, step=step, robot_pose=robot_pose, stage_id=stage_id
)
poi_ids.append(poi_id)

Expand All @@ -111,10 +115,7 @@ def initiate_mission(self, mission: Mission) -> None:

for task in mission.tasks:
for step in task.steps:
if isinstance(step, DriveToPose):
self._add_waypoint_task_to_mission(
mission_definition_id=mission_definition_id, step=step
)
# TODO: Support task with only DriveToStep
if isinstance(step, InspectionStep):
self._add_point_of_interest_inspection_task_to_mission(
task_name=step.id,
Expand Down Expand Up @@ -240,40 +241,75 @@ def _create_image(self, step: Union[TakeImage, TakeThermalImage]):
def _create_video(self, step: Union[TakeVideo, TakeThermalVideo]):
raise NotImplementedError

def _upsert_and_add_poi(self, task: Task, step: Step, stage_id: str) -> str:
def _create_and_add_poi(
self, task: Task, step: Step, robot_pose: Pose, stage_id: str
) -> str:
target: Position = self.transform.transform_position(
positions=step.target,
from_=step.target.frame,
to_=Frame("robot"),
)
pose: Pose3DStampedInput = Pose3DStampedInput(
timestamp=time.time(),
frameID="don't know",
pose: Pose3DInput = Pose3DInput(
position=Point3DInput(x=target.x, y=target.y, z=target.z),
orientation=QuaternionInput(
orientation=QuaternionInput( # Ask Energy Robotics what is this used for
x=0,
y=0,
z=0,
w=1,
),
)

poi_producer: PointOfInterestProducerInput = PointOfInterestProducerInput(
type=PointOfInterestProducerTypeEnum.MANUAL_IMPORT,
robotNumber=1,
robotType=RobotTypeEnum.EXR2,
photo_input_pose: Pose3DInput = Pose3DInput(
position=Point3DInput(
x=robot_pose.position.x,
y=robot_pose.position.y,
z=robot_pose.position.z,
),
orientation=QuaternionInput(
w=robot_pose.orientation.w,
x=robot_pose.orientation.x,
y=robot_pose.orientation.y,
z=robot_pose.orientation.z,
),
)
poi_input: UpsertPointOfInterestInput = UpsertPointOfInterestInput(
key=task.tag_id if task.tag_id else "default_poi",
name="insert_name_here",
type=PointOfInterestTypeEnum.GENERIC,
siteId=settings.ROBOT_EXR_SITE_ID,
pose=pose,
producer=poi_producer,
inspectionParameters={},

add_point_of_interest_input: dict[str, PointOfInterestActionPhotoInput] = {
"name": step.id,
"customerTag": task.tag_id,
"frame": "map",
"type": PointOfInterestTypeEnum.GENERIC,
"site": settings.ROBOT_EXR_SITE_ID,
"pose": pose,
}

if isinstance(step, TakeImage):
photo_input: PointOfInterestActionPhotoInput = (
PointOfInterestActionPhotoInput(
robotPose=photo_input_pose, sensor="inspection_cam_link"
)
)
add_point_of_interest_input["photoAction"] = photo_input

elif isinstance(step, TakeVideo):
video_input: PointOfInterestActionVideoInput = (
PointOfInterestActionVideoInput(
robotPose=photo_input_pose,
sensor="inspection_cam_link",
duration=step.duration,
)
)
add_point_of_interest_input["videoAction"] = video_input

else:
raise RobotInfeasibleStepException(
error_description=f"Step of type {type(step)} not supported"
)

poi_input: AddPointOfInterestInput = AddPointOfInterestInput(
**add_point_of_interest_input
)

poi_id: str = self.api.upsert_point_of_interest(
poi_id: str = self.api.create_point_of_interest(
point_of_interest_input=poi_input
)

Expand All @@ -289,7 +325,7 @@ def _add_waypoint_task_to_mission(
)
pose_3d_stamped: Pose3DStampedInput = Pose3DStampedInput(
timestamp=time.time(),
frameID="don't know",
frameID="map",
position=Point3DInput(
x=pose.position.x, y=pose.position.y, z=pose.position.z
),
Expand Down

0 comments on commit 6fe8a0a

Please sign in to comment.