RBRcervello User JSON schema

Type: object

JSON schema for Cervello units with 1.16


Example:

{
    "file": {
        "date": "20210814000000",
        "version": "3.1.0",
        "schema": "0011713",
        "customer": "RBR"
    },
    "controller": {
        "battery_period": 600,
        "deep_sleep": {
            "enabled": false,
            "deep_sleep_duration": 3600
        },
        "clock_sync_timeout": 43200
    },
    "gps": {
        "enabled": true,
        "period": 600,
        "fix_timeout": 60,
        "hdop_threshold": 1.5
    },
    "instrument": [
        {
            "enabled": true,
            "label": "Ice Maestro",
            "type": "RBR",
            "config_file": "deployment01.json",
            "port": 1,
            "ssm": 204448,
            "battery_period": 600,
            "can_be_stopped": true,
            "max_stopped_download_gap": 1382400,
            "enforce_max_dataset_size": true,
            "max_dataset_size": 1000000000,
            "processing": [
                {
                    "subset": "raw",
                    "channel": [
                        {
                            "key": "cond10",
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "temp14",
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "pres24",
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        }
                    ]
                }
            ]
        },
        {
            "enabled": true,
            "label": "Aquapro",
            "type": "Aquadopp",
            "config_file": "deployment02.json",
            "port": 1,
            "ssm": 205558,
            "battery_period": 600,
            "can_be_stopped": true,
            "max_stopped_download_gap": 1382400,
            "enforce_max_dataset_size": true,
            "max_dataset_size": 1000000000,
            "processing": [
                {
                    "subset": "raw",
                    "channel": [
                        {
                            "key": "n_an01",
                            "transmit": true,
                            "min": 0.0,
                            "max": 65535.0,
                            "res": 1
                        },
                        {
                            "key": "n_bt01",
                            "transmit": true,
                            "min": 5.0,
                            "max": 15.0,
                            "res": 0.1
                        },
                        {
                            "key": "n_ss01",
                            "transmit": true,
                            "min": 1400.0,
                            "max": 1600.0,
                            "res": 0.1
                        },
                        {
                            "key": "n_hd01",
                            "transmit": true,
                            "min": -360.0,
                            "max": 360.0,
                            "res": 0.1
                        },
                        {
                            "key": "n_pt01",
                            "transmit": true,
                            "min": -360.0,
                            "max": 360.0,
                            "res": 0.1
                        },
                        {
                            "key": "n_rl01",
                            "transmit": true,
                            "min": -360.0,
                            "max": 360.0,
                            "res": 0.1
                        },
                        {
                            "key": "n_pr01",
                            "transmit": true,
                            "min": -10.0,
                            "max": 1500.0,
                            "res": 0.001
                        },
                        {
                            "key": "n_tm01",
                            "transmit": true,
                            "min": -10.0,
                            "max": 40.0,
                            "res": 0.01
                        },
                        {
                            "key": "n_vl01",
                            "transmit": true,
                            "min": -1.0,
                            "max": 1.0,
                            "res": 1
                        },
                        {
                            "key": "n_ap01",
                            "transmit": true,
                            "min": 0.0,
                            "max": 255.0,
                            "res": 1
                        }
                    ]
                }
            ]
        },
        {
            "enabled": true,
            "label": "Weather Station",
            "type": "NMEA",
            "config_file": "deployment03.json",
            "port": 2,
            "ssm": 0,
            "burst": {
                "burst_interval": 3600,
                "burst_time": 480
            },
            "processing": [
                {
                    "subset": "raw",
                    "channel": [
                        {
                            "key": "wspd00",
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "wdir00",
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "baro98",
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "tair00",
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "wdir00",
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        }
                    ]
                },
                {
                    "subset": "weather",
                    "channel": [
                        {
                            "key": "wdir03",
                            "post_processing": {
                                "parameters": [],
                                "raw_channels": [
                                    4,
                                    0
                                ]
                            },
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "wspd02",
                            "post_processing": {
                                "parameters": [],
                                "raw_channels": [
                                    1,
                                    2
                                ]
                            },
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "wgst01",
                            "post_processing": {
                                "parameters": [
                                    5
                                ],
                                "raw_channels": [
                                    0
                                ]
                            },
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "baro99",
                            "post_processing": {
                                "parameters": [],
                                "raw_channels": [
                                    2
                                ]
                            },
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        },
                        {
                            "key": "tair02",
                            "post_processing": {
                                "parameters": [],
                                "raw_channels": [
                                    3
                                ]
                            },
                            "transmit": true,
                            "min": 0.0,
                            "max": 150.0,
                            "res": 0.0001
                        }
                    ]
                }
            ]
        }
    ],
    "streaming": {
        "enabled": false
    },
    "processing": {
        "enabled": true,
        "period": 1800,
        "time_series": true,
        "differential_encoding": true,
        "diagnostics": true
    },
    "telemetry": {
        "enabled": true,
        "force_period": 3600,
        "mode": [
            "gsm",
            "rudics"
        ],
        "gsm": {
            "failures_before_unavailable": 3,
            "retry_period": 7200,
            "apn": "auto",
            "destination": "dataincoming.rbr-global.com:9140"
        },
        "rudics": {
            "failures_before_unavailable": 3,
            "retry_period": 7200,
            "dial": "00881600005385"
        }
    }
}

Type: object

Information about the JSON file

No Additional Properties

Type: string

Date of modification of the file.

Must match regular expression: [0-9]{4}(0[1-9]|1[0-2])(0[1-9]|[1-2][0-9]|3[0-1])(2[0-3]|[01][0-9])[0-5][0-9]

Must be at least 14 characters long

Must be at most 14 characters long

Type: const

Schema version it complies to

Specific value: "3.1.0"

Type: string

Schema part number it complies to

Type: string

Customer identifier

Type: object

Settings for the Cervello behaviour

No Additional Properties

Type: number Default: 3600

How frequently to record the data controller battery level.

Value must be greater or equal to 60 and lesser or equal to 86400

Type: object
No Additional Properties

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object

The following properties are required:

  • enabled
  • deep_sleep_duration

Type: boolean Default: false

Whether the data controller should enter deep sleep whenever it's finished downloading from the logger.

Type: number Default: 3600

How long to stay in deep sleep before checking the logger for data again.

Value must be greater or equal to 600 and lesser or equal to 86400

Type: number Default: 43200

The number of seconds allowed to pass after setting the flag for the instrument sync to happen.

Value must be greater or equal to 60 and lesser or equal to 86400

Type: object

Settings for the GPS behaviour

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object
No Additional Properties

Type: boolean

Type: number Default: 600

How frequently to look for new GPS coordinates.

Value must be greater or equal to 300 and lesser or equal to 86400

Type: number Default: 60

How long to wait for a GPS fix.

Value must be greater or equal to 60 and lesser or equal to 240

Type: number Default: 1.5

The maximum permissible HDOP for a GPS sample.

Value must be greater or equal to 1.0 and lesser or equal to 3.5

Type: boolean Default: true

Whether position retrieval via GPS is enabled.

Type: object

[Deprecated] Information on streaming.

No Additional Properties

Type: const Default: false

Whether streaming data via the serial debug port is enabled or not.

Specific value: false

Type: object

Settings for the Data Processor global behaviour.

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object
No Additional Properties

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object

Type: const
Specific value: true

Type: boolean

Type: number Default: 1800

How frequently new data is to be processed for telemetry transmission.

Value must be greater or equal to 600 and lesser or equal to 86400

Type: boolean Default: true

Whether time-series data should be relayed over the data link.

Type: boolean Default: true

Whether time-series data should be differentially-encoded.

Type: boolean Default: true

Whether diagnostic data (GPS readings, battery levels) should be relayed over the data link

Type: boolean Default: true

Whether data processing for telemetry is enabled or not.

Type: object

Settings for Publisher's global behaviour.

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object
No Additional Properties

Type: boolean

Type: number Default: 7200

How frequently to power up the modem even in the absence of new data (to send a heartbeat and check for diagnostic tasks)

Value must be greater or equal to 600 and lesser or equal to 86400

Type: array of enum (of string) Default: ["gsm", "rudics"]

The transmission mode: gsm, rudics, nop. Multiple modes may be specified in order of preference.

Must contain a minimum of 1 items

All items must be unique

Each item of this array must be:

Type: enum (of string)

Must be one of:

  • "gsm"
  • "rudics"
  • "nop"

Type: object
No Additional Properties

Type: number Default: 3

When this transmission mode fails this many times in succession, it will be considered unavailable and the next-most-preferential mode will be used. If this mode is the only one available, or if this mode is the least preferable, then this setting is ignored.

Value must be greater or equal to 1 and lesser or equal to 10

Type: number Default: 7200

After the mode has become unavailable, wait this long between checks to see whether it's available again.

Value must be greater or equal to 600 and lesser or equal to 86400

Default: "auto"

The cellular provider access point name (APN).

Type: const
Specific value: "auto"
Type: object
Must match regular expression: ^(?:[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?\.)+[a-z0-9][a-z0-9-]{0,61}[a-z0-9]$

Type: string Default: "dataincoming.rbr-global.com:9140"

The destination for outgoing data messages sent over GSM.

Must match regular expression: ^(?:[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?\.)+[a-z0-9][a-z0-9-]{0,61}[a-z0-9]\:[0-9]{2,6}$

Type: object
No Additional Properties

Type: number Default: 3

When this transmission mode fails this many times in succession, it will be considered unavailable and the next-most-preferential mode will be used. If this mode is the only one available, or if this mode is the least preferable, then this setting is ignored.

Value must be greater or equal to 1 and lesser or equal to 10

Type: number Default: 7200

After the mode has become unavailable, wait this long between checks to see whether it's available again.

Value must be greater or equal to 600 and lesser or equal to 86400

Type: string Default: "00881600005385"

The Iridium number to dial for RUDICS.

Must match regular expression: ^[0-9]{13,15}$

Type: boolean Default: true

Whether telemetry is enabled or not.

Type: array of object

Array with each Logger's specific controller settings.

Each item of this array must be:


Type: object

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: enum (of string)

Must be one of:

  • "RBR"
  • "Aquadopp"
Type: object
No Additional Properties

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object

The following properties are required:

  • enabled
  • label
  • type
  • ssm
  • battery_period
  • can_be_stopped
  • max_stopped_download_gap
  • enforce_max_dataset_size
  • max_dataset_size

Type: boolean Default: true

Whether communication with/downloading from a data logger is enabled.

Type: string

Human readable descriptor of the specific unit (eg. Bottom CTD)

Type: enum (of string)

Type of logger, defines driver to be used.

Must be one of:

  • "RBR"
  • "Aquadopp"

Type: string

Configuration file for this instrument. If not specified it will default to deploymentXX.json

Must match regular expression: ^[a-zA-Z0-9-_]+\.json$
Examples:

"deployment01.json"
"ice_CTD_01.json"

Type: number Default: 1

Port number to which it is connected

Value must be greater or equal to 1 and lesser or equal to 3

Type: number

If the logger is connected to the data controller via an MLM, the serial number of the SSM connected to the instrument.

Value must be greater or equal to 0 and lesser or equal to 999999

Type: number Default: 600

How frequently to record the logger battery levels.

Value must be greater or equal to 600 and lesser or equal to 86400

Type: boolean Default: true

Whether the logger can be stopped and restarted when the configuration doesn't match the configuration stored in the Cervello.

Type: number Default: 1000000000

If the difference between the amount of data stored on the data controller and recorded in logger memory exceeds this amount, the logger will be restarted immediately.

Value must be greater or equal to 0 and lesser or equal to 1073741824

Type: boolean Default: true

Whether we should enforce a maximum dataset size. Useful for forcing the dataset to roll over in conjunction with the cervata.

Type: number Default: 262144000

The maximum permissible size of the dataset in logger memory. If it grows past this size, the logger should be restarted.

Value must be greater or equal to 0 and lesser or equal to 1073741824

Type: array of object

Each item of this array must be:

Type: object
No Additional Properties

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: "raw"
Type: object
Type: object

Type: array

Each item of this array must be:

Type: object

The following properties are required:

  • post_processing

Type: string

Name of the channels' subset

Must match regular expression: ^[a-zA-Z0-9]*$

Type: array

Each item of this array must be:

Type: object
No Additional Properties

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object

The following properties are required:

  • transmit
  • key
  • min
  • max
  • res

Type: boolean

Whether this channel should be processed for inclusion in transmission.

Type: string

Channel key according to RBR's channels.

Must match regular expression: ^[a-zA-Z_]{4}[0-9]{2}$

Type: number

Minimum of the value. Used when differential_encoding is enabled.

Type: number

Maximum of the value. Used when differential_encoding is enabled.

Type: number

Resolution of the value. Used when differential_encoding is enabled.

Type: object

Properties of the derived or processed channel.

No Additional Properties

Type: array

Parameters required by the algorithm.

Type: array of number

Input channels of the algorithm.

Each item of this array must be:

Type: number

Value must be greater or equal to 0

Type: object
Type: object

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: "NMEA"
Type: object
No Additional Properties

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object

The following properties are required:

  • enabled
  • label
  • type
  • ssm
  • burst

Type: boolean Default: true

Whether communication with/downloading from a data logger is enabled.

Type: string

Human readable descriptor of the specific unit (eg. Bottom CTD)

Type: const

Type of logger, defines driver to be used.

Specific value: "NMEA"

Type: string

Configuration file for this instrument. If not specified it will default to deploymentXX.json

Must match regular expression: ^[a-zA-Z0-9-_]+\.json$
Examples:

"deployment01.json"
"ice_CTD_01.json"

Type: number Default: 1

Port number to which it is connected

Value must be greater or equal to 1 and lesser or equal to 3

Type: number

If the logger is connected to the data controller via an MLM, the serial number of the SSM connected to the instrument.

Value must be greater or equal to 0 and lesser or equal to 999999

Type: object

Burst parameters for streaming instruments. This is the period in which processed channels are generated.

No Additional Properties

Type: number

Value must be greater or equal to 0 and lesser or equal to 86400

Type: number

Value must be greater or equal to 0 and lesser or equal to 86400

Type: array of object

Each item of this array must be:

Type: object
No Additional Properties

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: "raw"
Type: object
Type: object

Type: array

Each item of this array must be:

Type: object

The following properties are required:

  • post_processing

Type: string

Name of the channels' subset

Must match regular expression: ^[a-zA-Z0-9]*$

Type: array

Each item of this array must be:

Type: object
No Additional Properties

If the conditions in the "If" tab are respected, then the conditions in the "Then" tab should be respected. Otherwise, the conditions in the "Else" tab should be respected.

Type: object

Type: const
Specific value: true
Type: object

The following properties are required:

  • transmit
  • key
  • min
  • max
  • res

Type: boolean

Whether this channel should be processed for inclusion in transmission.

Type: string

Channel key according to RBR's channels.

Must match regular expression: ^[a-zA-Z_]{4}[0-9]{2}$

Type: number

Minimum of the value. Used when differential_encoding is enabled.

Type: number

Maximum of the value. Used when differential_encoding is enabled.

Type: number

Resolution of the value. Used when differential_encoding is enabled.

Type: object

Properties of the derived or processed channel.

No Additional Properties

Type: array

Parameters required by the algorithm.

Type: array of number

Input channels of the algorithm.

Each item of this array must be:

Type: number

Value must be greater or equal to 0

Type: object

Type: enum (of string)

Must be one of:

  • "RBR"
  • "Aquadopp"
  • "NMEA"