Skip to content

ucgmsim/velocity_modelling

Repository files navigation

NZ Community Velocity Model

License: MIT Python 3.11+

This repository contains the code for generating and working with the NZ Community Velocity Model (NZCVM). The NZCVM provides detailed 3D representations of New Zealand's subsurface velocity structure for seismic hazard analysis and earthquake engineering.

Note: The actual data files are maintained in a separate repository: nzcvm_data

Overview

This codebase provides tools to:

  • Generate 3D velocity models from various geophysical datasets
  • Extract 1D velocity profiles at specific locations
  • Create cross-sections from 3D velocity models
  • Compute threshold values (Vs30, Vs500, Z1.0, Z2.5) for station locations
  • Process and integrate multiple data sources (tomography, basin models, surface geology)

The NZCVM integrates datasets from numerous geophysical and geological studies, specifying compression wave velocity (Vp), shear wave velocity (Vs), and density (Rho) at specified locations in a 3D grid. By embedding discrete regional models into lower-resolution tomography data, the NZCVM provides a unified velocity model suitable for broadband physics-based ground motion simulations.

Architecture

The system uses a model version system as the primary interface between code and data:

  • Code Repository (this repo): Contains processing algorithms and model version definitions
  • Data Repository (nzcvm_data): Contains geophysical datasets and data registry
  • Model Versions: YAML files that specify which data components to use and how to combine them

This separation allows independent version control of code and data while maintaining flexible model configurations.

Key Components

  • Model Versions: Primary interface defining which data components to use
  • Output Formats: Details about the output formats, including the emod3d, csv and HDF5 formats

Requirements and Installation

Prerequisites

  • Python 3.11 or later
  • Git (for cloning the repository)
  • Git LFS (for large data files in the data repository. See Git LFS Installation)
  • Approximately 3GB of disk space for the full dataset and code
  • (Optional) Virtual environment tool (e.g., venv, conda)

Installation

# Install the modelling code
pip install velocity-modelling

Then, ensure you have the data repository. If you don't have it yet, the helper will clone it for you. If you already have it, the helper will pull the latest changes. If you have it in a custom location, you can specify that too.

# Fetch/update the dataset (default includes large LFS files)
nzcvm-data-helper ensure

# For lightweight CI/test installs (skip LFS, *Not* recommended for production):
nzcvm-data-helper ensure --no-full

# Use a custom path if you already cloned nzcvm_data:
nzcvm-data-helper ensure --path /path/to/nzcvm_data

Check where the data is located:

# Confirm where it is
nzcvm-data-helper where

Then, you can optionally export the path for your shell:

# Optionally export for your shell
export NZCVM_DATA_ROOT="$(nzcvm-data-helper where)"

For detailed installation and data setup instructions, see the Installation Guide.

Command-Line Tools

The NZCVM provides 4 main command-line tools:

1. Generate 3D Models: generate_3d_model

Creates 3D velocity models from configuration files.

generate_3d_model /path/to/config/nzcvm.cfg --out-dir /path/to/output

Key features:

  • Uses model versions to specify data components
  • Supports multiple output formats (EMOD3D, CSV, HDF5)
  • Configurable grid geometry and topography handling
  • Web interface for configuration generation

For detailed instructions, see Generating 3D Models.

2. Generate 1D Profiles: generate_1d_profiles

Extracts 1D velocity profiles at specific locations.

generate_1d_profiles sites.csv --model-version 2.03 --out-dir /path/to/output

Key features:

  • Uses same model versions as 3D generation
  • Supports custom depth sampling
  • Batch processing from CSV coordinates
  • Multiple output formats
  • Defaults to outputting in the same directory as the input CSV

For detailed instructions, see Generating 1D Profiles.

3. Extract Cross-sections: extract_cross_section

Creates cross-sections from existing 3D velocity models.

extract_cross_section /path/to/velocity_model.h5 --start-lat -41.0 --start-lon 174.0 --end-lat -41.5 --end-lon 175.0

For detailed instructions, see Extracting Cross-Sections.

4. Generate Thresholds: generate_thresholds

Computes velocity and depth threshold values (Vs30, Vs500, Z1.0, Z2.5) for station locations.

generate_thresholds locations.csv --model-version 2.07 --threshold-type Z1.0 --threshold-type Z2.5 --topo-type SQUASHED_TAPERED --out-dir /path/to/output

Key features:

  • Uses same model versions as 3D generation and 1D profiles
  • Computes Vs30, Vs500 (velocity thresholds) and Z1.0, Z2.5 (depth thresholds)
  • Configurable topography handling (default: SQUASHED)
  • Automatic basin membership determination for Z-thresholds
  • Batch processing from CSV files (default: name, lon, lat format)
  • Supports legacy station file formats with custom column indices
  • Can skip header rows with --skip-rows option
  • Output CSV includes header row by default (use --no-write-header to disable)
  • Output CSV uses input filename with .csv extension

For detailed instructions, see Generating Thresholds.

Model Version System

The model version system is the core interface that connects the velocity modeling code with the data repository. Model versions are YAML files (e.g., 2p03.yaml, 2p07.yaml) that specify:

  • Which tomography models to use
  • Which basin models to include
  • Surface handling methods
  • Special processing options (offshore tapering, GTL, smoothing)

Example model version specification:

# In nzcvm.cfg
MODEL_VERSION=2.03

This automatically loads model_versions/2p03.yaml which defines the complete model configuration.

All tools (generate_3d_model, generate_1d_profiles, generate_thresholds, extract_cross_section) use this same model version system, ensuring consistency across different analysis workflows.

For complete details, see Model Versions.

Data Files

All data files (surface models, boundaries, DEM, tomography models, etc.) are maintained in the separate nzcvm_data repository. The data repository includes:

  • nzcvm_registry.yaml: Catalog of all available datasets and their locations
  • Tomography models: Regional and national velocity models
  • Basin models: Detailed velocity structures for sedimentary basins
  • Surface data: Topography, geology, and Vs30 datasets

See the nzcvm_data README for details on available datasets and their formats. You can manage the dataset via nzcvm-data-helper.

For information about data format specifications used by this code, see the Data Formats Guide.

Quick Start Example

  1. Install both repositories:
# Install code + data
pip install git+https://github.com/ucgmsim/velocity_modelling.git
nzcvm-data-helper ensure
  1. Generate a 3D model:
   # Create basic configuration
   cat > test.cfg << EOF
   CALL_TYPE=GENERATE_VELOCITY_MOD
   MODEL_VERSION=2.03
   ORIGIN_LAT=-43.5
   ORIGIN_LON=172.5
   ORIGIN_ROT=0.0
   EXTENT_X=10
   EXTENT_Y=10
   EXTENT_ZMAX=20.0
   EXTENT_ZMIN=0.0
   EXTENT_Z_SPACING=0.5
   EXTENT_LATLON_SPACING=0.1
   MIN_VS=0.5
   TOPO_TYPE=BULLDOZED
   OUTPUT_DIR=/tmp/test_model
   EOF
   
   # Generate model
   generate_3d_model test.cfg
  1. Extract 1D profiles:
   # Create location file
  echo "id,lon,lat,zmin,zmax,spacing" > sites.csv
  echo "STATION_A,172.5,-43.5,0,3,0.05" >> sites.csv
  echo "STATION_B,172.6,-43.6,0,5,0.1" >> sites.csv
   # Generate profiles  
   generate_1d_profiles sites.csv --model-version 2.03 --out-dir /tmp/profiles
  1. Compute threshold values:
   # Create locations CSV (default format: id, lon, lat)
   echo "id,lon,lat" > locations.csv
   echo "STATION_A,172.5,-43.5" >> locations.csv
   echo "STATION_B,172.6,-43.6" >> locations.csv
   
   # Generate thresholds (with custom topography handling)
   generate_thresholds locations.csv --model-version 2.07 --threshold-type Z1.0 --threshold-type Z2.5 --topo-type SQUASHED_TAPERED --out-dir /tmp/thresholds
   
   # Or use legacy station file format (lon lat name)
   echo "172.5 -43.5 STATION_A" > stations.txt
   echo "172.6 -43.6 STATION_B" >> stations.txt
   generate_thresholds stations.txt --lon-index 0 --lat-index 1 --name-index 2 --sep " "

Changelogs and Development Plans

For information about the development roadmap, upcoming features, and past version changes, see the Development Schedule.

References

  • Ethan M. Thomson, Brendon A. Bradley & Robin L. Lee (2020). Methodology and computational implementation of a New Zealand Velocity Model (nzcvm2.0) for broadband ground motion simulation, New Zealand Journal of Geology and Geophysics, 63(1), 110-127. DOI: 10.1080/00288306.2019.1636830

  • Donna Eberhart-Phillips, Martin Reyners, Stephen Bannister, Mark Chadwick, Susan Ellis (2010). Establishing a Versatile 3-D Seismic Velocity Model for New Zealand. Seismological Research Letters, 81(6), 992–1000. DOI: 10.1785/gssrl.81.6.992

  • Donna Eberhart-Phillips, Stephen Bannister, Martin Reyners, and Stuart Henrys (2020). New Zealand Wide Model 2.2 Seismic Velocity and Qs and Qp Models for New Zealand. Zenodo. DOI: 10.5281/zenodo.3779523

About

Next-gen velocity modeling tools

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 9