Readme ====== .. image:: https://git-dev.cs.dal.ca/meridian/aisdb/badges/master/pipeline.svg .. image:: https://img.shields.io/gitlab/coverage/meridian/aisdb/master?gitlab_url=https%3A%2F%2Fgit-dev.cs.dal.ca&job_name=python-test .. image:: https://img.shields.io/gitlab/v/release/meridian/aisdb?gitlab_url=https%3A%2F%2Fgit-dev.cs.dal.ca&include_prereleases&sort=semver .. description: Description ----------- Package features: + SQL database for storing AIS position reports and vessel metadata + Vessel position cleaning and trajectory modeling + Utilities for streaming and decoding AIS data in the NMEA binary string format (See `Base Station Deployment `__) + Integration with external datasources including depth charts, distances from shore, vessel geometry, etc. + Network graph analysis, MMSI deduplication, interpolation, and other processing utilities + Data visualization .. image:: https://aisdb.meridian.cs.dal.ca/readme_example.png | Web Interface: https://aisdb.meridian.cs.dal.ca/ | Docs: https://aisdb.meridian.cs.dal.ca/doc/readme.html | Source Code: https://git-dev.cs.dal.ca/meridian/aisdb .. whatisais: What is AIS? ------------ | Wikipedia: https://en.wikipedia.org/wiki/Automatic_identification_system | Description of message types: https://arundaleais.github.io/docs/ais/ais_message_types.html Install ------- .. _install-pip: Requires Python version 3.8 or newer. Optionally requires SQLite (included in Python) or PostgresQL server (installed separately). The AISDB Python package can be installed using pip. It is recommended to install the package in a virtual Python environment such as ``venv``. .. code-block:: sh python -m venv env_ais source ./env_ais/*/activate pip install aisdb .. _install-src: For information on installing AISDB from source code, see `Installing from Source `__ .. _readme-docs: Documentation ------------- An introduction to AISDB can be found here: `Introduction `__. Additional API documentation: `API Docs `__. .. _readme-examples: Code examples ------------- 1. `Parsing raw format messages into a database `__ 2. `Automatically generate SQL database queries `__ 3. `Compute trajectories from database rows `__ 4. `Vessel trajectory cleaning and MMSI deduplication `__ 5. `Compute network graph of vessel movements between polygons `__ 6. Integrating data from web sources, such as depth charts, shore distance, etc.