Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sensor failure recovery, support calibration to the antenna, save onboard cals separately, cal on startup #281

Merged
merged 59 commits into from
Mar 29, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
63f4dbd
add default differential cal file
aromanielloNTIA Jan 26, 2024
bac3109
remove sigan calibration
aromanielloNTIA Jan 26, 2024
4f150fa
update requirements
aromanielloNTIA Jan 26, 2024
a2353a4
update sensor loader for calibration changes
aromanielloNTIA Jan 26, 2024
03c6f66
Merge branch 'master' into calibrate_to_antenna
aromanielloNTIA Feb 7, 2024
c0eafb4
convert calibration file string to path before passing
aromanielloNTIA Feb 7, 2024
f6db82c
Merge branch 'master' into calibrate_to_antenna
aromanielloNTIA Feb 26, 2024
e0ff8a6
Group related sigan variables, add auto calibration config
aromanielloNTIA Mar 5, 2024
a9999c7
remove default calibration files
aromanielloNTIA Mar 5, 2024
caa811a
remove default calibration files and update cal loading
aromanielloNTIA Mar 5, 2024
073b1ef
add calibrate_on_startup
aromanielloNTIA Mar 5, 2024
5c343d2
avoid setting environment vars to None
aromanielloNTIA Mar 6, 2024
325b8bc
remove unused import
aromanielloNTIA Mar 6, 2024
bc5969c
fix sensor loader initialization
aromanielloNTIA Mar 6, 2024
b5bb922
get sensor cal from sensor instead of sigan
aromanielloNTIA Mar 6, 2024
e139738
Fix ONBOARD_CALIBRATION_FILE setting.
dboulware Mar 14, 2024
9576cbe
Add CALIBRATE_ON_STARTUP setting defaulting to false.
dboulware Mar 14, 2024
9175e88
Add CALIBRATE_ON_STARTUP to docker-compose.yml.
dboulware Mar 14, 2024
3829f7d
Use setting for STARTUP_CALIBRATION_ACTION and don't raise exception …
dboulware Mar 14, 2024
75e64c8
Set ONBOARD_CALIBRATION_FILE whether it exists or not.
dboulware Mar 14, 2024
33f8200
Cal on startup if calibration is expired.
dboulware Mar 14, 2024
bdf6b9f
Add CALIBRATION_EXPIRATION_LIMIT to docker-compose.yml and remove fr…
dboulware Mar 14, 2024
19ac7a4
Fix STARTUP_CALIBRATION_ACTION setting.
dboulware Mar 14, 2024
a47087f
Remove "CALIBRATION_EXPIRATION_LIMIT" from settings.
dboulware Mar 14, 2024
0bceffe
Only update cal when actually running.
dboulware Mar 14, 2024
d0c24cc
Merge in autohealing fixes. Move cal on startup check to initializati…
dboulware Mar 14, 2024
ec4c26a
remove actions from laod_sensor
dboulware Mar 14, 2024
ee5aef6
add RAY_INIT setting.
dboulware Mar 14, 2024
975d240
Log performing startup cal.
dboulware Mar 14, 2024
74bc22d
Correct log message.
dboulware Mar 15, 2024
103253a
temporarily catch BaseException from startup cal.
dboulware Mar 15, 2024
68a2aa5
create method for startup cal.
dboulware Mar 15, 2024
104ea45
move startup calibration into scheduler.
dboulware Mar 15, 2024
6d13cff
remove dead code.
dboulware Mar 15, 2024
c94399b
Don't raise exceptions (that will be caught anyway) in loading cals.
dboulware Mar 17, 2024
0b95fe9
pre-commit
dboulware Mar 19, 2024
acb3fe7
Merge branch 'master' into calibrate_to_antenna
aromanielloNTIA Mar 22, 2024
c096d36
update scos-tekrsa and scos-actions version
jhazentia Mar 27, 2024
3b06062
fix import
aromanielloNTIA Mar 27, 2024
c71267d
Remove obsolete 'version' field and rename to compose.yaml
aromanielloNTIA Mar 27, 2024
bd46397
GH Actions: wait longer for container to be healthy
aromanielloNTIA Mar 27, 2024
c9bc7d1
try longer sleep in GH actions testing
aromanielloNTIA Mar 27, 2024
d07afdb
use docker compose v2 in github action
aromanielloNTIA Mar 27, 2024
2864b66
return to shorter sleep time in GH action
aromanielloNTIA Mar 27, 2024
d4795de
skip startup calibration when running with mock sigan
aromanielloNTIA Mar 27, 2024
6b2b92a
add missing return statement
aromanielloNTIA Mar 27, 2024
a01a6ad
Do not check for USB_DEVICE when using mock sigan
aromanielloNTIA Mar 27, 2024
560e347
remove unused variables
aromanielloNTIA Mar 28, 2024
fbb8404
remove unused import, get SCOS_SENSOR_GIT_TAG from settings
aromanielloNTIA Mar 28, 2024
5680801
update readme for calibration changes
aromanielloNTIA Mar 28, 2024
fc8335b
remove unused variable CALIBRATE_ON_STARTUP
aromanielloNTIA Mar 28, 2024
e2bd008
switch BASE_IMAGE version to latest
aromanielloNTIA Mar 28, 2024
b0af772
update all pre-commit hooks
aromanielloNTIA Mar 28, 2024
c3f02ad
Run updated pre-commit on all files
aromanielloNTIA Mar 28, 2024
ec3cb11
Use get_disk_usage from SCOS Actions in status view
aromanielloNTIA Mar 28, 2024
beef855
remove unused import
aromanielloNTIA Mar 28, 2024
6da59db
fix wording in cal file comment
aromanielloNTIA Mar 28, 2024
2419998
simplify parameterization of get_calibration
aromanielloNTIA Mar 28, 2024
2eb839f
simplify calibration file example
aromanielloNTIA Mar 28, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .github/workflows/github-actions-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -75,8 +75,8 @@ jobs:
source ./env.template
export MOCK_SIGAN=1
export MOCK_SIGAN_RANDOM=1
docker-compose build --no-cache
docker-compose up -d
docker compose build --no-cache
docker compose up -d

- name: Wait for containers # wait for containers to finish starting
run: sleep 45
Expand Down
8 changes: 4 additions & 4 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -19,24 +19,24 @@ repos:
- id: end-of-file-fixer
- id: trailing-whitespace
- repo: https://github.com/asottile/pyupgrade
rev: v3.15.0
rev: v3.15.2
hooks:
- id: pyupgrade
args: ["--py38-plus"]
- repo: https://github.com/pycqa/isort
rev: 5.12.0
rev: 5.13.2
hooks:
- id: isort
name: isort (python)
types: [file, python]
args: ["--profile", "black", "--filter-files", "--gitignore"]
- repo: https://github.com/psf/black
rev: 23.10.1
rev: 24.3.0
hooks:
- id: black
types: [file, python]
- repo: https://github.com/igorshubovych/markdownlint-cli
rev: v0.37.0
rev: v0.39.0
hooks:
- id: markdownlint
types: [file, markdown]
Expand Down
129 changes: 61 additions & 68 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -292,7 +292,9 @@ scos-sensor website from the same computer as where it is hosted.
When running in a production environment or on a remote system, various settings will
need to be configured.

## docker-compose.yml
### Compose File

This section details configuration which takes place in `compose.yaml`:

- shm_size: This setting is overriding the default setting of 64 mb. If using
scos-sensor on a computer with lower memory, this may need to be decreased. This is
Expand Down Expand Up @@ -321,6 +323,9 @@ settings in the environment file:
By default, this is configured to
use a version of `ghcr.io/ntia/scos-tekrsa/tekrsa_usb` to use a Tektronix
signal analyzer.
- CALIBRATION_EXPIRATION_LIMIT: Number of seconds elapsed for a calibration result to
become expired. On startup, if existing calibration is expired, the action defined by
STARTUP_CALIBRATION_ACTION will be run to generate new calibration data.
- CALLBACK_AUTHENTICATION: Sets how to authenticate to the callback URL. Supports
`TOKEN` or `CERT`.
- CALLBACK_SSL_VERIFICATION: Set to “true” in production environment. If false, the SSL
Expand Down Expand Up @@ -353,6 +358,7 @@ settings in the environment file:
certificate.
- POSTGRES_PASSWORD: Sets password for the Postgres database for the “postgres” user.
Change in production. The env.template file sets to a randomly generated value.
- RAY_INIT: If set to true, SCOS Sensor will ensure initializaiton of the Ray library.
- REPO_ROOT: Root folder of the repository. Should be correctly set by default.
- SCOS_SENSOR_GIT_TAG: The scos-sensor branch name. This value may be used in action
metadata to capture the version of the software that produced the sigmf archive.
Expand All @@ -379,6 +385,8 @@ settings in the environment file:
scos-sensor repository with a valid certificate in production.
- SSL_KEY_PATH: Path to server SSL private key. Use the private key for your valid
certificate in production.
- STARTUP_CALIBRATION_ACTION: The name of an available action which will run on startup
if no unexpired calibration data is already present.
- USB_DEVICE: Optional string used to search for available USB devices. By default,
this is set to Tektronix to see if the Tektronix signal analyzer is available. If
the specified value is not found in the output of lsusb, scos-sensor will attempt
Expand Down Expand Up @@ -420,95 +428,80 @@ specific to the sensor you are using.
}
```

### Sensor Calibration File
### Calibration Files

By default, scos-sensor will use `configs/default_calibration.json` as the sensor
calibration file. However, if`configs/sensor_calibration.json` or
`configs/sigan_calibration.json` exist they will be used instead of the default
calibration file. Sensor calibration files allow scos-sensor to apply a gain based
on a laboratory calibration of the sensor and may also contain other useful
metadata that characterizes the sensor performance. For additional
information on the calibration data, see the
[NTIA-Sensor SigMF Calibration Object](https://github.com/NTIA/sigmf-ns-ntia/blob/master/ntia-sensor.sigmf-ext.md#08-the-calibration-object).
The default calibration file is shown below:
Calibration files allow SCOS Sensor to scale data based on a laboratory and/or
in-field calibration of the sensor, and may also contain other useful metadata that
characterizes the sensor performance. Two primary types of calibration files are used:
sensor calibration files and differential calibration files.

```json
{
"calibration_data":{
"datetime": "1970-01-01T00:00:00.000000Z",
"gain": 0,
"noise_figure": null,
"1db_compression_point": null,
"enbw": null,
"temperature": 26.85
},
"last_calibration_datetime": "1970-01-01T00:00:00.000000Z",
"calibration_parameters": [],
"clock_rate_lookup_by_sample_rate": [
],
"sensor_uid": "DEFAULT CALIBRATION",
"calibration_reference": "noise source output"
}
```
Sensor calibration files may be provided upon sensor deployment or generated by onboard
calibration actions. If both exist, onboard calibration data takes priority. The
sensor will first attempt to load `configs/onboard_sensor_calibration.json`, and fall
back to `configs/sensor_calibration.json` if the first option fails. Next, SCOS determines
whether the loaded calibration data is expired, based on the threshold set by the
CALIBRATION_EXPIRATION_LIMIT threshold. If calibration data is expired, the sensor will
attempt to run the calibration action defined by STARTUP_CALIBRATION_ACTION.

SCOS Sensor also supports an additional calibration file, called a differential
calibration. The differential calibration is used to provide additional scaling factors
to shift the reference point of data from the onboard calibration terminal to elsewhere
in the signal path. For instance, a differential calibration file can be provided with
scaling factors to shift the data reference point from the onboard calibration terminal
to the antenna port. The differential calibration is loaded separately, and used in
addition to, either the onboard or lab-provided sensor calibration file.

#### Calibration File Contents

In sensor calibration files, the unit of calibration data is defined by the
[NTIA-Sensor SigMF Calibration Object](https://github.com/NTIA/sigmf-ns-ntia/blob/master/ntia-sensor.sigmf-ext.md#08-the-calibration-object).
In differential calibration files, the only key in the calibration data is `loss`.

The `calibration_parameters` key lists the parameters that will be used to obtain
the calibration data. In the case of the default calibration, there are no
`calibration_parameters` so the calibration data is found directly within the
`calibration_data` element and by default scos-sensor will not apply any additional
gain. Typically, a sensor would be calibrated at particular
sensing parameters. The calibration data for specific parameters should be listed
within the calibration_data object and accessed by the values of the settings
listed in the calibration_parameters element. For example, the calibration below
provides an example of a sensor calibrated at a sample rate of 14000000.0 samples
per second at several frequencies with a signal analyzer reference level setting of -25.
the calibration data. In the case of onboard calibration being generated from scratch,
the startup calibration action's signal analyzer settings are used as the `calibration_parameters`.
The calibration data is found directly within the `calibration_data` element and by
default SCOS Sensor will not apply any additional gain. Typically, a sensor would be
calibrated at particular sensing parameters. The calibration data for specific parameters
should be listed within the `calibration_data` object and accessed by the values of the
settings listed in the calibration_parameters element. For example, the sensor
calibration below provides an example of a sensor calibrated at a sample rate of
140000000 samples per second at several frequencies with a signal analyzer reference
level setting of -25.
jhazentia marked this conversation as resolved.
Show resolved Hide resolved

```json
{
"last_calibration_datetime": "2023-10-23T14:39:13.682Z",
"calibration_parameters": [
"sample_rate",
"frequency",
"reference_level",
"preamp_enable",
"attenuation"
"reference_level"
],
"clock_rate_lookup_by_sample_rate": [],
"calibration_data": {
"14000000.0": {
"3545000000.0": {
"-25": {
"true": {
"0": {
"datetime": "2023-10-23T14:38:02.882Z",
"gain": 30.09194805857024,
"noise_figure": 4.741521295220736,
"temperature": 15.6
}
}
"datetime": "2023-10-23T14:38:02.882Z",
"gain": 30.09194805857024,
"noise_figure": 4.741521295220736,
"temperature": 15.6
}
},
"3555000000.0": {
"-25": {
"true": {
"0": {
"datetime": "2023-10-23T14:38:08.022Z",
"gain": 30.401008416406599,
"noise_figure": 4.394893979804061,
"temperature": 15.6
}
}
"datetime": "2023-10-23T14:38:08.022Z",
"gain": 30.401008416406599,
"noise_figure": 4.394893979804061,
"temperature": 15.6
}
},
"3565000000.0": {
"-25": {
"true": {
"0": {
"datetime": "2023-10-23T14:38:11.922Z",
"gain": 30.848049817892105,
"noise_figure": 4.0751785215495819,
"temperature": 15.6
}
}
"datetime": "2023-10-23T14:38:11.922Z",
"gain": 30.848049817892105,
"noise_figure": 4.0751785215495819,
"temperature": 15.6
}
}
}
Expand All @@ -518,7 +511,7 @@ per second at several frequencies with a signal analyzer reference level setting

When an action is run with the above calibration, SCOS will expect the action to have
a sample_rate, frequency, and reference_level specified in the action config. The values
jhazentia marked this conversation as resolved.
Show resolved Hide resolved
specified for these parameters will then be used to retrieve the calibration data.
specified for these parameters will then be used to retrieve the calibration data entry.

## Security

Expand Down Expand Up @@ -844,7 +837,7 @@ for additional information. Be sure to re-source the environment file, update th
requirements files, and prune any existing containers
before rebuilding scos-sensor.

## Preselector Support
### Preselector Support

Scos-sensor can be configured to support
[preselectors](http://www.github.com/ntia/Preselector).
Expand All @@ -858,7 +851,7 @@ in docker-compose.yaml to the python module that contains the
preselector implementation you specify in PRESELECTOR_CLASS in
docker-compose.yaml.

## Relay Support
### Relay Support

Scos-sensor can be configured with zero or more [network controlled relays](https://www.controlbyweb.com/webrelay/).
The default relay configuration directory is configs/switches.
Expand Down
5 changes: 3 additions & 2 deletions docker-compose.yml → compose.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
version: '3'

services:
db:
image: postgres:15-alpine
Expand Down Expand Up @@ -45,6 +43,7 @@ services:
- ADDITIONAL_USER_NAMES
- ADDITIONAL_USER_PASSWORD
- AUTHENTICATION
- CALIBRATION_EXPIRATION_LIMIT
- CALLBACK_AUTHENTICATION
- CALLBACK_SSL_VERIFICATION
- CALLBACK_TIMEOUT
Expand All @@ -70,6 +69,8 @@ services:
- SIGAN_CLASS
- SIGAN_POWER_SWITCH
- SIGAN_POWER_CYCLE_STATES
- STARTUP_CALIBRATION_ACTION
- RAY_INIT
- RUNNING_MIGRATIONS
- USB_DEVICE
expose:
Expand Down
16 changes: 0 additions & 16 deletions configs/default_calibration.json

This file was deleted.

16 changes: 10 additions & 6 deletions env.template
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,7 @@ ADMIN_PASSWORD=password

# set to CERT to enable scos-sensor certificate authentication
AUTHENTICATION=TOKEN

BASE_IMAGE=ghcr.io/ntia/scos-tekrsa/tekrsa_usb:0.2.3
CALIBRATION_EXPIRATION_LIMIT=360
# Default callback api/results
# Set to CERT for certificate authentication
CALLBACK_AUTHENTICATION=TOKEN
Expand All @@ -34,8 +33,6 @@ CALLBACK_TIMEOUT=2
# Use either true or false
DEBUG=true

DEVICE_MODEL=RSA507A

# Use latest as default for local development
DOCKER_TAG=latest

Expand Down Expand Up @@ -75,8 +72,12 @@ SCOS_SENSOR_GIT_TAG="$(git describe --tags)"
# SECURITY WARNING: generate unique key with `manage.py generate_secret_key`
SECRET_KEY="$(python3 -c 'import secrets; print(secrets.token_urlsafe(64))')"

# Signal analyzer selection/setup
SIGAN_CLASS=TekRSASigan
SIGAN_MODULE=scos_tekrsa.hardware.tekrsa_sigan
USB_DEVICE=Tektronix
DEVICE_MODEL=RSA507A
BASE_IMAGE=ghcr.io/ntia/scos-tekrsa/tekrsa_usb:latest

# SECURITY WARNING: You should be using certs from a trusted authority.
# If you don't have any, try letsencrypt or a similar service.
Expand All @@ -86,8 +87,11 @@ SSL_CA_PATH=scos_test_ca.crt
SSL_CERT_PATH=sensor01.pem
SSL_KEY_PATH=sensor01.pem

USB_DEVICE=Tektronix

# Calibration action selection
# The action specified here will be used to attempt an onboard
# sensor calibration on startup, if no onboard calibration data
# is available on startup. The specified action must be available.
STARTUP_CALIBRATION_ACTION=SEA_CBRS_Calibrate_Baseline

# Debug dependant settings
if $DEBUG; then
Expand Down
1 change: 0 additions & 1 deletion gunicorn/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@
import sys
from multiprocessing import cpu_count


bind = ":8000"
workers = 1
worker_class = "gthread"
Expand Down
5 changes: 1 addition & 4 deletions src/handlers/apps.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
from scos_actions.signals import (
location_action_completed,
measurement_action_completed,
trigger_api_restart
trigger_api_restart,
)

logger = logging.getLogger(__name__)
Expand All @@ -20,7 +20,6 @@ def ready(self):
db_location_deleted,
db_location_updated,
location_action_completed_callback,

)
from handlers.measurement_handler import measurement_action_completed_callback

Expand All @@ -40,5 +39,3 @@ def ready(self):

trigger_api_restart.connect(trigger_api_restart_callback)
logger.debug("trigger_api_restart_callback registered to trigger_api_restart")


Loading
Loading