From be42d953b2a66af0a818de126880632a0ccaf3d7 Mon Sep 17 00:00:00 2001 From: Marius Isken Date: Thu, 7 Mar 2024 15:47:04 +0100 Subject: [PATCH] docs: fixup --- .github/workflows/docs.yaml | 2 +- README.md | 28 ++++---- docs/benchmark.md | 14 ++-- docs/components/configuration.md | 73 +++++++++------------ docs/components/general.md | 11 +++- docs/components/image_function.md | 6 +- docs/components/octree.md | 6 +- docs/components/ray_tracer.md | 14 ++-- docs/components/seismic_data.md | 10 +-- docs/components/station_corrections.md | 12 +++- docs/getting_started.md | 87 ++++--------------------- docs/images/octree-concept.webp | Bin 40508 -> 67962 bytes docs/index.md | 7 +- docs/theme/announce.html | 2 +- docs/visualizing_results.md | 2 +- mkdocs.yml | 12 ++-- pyproject.toml | 4 +- src/qseek/utils.py | 41 +++++++++++- 18 files changed, 157 insertions(+), 174 deletions(-) diff --git a/.github/workflows/docs.yaml b/.github/workflows/docs.yaml index 232eed53..7f30ded1 100644 --- a/.github/workflows/docs.yaml +++ b/.github/workflows/docs.yaml @@ -21,5 +21,5 @@ jobs: path: .cache restore-keys: | mkdocs-material- - - run: pip install .[dev] + - run: pip install .[docs] - run: mkdocs gh-deploy --force diff --git a/README.md b/README.md index 624b9924..e1022bb3 100644 --- a/README.md +++ b/README.md @@ -1,15 +1,15 @@ -# Lassie +# Qseek *The friendly earthquake detector* -[![Build and test](https://github.com/miili/lassie-v2/actions/workflows/build.yaml/badge.svg)](https://github.com/miili/lassie-v2/actions/workflows/build.yaml) -[![Documentation](https://img.shields.io/badge/read-documentation-blue)](https://pyrocko.github.io/lassie-v2/) +[![Build and test](https://github.com/pyrocko/qseek/actions/workflows/build.yaml/badge.svg)](https://github.com/pyrocko/qseek/actions/workflows/build.yaml) +[![Documentation](https://img.shields.io/badge/read-documentation-blue)](https://pyrocko.github.io/qseek/) ![Python 3.10+](https://img.shields.io/badge/python-3.10%203.11-blue.svg) Code style: black [![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://pre-commit.com/) -Lassie is an earthquake detection and localisation framework based on stacking and migration method. It combines neural network phase picks with an iterative octree localisation approach for accurate localisation of seismic events. +Qseek is an earthquake detection and localisation framework based on stacking and migration, a beamforming method. It combines neural network phase picks with an iterative octree localisation approach for accurate localisation of seismic events. Key features are of the earthquake detection and localisation framework are: @@ -25,24 +25,24 @@ Key features are of the earthquake detection and localisation framework are: * Automatic extraction of modelled and picked travel times * Calculation and application of station corrections / station delay times -Lassie is built on top of [Pyrocko](https://pyrocko.org). +Qseek is built on top of [Pyrocko](https://pyrocko.org). -For more information check out the documentation at https://pyrocko.github.io/lassie-v2/. +For more information check out the documentation at https://pyrocko.github.io/qseek/. ## Installation Simple installation from GitHub. ```sh -pip install git+https://github.com/pyrocko/lassie-v2 +pip install git+https://github.com/pyrocko/qseek ``` ## Project Initialisation -Initialize a new project in a fresh directory. +Show the default config. ```sh -lassie init my-project/ +qseek config ``` Edit the `my-project.json` @@ -50,7 +50,7 @@ Edit the `my-project.json` Start the earthquake detection with ```sh -lassie search search.json +qseek search search.json ``` ## Packaging @@ -62,7 +62,7 @@ The simplest and recommended way of installing from source: Local development through pip. ```sh -cd lassie-v2 +cd qseek pip3 install .[dev] ``` @@ -74,12 +74,12 @@ pre-commit install ## Citation -Please cite lassie as: +Please cite Qseek as: -> TBD +> Marius Paul Isken, Peter Niemz, Jannes Münchmeyer, Sebastian Heimann, Simone Cesca, Torsten Dahm, Qseek: A data-driven Framework for Machine-Learning Earthquake Detection, Localization and Characterization, Seismica, 2024, *submitted* ## License Contribution and merge requests by the community are welcome! -Lassie-v2 was written by Marius Paul Isken and is licensed under the GNU GENERAL PUBLIC LICENSE v3. +Qseek was written by Marius Paul Isken and is licensed under the GNU GENERAL PUBLIC LICENSE v3. diff --git a/docs/benchmark.md b/docs/benchmark.md index 773b2710..b3c2f1ae 100644 --- a/docs/benchmark.md +++ b/docs/benchmark.md @@ -2,7 +2,7 @@ ## Computation Performance -Lassie is built for searching in large-N data sets. The implementation is leveraging Python [`asyncio`](https://docs.python.org/3/library/asyncio.html) heavily to implement threading and keeping the CPU busy. It is built on top of highly performant Pyrocko functions implemented in C language. The inference is using [PyTorch](https://pytorch.org/) which enables GPU computation of the seismic imaging functions. +Qseek is built for searching in large-N data sets. The implementation is leveraging Python [`asyncio`](https://docs.python.org/3/library/asyncio.html) heavily to implement threading and keeping the CPU busy. It is built on top of highly performant Pyrocko functions implemented in C language. The inference is using [PyTorch](https://pytorch.org/) which enables GPU computation of the seismic imaging functions. This enables high throughput of seismic data in different scenarios. @@ -22,7 +22,7 @@ A list of other projects using stacking and migration approach to back-project s ### Lassie-v1 -Lassie - The friendly Earthquake detector in version 1. The re-writen version of Lassie utilizes the same heavy-duty functions for stacking and migration as Lassie v1. +Lassie - The friendly Earthquake detector in version 1. Qseek utilizes the same optimized heavy-duty functions for stacking and migration as Lassie v1. [Lassie-v1 on Pyrocko Git](https://git.pyrocko.org/pyrocko/lassie) @@ -30,7 +30,13 @@ Lassie - The friendly Earthquake detector in version 1. The re-writen version of QuakeMigrate uses a waveform migration and stacking algorithm to search for coherent seismic phase arrivals across a network of instruments. It produces—from raw data—catalogues of earthquakes with locations, origin times, phase arrival picks, and local magnitude estimates, as well as rigorous estimates of the associated uncertainties. -[QuakeMigrate on GitHub](https://git.pyrocko.org/pyrocko/lassie) +[QuakeMigrate on GitHub](https://github.com/QuakeMigrate/QuakeMigrate) + +### BPMF + +Complete framework for earthquake detection and location: Backprojection and matched-filtering (BPMF), with methods for automatic picking, relocation and efficient waveform stacking. + +[BPMF on GitHub](https://github.com/ebeauce/Seismic_BPMF) ### Loki @@ -40,6 +46,6 @@ LOKI (LOcation of seismic events through traveltime staKIng) is a code that perf ### MALMI -MALMI (MAchine Learning aided earthquake MIgration location). +MALMI (MAchine Learning aided earthquake MIgration location), variant of Loki for detecting and locating earthquakes using ML image functions provided by SeisBench. [MALMI on GitHub](https://github.com/speedshi/MALMI) diff --git a/docs/components/configuration.md b/docs/components/configuration.md index ecc5d44c..f57ed9d6 100644 --- a/docs/components/configuration.md +++ b/docs/components/configuration.md @@ -1,4 +1,4 @@ -# Lassie Configuration +# Qseek Configuration At center is a JSON configuration file which is parsed by [Pydantic](https://docs.pydantic.dev/). The following pages will detail how to setup this JSON file for the search. @@ -12,17 +12,17 @@ The search configuration. **This is the entrypoint for the EQ detection and loca More information on the submodules (e.g. Octree, Data Provider and other) can be found on subpages in the navigation. ```python exec='on' -from lassie.utils import generate_docs -from lassie.search import Search +from qseek.utils import generate_docs +from qseek.search import Search print(generate_docs(Search())) ``` ## Minimal Config -This is a minimal config which can used to start a Lassie search. +This is a minimal config which can used to start a Qseek search. -```json title="Minimal Lassie Config" +```json title="Minimal Qseek Config" { "project_dir": ".", "stations": { @@ -94,44 +94,31 @@ This is a minimal config which can used to start a Lassie search. Structure of the search and optimisation of the octree, which is focusing in on seismic energy. ```mermaid -flowchart TD - - -subgraph Data Input - waveforms(["Seismic Waveforms"]) - image[" - Phase Image Function - PhaseNet, EQTransformer, ... - "] -end -subgraph Migration - quadtree["Quadtree"] - travelTimes[" - Seismic Travel Time Model - 1D Raytracer, ... - "] -end -subgraph Detection - search["Stacking Image Functions"] - detection["EQ Event Detection & Localisation"] -end -featureExtraction[" - Feature Extraction - Local Magnitude, Ground Motion, ... -"] -stationCorrections[" - Traveltime residuals from Image - → Station Corrections -"] - -waveforms --> image -image --> search -quadtree --> travelTimes -travelTimes -->search -detection -- Refine Quadtree --> search -search --> detection -detection --> featureExtraction -detection --> stationCorrections +%%{init: {'theme': 'neutral', 'themeVariables': { 'fontSize': '14pt'}}}%% +flowchart LR + subgraph Seismic Data + waveforms(["fa:fa-water Seismic\nWaveforms"]) + image{{"fa:fa-bolt Waveform Image Function\nPhaseNet / EQTransformer / ..."}} + waveforms --> image + end + subgraph Travel Time Model + travelTimes(["fa:fa-layer-group Seismic\nTravel Time Model"]) + stationCorrections{{"fab:fa-arrows-to-dot Station Corrections\nSST / SSST"}} + travelTimes -->|add| stationCorrections + end + subgraph Stacking and Migration + octree["fa:fa-cubes\nOctree Grid"] + detection["fa:fa-bullseye Detection\nand Localisation"] + end + featureExtraction("fa:fa-info Extract Event Features\nMagnitudes, Ground Motion, ...") + correctionExtraction("fa:fa-stopwatch Extract\nStation Corrections") + + image --> octree + stationCorrections --> octree + detection -.->|"fa:fa-cube\nRefine"| octree + octree --> detection + detection --> featureExtraction & correctionExtraction + ``` *Building blocks of the specific stacking and migration method for earthquake detection, localisation and characterisation.* diff --git a/docs/components/general.md b/docs/components/general.md index 62479d20..d84eb726 100644 --- a/docs/components/general.md +++ b/docs/components/general.md @@ -6,10 +6,15 @@ Paths can be relative to the location of the config file or absolute. **File pat ## Date and Time -Serialisation of time, dates and date times and durations follow [ISO8601](https://en.wikipedia.org/wiki/ISO_8601) format with timezone information. E.g. `2023-10-28T01:21:21.003+00:00`. +Serialisation of time, dates and date times and durations follow [ISO8601](https://en.wikipedia.org/wiki/ISO_8601) format with timezone information. E.g. `2023-10-28T01:21:21.003Z`. Duration are serialized like `PT600S`, this example shows a duration of 600 seconds, 10 minutes. + +!!!+ note Timezone Info + All datetimes are timezone aware! For UTC this is the `Z` or `+00:00` suffix. + Also other offsets can be defined according to [ISO8601](https://en.wikipedia.org/wiki/ISO_8601). + ```json title="Example of datetimes and durations" { "start_time": "2023-10-28T01:21:21.003+00:00", @@ -25,8 +30,8 @@ Geographic locations have a geographic reference and a relative shift in meters. All **distances, depths and elevations are given in meters**. ```python exec='on' -from lassie.utils import generate_docs -from lassie.models.location import Location +from qseek.utils import generate_docs +from qseek.models.location import Location print(generate_docs(Location(lat= 52.3825, lon=13.0644))) ``` diff --git a/docs/components/image_function.md b/docs/components/image_function.md index 10582bf3..99e2c90c 100644 --- a/docs/components/image_function.md +++ b/docs/components/image_function.md @@ -1,6 +1,6 @@ # Image Function -For image functions this version of Lassie relies heavily on machine learning pickers delivered by [SeisBench](https://github.com/seisbench/seisbench). +For image functions this version of Qseek relies heavily on machine learning pickers delivered by [SeisBench](https://github.com/seisbench/seisbench). ## PhaseNet Image Function @@ -8,8 +8,8 @@ For image functions this version of Lassie relies heavily on machine learning pi *Zhu, Weiqiang, and Gregory C. Beroza. "PhaseNet: A Deep-Neural-Network-Based Seismic Arrival Time Picking Method." arXiv preprint arXiv:1803.03211 (2018).* ```python exec='on' -from lassie.utils import generate_docs -from lassie.images.phase_net import PhaseNet +from qseek.utils import generate_docs +from qseek.images.phase_net import PhaseNet print(generate_docs(PhaseNet())) ``` diff --git a/docs/components/octree.md b/docs/components/octree.md index 27dcc802..7787a252 100644 --- a/docs/components/octree.md +++ b/docs/components/octree.md @@ -1,14 +1,14 @@ # Octree -A 3D space is searched for sources of seismic energy. Lassie created an octree structure which is iteratively refined when energy is detected, to focus on the source' location. This speeds up the search and improves the resolution of the localisations. +A 3D space is searched for sources of seismic energy. Qseek created an octree structure which is iteratively refined when energy is detected, to focus on the source' location. This speeds up the search and improves the resolution of the localisations. ![Octree Concept](../images/octree-concept.webp) *Surface projection of the refined octree focusing on the seismic source region. In this example four levels of refinement are can be seen, refining the 3D octree from the initial 4000 nodes to 8823 nodes.* ```python exec='on' -from lassie.utils import generate_docs -from lassie.octree import Octree +from qseek.utils import generate_docs +from qseek.octree import Octree print(generate_docs(Octree())) ``` diff --git a/docs/components/ray_tracer.md b/docs/components/ray_tracer.md index 45fc27ac..1c59d9fc 100644 --- a/docs/components/ray_tracer.md +++ b/docs/components/ray_tracer.md @@ -1,6 +1,6 @@ # Ray Tracers -The calculation of seismic travel times is a cornerstone for the migration and stacking approach. Lassie supports different ray tracers for travel time calculation, which can be adapted for different geological settings. +The calculation of seismic travel times is a cornerstone for the migration and stacking approach. Qseek supports different ray tracers for travel time calculation, which can be adapted for different geological settings. ## Constant Velocity @@ -13,8 +13,8 @@ $$ This module is used for simple use cases and cross-referencing testing. ```python exec='on' -from lassie.utils import generate_docs -from lassie.tracers.constant_velocity import ConstantVelocityTracer +from qseek.utils import generate_docs +from qseek.tracers.constant_velocity import ConstantVelocityTracer print(generate_docs(ConstantVelocityTracer())) ``` @@ -27,8 +27,8 @@ Calculation of travel times in 1D layered media is based on the [Pyrocko Cake](h *Pyrocko Cake 1D ray tracer for travel time calculation in 1D layered media* ```python exec='on' -from lassie.utils import generate_docs -from lassie.tracers.cake import CakeTracer +from qseek.utils import generate_docs +from qseek.tracers.cake import CakeTracer print(generate_docs(CakeTracer(), exclude={'earthmodel': {'raw_file_data'}})) ``` @@ -45,8 +45,8 @@ We implement the fast marching method for calculating first arrivals of waves in *Conceptual 2D visualisation for seismic traveltimes calculation in heterogenous media using the fast-marching method for the Eikonal solution is presented. Traveltimes from the receiving station at the surface (indicated by a yellow triangle) towards the subsurface grid are calculated, resulting in station-specifig traveltimes for all potential source locations simultaneously.* ```python exec='on' -from lassie.utils import generate_docs -from lassie.insights.tracers.fast_marching import FastMarchingTracer +from qseek.utils import generate_docs +from qseek.insights.tracers.fast_marching import FastMarchingTracer print(generate_docs(FastMarchingTracer())) ``` diff --git a/docs/components/seismic_data.md b/docs/components/seismic_data.md index 9c6b95d6..84aa1011 100644 --- a/docs/components/seismic_data.md +++ b/docs/components/seismic_data.md @@ -2,13 +2,13 @@ ## Waveform Data -The seismic can be delivered in MiniSeed or any other format compatible with Pyrocko. Lassie utilizes the Pyrocko Squirrel for fast and asynchronous data access. +The seismic can be delivered in MiniSeed or any other format compatible with Pyrocko. Qseek utilizes the Pyrocko Squirrel for fast and asynchronous data access. To prepare your data for EQ detection and localisation, **organize it in a MiniSeed file or an [SDS structure](https://www.seiscomp.de/doc/base/concepts/waveformarchives.html)**. ```python exec='on' -from lassie.utils import generate_docs -from lassie.waveforms import PyrockoSquirrel +from qseek.utils import generate_docs +from qseek.waveforms.squirrel import PyrockoSquirrel print(generate_docs(PyrockoSquirrel())) ``` @@ -25,8 +25,8 @@ Supported data formats are: Metadata does not need to include response information for pure detection and localisation. If local magnitudes M~L~ are extracted, response information is required. ```python exec='on' -from lassie.utils import generate_docs -from lassie.models.station import Stations +from qseek.utils import generate_docs +from qseek.models.station import Stations print(generate_docs(Stations())) ``` diff --git a/docs/components/station_corrections.md b/docs/components/station_corrections.md index 810c1073..c98d2dbe 100644 --- a/docs/components/station_corrections.md +++ b/docs/components/station_corrections.md @@ -3,8 +3,16 @@ Station corrections can be extract from previous runs to refine the localisation accuracy. The corrections can also help to improve the semblance find more events in a dataset. ```python exec='on' -from lassie.utils import generate_docs -from lassie.station_corrections import StationCorrections +from qseek.utils import generate_docs +from qseek.insights import StationCorrections print(generate_docs(StationCorrections())) ``` + + +```python exec='on' +from qseek.utils import generate_docs +from qseek.insights import SourceSpecificStationCorrections + +print(generate_docs(SourceSpecificStationCorrections())) +``` diff --git a/docs/getting_started.md b/docs/getting_started.md index 74e84290..a2ff40c5 100644 --- a/docs/getting_started.md +++ b/docs/getting_started.md @@ -5,102 +5,39 @@ The installation is straight-forward: ```sh title="From GitHub" -pip install git+https://github.com/pyrocko/lassie-v2 +pip install git+https://github.com/pyrocko/qseek ``` -## Running Lassie +## Running Qseek -The main entry point in the executeable is the `lassie` command. The provided command line interface (CLI) and a JSON config file is all what is needed to run the program. +The main entry point in the executeable is the `qseek` command. The provided command line interface (CLI) and a JSON config file is all what is needed to run the program. ```bash exec='on' result='ansi' source='above' -lassie --help +qseek --help ``` ## Initializing a New Project -Once installed you can run the lassie executeable to initialize a new project. +Once installed you can run the `qseek` executeable to initialize a new project. ```sh title="Initialize new Project" -lassie init my-project +qseek config > my-search.json ``` -Check out the `search.json` config file and add your waveform data and velocity models. +Check out the `my-search.json` config file and add your waveform data and velocity models. ??? abstract "Minimal Configuration Example" - Here is a minimal JSON configuration for Lassie - ```json - { - "project_dir": ".", - "stations": { - "station_xmls": [], - "pyrocko_station_yamls": ["search/pyrocko-stations.yaml"], - }, - "data_provider": { - "provider": "PyrockoSquirrel", - "environment": ".", - "waveform_dirs": ["data/"], - }, - "octree": { - "location": { - "lat": 0.0, - "lon": 0.0, - "east_shift": 0.0, - "north_shift": 0.0, - "elevation": 0.0, - "depth": 0.0 - }, - "root_node_size": 2000.0, - "n_levels": 3, - "east_bounds": [ - -10000.0, - 10000.0 - ], - "north_bounds": [ - -10000.0, - 10000.0 - ], - "depth_bounds": [ - 0.0, - 20000.0 - ], - "absorbing_boundary": 1000.0 - }, - "image_functions": [ - { - "image": "PhaseNet", - "model": "ethz", - "torch_use_cuda": false, - "phase_map": { - "P": "constant:P", - "S": "constant:S" - }, - } - ], - "ray_tracers": [ - { - "tracer": "ConstantVelocityTracer", - "phase": "constant:P", - "velocity": 5000.0 - } - ], - "station_corrections": {}, - "event_features": [], - "sampling_rate": 100, - "detection_threshold": 0.05, - "detection_blinding": "PT2S", - "node_split_threshold": 0.9, - "window_length": "PT300S", - "n_threads_parstack": 0, - "n_threads_argmax": 4, - } + Here is a minimal JSON configuration for Qseek + ```bash exec='on' result='json' + qseek config ``` For more details and information about the component, head over to [details of the modules](components/seismic_data.md). ## Starting the Search -Once happy, start the lassie CLI. +Once happy, start the `qseek` CLI. ```sh title="Start earthquake detection" -lassie search search.json +qseek search my-search.json ``` diff --git a/docs/images/octree-concept.webp b/docs/images/octree-concept.webp index 3a91c95fa57010847cf35dc0d7d6702f51070476..7fdc71dc1aa4b453759adb56b89a6cb40cd59294 100644 GIT binary patch literal 67962 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�Oq{f7-n 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 literal 40508 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 YY9XZH4x{a!k(R$?r!!Zn|Bu)8AFI7~7ytkO diff --git a/docs/index.md b/docs/index.md index 97e69af2..2b9fffa9 100644 --- a/docs/index.md +++ b/docs/index.md @@ -1,11 +1,12 @@ -# Welcome to Lassie 🐕‍🦺 +# Welcome to Qseek 🐕‍🦺 -Lassie is an earthquake detection and localisation framework. It combines modern **machine learning phase detection and robust migration and stacking techniques**. +Qseek is an earthquake detection and localisation framework. It combines modern **machine learning phase detection and robust migration and stacking techniques**. The detector is leveraging [Pyrocko](https://pyrocko.org) and [SeisBench](https://github.com/seisbench/seisbench), it is highly-performant and can search massive data sets for seismic activity efficiently. !!! abstract "Citation" - TDB + Marius Paul Isken, Peter Niemz, Jannes Münchmeyer, Sebastian Heimann, Simone Cesca, Torsten Dahm, Qseek: A data-driven Framework for Machine-Learning Earthquake Detection, Localization and Characterization, Seismica, 2024, *submitted* + ![Reykjanes detections](images/reykjanes-demo.webp) diff --git a/docs/theme/announce.html b/docs/theme/announce.html index 594d6af7..1a9be47d 100644 --- a/docs/theme/announce.html +++ b/docs/theme/announce.html @@ -1 +1 @@ -Lassie is in Beta 🧫 Please handle with care +Qseek is in Beta 🧫 Please handle with care diff --git a/docs/visualizing_results.md b/docs/visualizing_results.md index 850c9bb2..250cce09 100644 --- a/docs/visualizing_results.md +++ b/docs/visualizing_results.md @@ -1,6 +1,6 @@ # Visualizing Detections -The event detections are exported in Lassie-native JSON, Pyrocko YAML format and as CSV files. +The event detections are exported in Qseek-native JSON, Pyrocko YAML format and as CSV files. ## Pyrocko Sparrow diff --git a/mkdocs.yml b/mkdocs.yml index 2d6b68ba..f5d4549b 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -1,9 +1,9 @@ -site_name: Lassie - Earthquake Detector +site_name: Qseek - Earthquake Detection and Localization site_description: The friendly earthquake detector site_author: Marius Paul Isken -repo_url: https://github.com/pyrocko/lassie-v2 -repo_name: pyrocko/lassie-v2 +repo_url: https://github.com/pyrocko/qseek +repo_name: pyrocko/qeek edit_uri: edit/main/docs/ theme: @@ -13,13 +13,13 @@ theme: - scheme: default primary: blue grey toggle: - icon: material/toggle-switch + icon: material/eye name: Switch to dark mode # Palette toggle for dark mode - scheme: slate primary: blue grey toggle: - icon: material/toggle-switch-off-outline + icon: material/eye-outline name: Switch to light mode icon: repo: fontawesome/brands/git-alt @@ -60,7 +60,7 @@ extra_javascript: - https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js watch: - - lassie + - src/qseek plugins: - search diff --git a/pyproject.toml b/pyproject.toml index b6a7199f..b6c746df 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -71,9 +71,9 @@ dev = [ ] docs = [ - "mkdocs-material>=9.4.8", + "mkdocs-material>=9.5.13", "mkdocstrings[python]>=0.23", - "qseek-insights", + "markdown-exec>=1.8.0", ] completion = ["argcomplete>=3.2"] diff --git a/src/qseek/utils.py b/src/qseek/utils.py index eaa69e65..a765b353 100644 --- a/src/qseek/utils.py +++ b/src/qseek/utils.py @@ -24,7 +24,7 @@ ) import numpy as np -from pydantic import AfterValidator, ByteSize, constr +from pydantic import AfterValidator, BaseModel, ByteSize, constr from pyrocko.util import UnavailableDecimation from rich.logging import RichHandler @@ -553,3 +553,42 @@ class ChannelSelectors: NSL_RE = r"^[a-zA-Z0-9]{0,2}\.[a-zA-Z0-9]{0,5}\.[a-zA-Z0-9]{0,3}$" + + +def generate_docs(model: BaseModel, exclude: dict | set | None = None) -> str: + """Takes model and dumps markdown for documentation""" + + def generate_submodel(model: BaseModel) -> list[str]: + lines = [] + for name, field in model.model_fields.items(): + if field.description is None: + continue + lines += [ + f" - **`{name}`** *`{field.annotation}`*\n", + f" {field.description}", + ] + return lines + + model_name = model.__class__.__name__ + lines = [f"### {model_name} Module"] + if model.__class__.__doc__ is not None: + lines += [f"{model.__class__.__doc__}\n"] + lines += [f'=== "Config {model_name}"'] + for name, field in model.model_fields.items(): + if field.description is None: + continue + lines += [ + f" **`{name}`**\n", + f" : {field.description}\n", + ] + + def dump_json() -> list[str]: + dump = model.model_dump_json(by_alias=False, indent=2, exclude=exclude) + lines = dump.split("\n") + return [f" {line}" for line in lines] + + lines += ['=== "JSON Block"'] + lines += [f" ```json title='JSON block for {model_name}'"] + lines.extend(dump_json()) + lines += [" ```"] + return "\n".join(lines)