platform_status.py 6.01 KB
Newer Older
1
"""
2
    schema: platform-specific decoded status message
3
"""
4

5 6
sensor_schema = {
    "type": "object",
7 8
    "description": "Scanning sensor on platform available"
    + " to be controlled by  the Autonomy Engine",
9 10 11 12 13 14
    "properties": {
        "sensor_serial": {
            "type": "string",
            "description": "serial number of sensor",
            "example": "mbes-002a",
        },
15
        "sensor_on": {
16 17 18 19 20 21 22 23 24 25 26 27
            "type": "boolean",
            "description": "Sensor switched on (True) or off (False)",
            "example": True,
        },
        "additional_data": {
            "type": "null",
            "description": "Any addition fields/data to be added here",
            "example": {"payload": [1.2, 434]},
        },
    },
    "required": [],
}
28

29 30 31
platform_status_message_schema = {
    "type": "object",
    "properties": {
32 33 34 35 36
        "message_type": {
            "type": "string",
            "description": "Type of message",
            "example": "platform_status",
        },
37 38 39 40 41
        "platform_ID": {
            "type": "integer",
            "description": "Identifier for platform",
            "example": 1,
        },
42 43 44 45 46 47 48
        "status_source": {
            "type": "string",
            "enum": ["usbl", "onboard_platform"],
            "description": "Indicate if this status message is from the"
            + " platform or USBL",
            "example": "usbl",
        },
49 50 51 52 53 54 55 56
        "transmission_mode": {
            "type": "string",
            "enum": ["acoustics", "iridium", "wifi", "starlink"],
            "description": "Mode in which status message was transmitted"
            + " when on the surface (i.e. iridium/wifi) or underwater"
            + " (i.e. acoustics)",
            "example": "wifi",
        },
57
        "platform_timestamp": {
58 59
            "type": "string",
            "format": "date-time",
60 61 62 63 64 65
            "decription": "Timestamp for onboard platform status message",
            "example": "2022-12-21T00:00:00Z",
        },
        "active": {
            "type": "boolean",
            "description": "When a platform is in deployment (executing a"
66
            + " mission plan) this should be True",
67 68 69
            "example": True,
        },
        "platform_state": {
70
            # TODO: Define enum with potential STATES of each platform
71 72
            "type": "string",
            "description": "Current state executed by platform. E.g. "
73
            + "STOP, IDLE, ABORT.",
74 75
            "example": "ABORT",
        },
76
        "autonomy_engine_plan_ID": {
77
            "type": "integer",
78 79
            "description": "Last mission plan ID (according to Autonomy"
            + " Engine's mission plan number sent) executed by platform",
80 81
            "example": 1,
        },
82 83
        "latitude": {
            "type": "number",
84
            "format": "float",
85 86 87 88 89
            "description": "Latitude in decimal degrees.",
            "example": 178.2,
        },
        "longitude": {
            "type": "number",
90
            "format": "float",
91 92 93 94 95
            "description": "Longitude in decimal degrees.",
            "example": -10.122,
        },
        "depth": {
            "type": "number",
96
            "format": "float",
97 98 99 100 101 102
            "description": "Target depth in metres",
            "example": 50,
            "default": 0,
        },
        "altitude": {
            "type": "number",
103
            "format": "float",
104 105 106
            "description": "Target altitude in metres",
            "example": 20,
        },
107 108 109 110 111 112 113 114
        "mission_track_ID": {
            "type": "integer",
            "description": "Track number - stage in mission (e.g. "
            + "4 --> Waypoint 3 to Waypoint 4)",
            "example": 4,
        },
        "mission_action_ID": {
            "type": "integer",
115
            "description": "",  # TODO: Add description
116 117 118 119
            "example": 1,
        },
        "range_to_go": {
            "type": "number",
120
            "format": "float",
121 122 123 124 125
            "description": "Estimated distance to reach next waypoint",
            "example": 124.3,
        },
        "speed_over_ground": {
            "type": "number",
126 127
            "format": "float",
            "description": "",  # TODO: Add description
128 129 130 131
            "example": 124.3,
        },
        "water_current_velocity": {
            "type": "number",
132 133
            "format": "float",
            "description": "",  # TODO: Add description
134 135 136 137
            "example": 124.3,
        },
        "thrust_applied": {
            "type": "number",
138 139
            "format": "float",
            "description": "",  # TODO: Add description
140 141
            "example": 124.3,
        },
142 143
        "heading": {
            "type": "number",
144
            "format": "float",
145 146 147 148
            "description": "Angular distance relative to north, usually 000°"
            + " at north, clockwise through 359°, in degrees",
            "example": 124.3,
        },
149 150 151 152 153 154 155 156
        "health_status": {
            "type": "string",
            "description": "Health status extracted by respective platform "
            + "if any diagnosis is available to check sensors",
            "example": "Warning",
        },
        "localisation_error": {
            "type": "number",
157
            "format": "float",
158 159 160 161 162
            "description": "Localisation error at last USBL update.",
            "example": 0.000129,
        },
        "usbl_fix_seconds_ago": {
            "type": "number",
163
            "format": "float",
164 165 166 167 168
            "description": "USBL Fix received x second ago.",
            "example": 10.0,
        },
        "battery_remaining_capacity": {
            "type": "number",
169
            "format": "float",
170
            "description": "Battery remaining % provided by respective C2",
171 172
            "example": 80.2,
        },
173 174
        "current_pitch": {
            "type": "number",
175
            "format": "float",
176 177 178
            "description": "Current pitch of platform",
            "example": -4.0,
        },
179
        "sensor_config": sensor_schema,
180
    },
181
    "required": [
182
        "message_type",
183
        "platform_ID",
184
        "status_source",
185
        "platform_timestamp",
186 187
        "latitude",
        "longitude",
188 189
    ],
}