Skip to content

Generate compacted sediment thickness and decompacted sediment rate grids for paleo times using polynomials of ocean floor age and distance to passive margins.

License

Notifications You must be signed in to change notification settings

EarthByte/predicting-sediment-thickness

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Predicting sediment thickness

This workflow generates compacted sediment thickness and decompacted sediment rate grids for palaeo-times using polynomials of ocean floor age and distance to passive margins. The polynomial relationship is calibrated to present day and can be updated with new datasets if needed (see below for more information).

To generate sediment thickness and rate grids through time, all that is required is a GPlates-compatible plate motion model (specifically: rotation file(s), topology (or dynamic polgyon) file(s), and passive continental margin locations (COBs), and corresponding paleo-age grids. The latest plate model and time-evolving seafloor age grids can be downloaded here.

Note: Currently you may notice artefacts in the mean-distance and sedimentation grids, such as alternating stripes, that are caused by non-optimal reconstruction of ocean basin points using the topological model. We plan to improve this in the future (by improving the collision detection of ocean basin points with topological plates and networks in pyGPlates).

Dependencies

You'll also need to install the following Python dependencies:

You can install these with conda:

conda create -n <conda-environment> -c conda-forge numpy scipy gmt platetectonictools
conda activate <conda-environment>

...where <conda-environment> should be replaced with the name of your conda environment.

Releases

v2.0

This release significantly reduces running time and memory usage.

Other changes include:

  • Can generate costly distance grids faster using a lower internal resolution (eg, 1 degree).
    • Then upscale to a higher resolution (eg, 0.1 degrees).
  • Can specify maximum memory usage (to avoid out-of-memory crashes).
  • Input parameters easier to configure.
    • Eg, specifying age grid filename format (where time is in the filename and how many decimal places).
  • Can specify a non-zero reference frame (eg, if age grids are in a non-zero mantle frame).

v1.1

This release contains the sediment thickness workflow with an updated calibration for sediment thickness and rate using GlobSed sediment thickness (Straume et al. 2019) and age grid from 'Muller-2019-Young2019-Cao2020' in the GPlates 2.3 sample data (Zahirovic et al. 2022)

v1.0

This release contains the original sediment thickness workflow from Dutkiewicz et al. (2017). The relationship for sedimentation rate and thickness was based on the calibration of the age grid from Müller et al. (2016), and present-day sediment thickness of Divins (2003), incorporating additions by Whittaker et al. (2013) and Wobbe et al. (2014) for the Southern Ocean.

Workflow procedure

  • Download paleo-age grids and associated topologies.

    • The latest plate model and paleo-age grids can be downloaded from here.
    • Alternatively, Müller et al. (2016; AREPS) can be downloaded from here
  • Open the 01_generate_distance_grids.py script and:

    • Set the min_time, max_time and time_step time range variables for the times to generate distance grids.
    • Set the age_grid_filenames_format variable to the location/filenames of the downloaded age grids.

      Note: This format string includes a pattern (such as {:.1f}) that will be substituted with the age grid paleo times.

    • Set the data_dir variable to the location of all your topological files.
    • Set the rotation_filenames and topology_filenames variables to match those in the data_dir.
    • Set the max_topological_reconstruction_time variable to oldest age supported by the topological model (eg, 250, 410, or 1000).
    • Set the anchor_plate_id variable to the reference frame in which to generate the distance grids.

      Note: The age grids must also be in this reference frame.

    • Set the proximity_features_files variable to the passive margin files (that distances are calculated relative to).

      Note: These can be passive margins generated from contoured continents (see here).
      In this case, ensure that the same rotation (and topological) model is used for contouring (as is used in rotation_filenames and topology_filenames). And ensure that passive margins are generated as far back as max_topological_reconstruction_time.

    • Set the continent_obstacle_files variable to the continent files (obstacles to water flow).

      Note: These can be contoured continents (see here).
      In this case, ensure that the same rotation (and topological) model is used for contouring (as is used in rotation_filenames and topology_filenames). And ensure that passive margins are generated as far back as max_topological_reconstruction_time.

      • The shortest distance (from ocean points to passive margins) must go around the continents (ie, water flows around continents).
      • This can be None to just use the minimum straight-line distance to passive margins (ignoring continent obstacles).
      • Set the plate_boundary_obstacles variable to those plate boundary feature types that also act as obstacles (to water flow).

        Note: This parameter is ignored unless continent_obstacle_files is also specified.

        • This should typically be left as the default (mid-ocean ridges and subduction zones), but you can change this if desired.
    • Set the grid_spacing variable to the desired grid spacing (in degrees, e.g. 0.1) of the generated distance grids.
      • The output distance grids are upscaled from the grid spacing used internally for computations (internal_grid_spacing).
    • Set the internal_grid_spacing variable to grid spacing (in degrees) used for internal distance computations.

      Note: This parameter significantly affects the time it takes to generate distance grids in this workflow.

    • Set the use_all_cpus variable to the number of CPU cores to use (eg, False, True or a specific number).
    • Set the max_memory_usage_in_gb variable to the amount of memory (in GB) to use.
      • For example, set it to the amount of physical RAM (or less if running other workflows simultaneously).
  • Run the Python script: python 01_generate_distance_grids.py

    • The script outputs mean distance grids:
      • Have units in metres.
      • Are located in distances_<grid_spacing>d (unles you've changed your output folder with output_dir).
  • Open the 02_generate_predicted_sedimentation_grids.py script and:

    • Set the min_time, max_time and time_step time range variables for the times to generate sedimentation grids.
    • Set the age_grid_filenames_format variable to the location/filenames of the downloaded age grids.

      Note: This format string includes a pattern (such as {:.1f}) that will be substituted with the age grid paleo times.

    • Set the distance_grid_spacing variable to equal the grid_spacing variable used to generate the distance grids in part 1.
    • Set the grid_spacing variable to your desired spacing in degrees (of the output sedimentation grids).
    • Set the use_all_cpus variable to the number of CPU cores to use (eg, False, True or a specific number).
  • Run the Python script: python 02_generate_predicted_sedimentation_grids.py

    • The script outputs predicted decompacted sedimentation rate grids:
      • Have units cm/Ky (not m/My).
      • Are located in sedimentation_output/predicted_rate.
    • The script also outputs predicted compacted sediment thickness grids:
      • Have units in metres.
      • Are located in sedimentation_output/predicted_thickness.

Calculating the relationships for sedimentation rate and thickness

The scripts to calculate the sedimentation rate and thickness relationships are in the folder python_notebooks_and_input_data_archive. If a new relationship needs to be derived (for example, to be consistent with a different present-day age grid), run the sediment_rate.ipynb and sediment_thick.ipynb notebooks (with a modified alldata file, and update the script generate_predicted_sedimentation_grids.py to be consistent with the polynomial coefficients obtained from the jupyter notebooks.

Miscellaneous

Most recent global sediment thickness map:

https://www.ngdc.noaa.gov/mgg/sedthick/

Previous versions:

https://www.ngdc.noaa.gov/mgg/sedthick/sedthick.html

and

One of the links at the bottom of this page... https://doi.pangaea.de/10.1594/PANGAEA.835589?format=html#download

...seems to be a version of the global sediment thickness map, with their new grid merged into it http://store.pangaea.de/Publications/WobbeF_et_al_2014/sedthick_world_v3_5min_epsg4326.nc

Reference

Dutkiewicz, A., Müller, R.D., Wang, X., O’Callaghan, S., Cannon, J. and Wright, N.M., 2017. Predicting sediment thickness on vanished ocean crust since 200 Ma. Geochemistry, Geophysics, Geosystems, 18, 4586-4603, DOI: https://doi.org/10.1002/2017GC007258.

Note: The paper forgot to mention that mid-ocean ridges and subduction zones were hardwired to act as obstacles to water flow (in addition to the continents). This has now been made a configurable parameter (see plate_boundary_obstacles above) that defaults to mid-ocean ridges and subduction zones.

About

Generate compacted sediment thickness and decompacted sediment rate grids for paleo times using polynomials of ocean floor age and distance to passive margins.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •