-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcalcSlipRates_MCMC.py
executable file
·126 lines (101 loc) · 6.55 KB
/
calcSlipRates_MCMC.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#!/usr/bin/env python3
'''
** RISeR Incremental Slip Rate Calculator **
This script serves as a wrapper for computing incremental fault slip rates using the Markov chain Monte Carlo (MCMC)
method.
It structures the input arguments and passes them to a generic wrapper to ensure consistency in slip rate formatting
and results.
Rob Zinke 2019-2021
'''
### IMPORT MODULES ---
import argparse
from slipRateComputation import computeIncrRates
### PARSER ---
Description = '''Calculate incremental slip rates for a dated fault slip history using the Markov chain Monte Carlo
method. This method is well-suited for data sets in which one or more pair of dated markers overlap within uncertainty.
Inputs are provided as probability density functions (PDFs) representing the age and displacement of each marker. From
those PDFs, random samples are drawn, and samples resulting in negative slip rates are discarded. From the n valid
random draws, incremental slip rates are calculated.
REQUIRED INPUT
This routine requires a YAML file (e.g., data.yaml) which lists each dated displacement marker in order from youngest
and least-offset, to oldest and most-offset. Each entry gives the marker name, followed by a dictionary-like entry
specifying the path to the age PDF file, and the path to the displacement PDF file.
For example: The file data.yaml might contain
# Commented description of data scheme
T2/T3 riser: {\"ageFile\": \"T2T3age.txt\", \"dspFile\": \"T2T3dsp.txt\"}
T1/T2 riser: {\"ageFile\": \"T1T2age.txt\", \"dspFile\": \"T1T2dsp.txt\"}
Where T2/T3 is younger and less-offset than T1/T2. Change the .txt filenames to the relativeor absolute paths to the PDF
files, accordingly.
Note: More than one entry must be present to calculate incremental slip rates.
'''
Examples = '''EXAMPLES
From the Examples/SimpleExample folder
calcSlipRates_MCMC.py DspAgeData.yaml
'''
def createParser():
parser = argparse.ArgumentParser(description=Description,
formatter_class=argparse.RawTextHelpFormatter, epilog=Examples)
# Required
requiredArgs = parser.add_argument_group('ESSENTIAL ARGUMENTS')
requiredArgs.add_argument(dest='dataFile', type=str,
help='Data file in YAML format. Each entry provides a unique marker \
name, with ageFile and dspFile specified. Youngest, least offset features at \
the top; oldest, most-offset features at the bottom.')
requiredArgs.add_argument('-o','--outName', dest='outName', type=str, default='Out',
help='Head name for outputs (no extension). [Default = \'Out\'].')
# Generic arguments
generalArgs = parser.add_argument_group('GENERIC ARGUMENTS')
generalArgs.add_argument('-v','--verbose', dest='verbose', action='store_true',
help='Verbose mode.')
generalArgs.add_argument('-vv','--extra-verbose', dest='xtrVerbose', action='store_true',
help='Print all possible statements to screen.')
generalArgs.add_argument('-p','--plot-outputs', dest='plotOutputs', action='store_true',
help='Plot outputs.')
generalArgs.add_argument('-l','--label-markers', dest='labelMarkers', action='store_true',
help='Label dated displacement markers on raw data plot.')
# Fine-tuning
detailMCargs = parser.add_argument_group('DETAILED MC ARGUMENTS')
detailMCargs.add_argument('-n','--Nsamples', dest='Nsamples', type=int, default=1E4,
help='Number of samples picked in MC run [default = 10,000; more is often better].')
detailMCargs.add_argument('--max-rate', dest='maxRate', type=float, default=1E3,
help='Maximum rate considered in MC analysis. Units are <dispalcement units> per <age units>. [Default = 1,000].')
detailMCargs.add_argument('-b','--MCbound', dest='MCbound', type=int, default=None,
help='Upper bound at which to stop sampling, even if specified number of samples has not been achieved. [Default = 4 x Nsamples].')
detailMCargs.add_argument('--seed', dest='seed', type=float, default=0,
help='Seed value for random number generator. [Default = 0].')
detailAnalysisArgs = parser.add_argument_group('DETAILED SLIP RATE ANALYSIS ARGUMENTS')
detailAnalysisArgs.add_argument('--pdf-method', dest='pdfMethod', type=str, default='kde',
help='Method used for transforming rate picks into slip rate PDF (\'hist\', [\'kde\']).')
detailAnalysisArgs.add_argument('--rate-step', dest='rateStep', type=float, default=0.01,
help='Step size for slip rate functions. [Default = 0.01].')
detailAnalysisArgs.add_argument('--smoothing-kernel', dest='smoothingKernel', type=str, default=None,
help='Smoothing kernel type of slip rate functions. ([None], mean, gauss).')
detailAnalysisArgs.add_argument('--kernel-width', dest='kernelWidth', type=int, default=2,
help='Smoothing kernel width of slip rate functions.')
detailAnalysisArgs.add_argument('--pdf-analysis', dest='pdfAnalysis', type=str, default='IQR',
help='Method for analyzing slip rate PDFs. ([\'IQR\'] for interquantile range; \'HPD\' for highest posterior density).')
detailAnalysisArgs.add_argument('--rate-confidence', dest='rateConfidence', type=float, default=68.27,
help='Confidence range for slip rate PDF reporting, (percent, e.g., [68.27], 95.45).')
detailFigureArgs = parser.add_argument_group('DETAILED SLIP RATE PLOT ARGUMENTS')
detailFigureArgs.add_argument('--max-picks2plot', dest='maxPicks2plot', type=int, default=500,
help='Max number of picks to plot on MC results figure. [Default = 500].')
detailFigureArgs.add_argument('--max-rate2plot', dest='maxRate2plot', type=float, default=None,
help='Maximum spreading rate to plot (unlike -max-rate, this will not affect calculations). [Default = None].')
detailFigureArgs.add_argument('--age-units', dest='ageUnits', type=str, default=None,
help='Label for age axis (calculations not affected). [Default = None].')
detailFigureArgs.add_argument('--dsp-units', dest='dspUnits', type=str, default=None,
help='Label for displacement axis (calculations not affected). [Default = None].')
detailFigureArgs.add_argument('--rate-units', dest='rateUnits', type=str, default=None,
help='Label for slip rate axis (calculations not affected). [Default = None].')
detailFigureArgs.add_argument('--plot-inputs', dest='plotInputs', action='store_true',
help='Plot inputs.')
return parser
def cmdParser(inps_args=None):
parser = createParser()
return parser.parse_args(inps_args)
### MAIN ---
if __name__ == '__main__':
## Gather arguments
inps = cmdParser()
## Pass arguments to slip rate wrapper
computeIncrRates('MCMC', inps)