From b6ca536cbaaebee085eb5d30d9cf375e155da882 Mon Sep 17 00:00:00 2001 From: Peter Powers <pmpowers@usgs.gov> Date: Tue, 10 Oct 2017 12:00:20 -0600 Subject: [PATCH] ShahjoueiPezeshk base implementation --- .../nshmp/gmm/ShahjoueiPezeshk_2016.java | 123 ++++++++++++++++++ .../usgs/earthquake/nshmp/gmm/coeffs/SP16.csv | 25 ++++ 2 files changed, 148 insertions(+) create mode 100644 src/gov/usgs/earthquake/nshmp/gmm/ShahjoueiPezeshk_2016.java create mode 100644 src/gov/usgs/earthquake/nshmp/gmm/coeffs/SP16.csv diff --git a/src/gov/usgs/earthquake/nshmp/gmm/ShahjoueiPezeshk_2016.java b/src/gov/usgs/earthquake/nshmp/gmm/ShahjoueiPezeshk_2016.java new file mode 100644 index 000000000..862a1d116 --- /dev/null +++ b/src/gov/usgs/earthquake/nshmp/gmm/ShahjoueiPezeshk_2016.java @@ -0,0 +1,123 @@ +package gov.usgs.earthquake.nshmp.gmm; + +import static gov.usgs.earthquake.nshmp.gmm.GmmInput.Field.MW; +import static gov.usgs.earthquake.nshmp.gmm.GmmInput.Field.RJB; +import static gov.usgs.earthquake.nshmp.gmm.GmmInput.Field.VS30; +import static gov.usgs.earthquake.nshmp.gmm.GmmUtils.BASE_10_TO_E; +import static java.lang.Math.log10; +import static java.lang.Math.max; +import static java.lang.Math.min; +import static java.lang.Math.sqrt; + +import com.google.common.collect.Range; + +import java.util.Map; + +import gov.usgs.earthquake.nshmp.gmm.GmmInput.Constraints; + +/** + * Implementation of the Shahjouei and Pezeshk (2016) ground motion model for + * central and eastern North America (CENA). This ground motion model is an + * updated version of the Shahjouei and Pezeshk NGA-East Seed Model + * {@link Gmm#NGA_EAST_SEED_SP15}. + * + * <p><b>Note:</b> Direct instantiation of {@code GroundMotionModel}s is + * prohibited. Use {@link Gmm#instance(Imt)} to retrieve an instance for a + * desired {@link Imt}. + * + * <p><b>Reference:</b> Shahjouei, A., and Pezeshk, S., 2016. Alternative hybrid + * ground-motion model for central and eastern North America using hybrid + * simulations and NGA-West2 models: Bulletin of the Seismological Society of + * America, v. 106, no. 2, pp. 734–754. + * + * <p><b>doi:</b> <a href="http://dx.doi.org/10.1785/0120140367"> + * 10.1785/0120140367</a> + * + * <p><b>Component:</b> average horizontal (RotD50) + * + * @author Allison Shumway + * @author Peter Powers + * @see Gmm#NGA_EAST_SEED_SP16 + */ +public final class ShahjoueiPezeshk_2016 implements GroundMotionModel { + + /* + * Developer notes: + * + * Whereas some seed model updates were provided to the USGS as drop in + * updates to the NGA-East ground motion table format (e.g. Graizer17), this + * update was provided as the complete (mean and sigma) functional form and is + * therefore implemented outside the NgaEastUsgs_2017 wrapper class. + */ + static final String NAME = NgaEastUsgs_2017.Seed.NAME + "SP16"; + + static final Constraints CONSTRAINTS = Constraints.builder() + .set(MW, Range.closed(4.0, 8.0)) + .set(RJB, Range.closed(0.0, 1000.0)) + .set(VS30, Range.singleton(3000.0)) + .build(); + + static final CoefficientContainer COEFFS = new CoefficientContainer("SP16.csv"); + + private static final double SIGMA_FAC = -6.898e-3; + private static final double SIGMA_FAC_PGV = -3.054e-5; + + private static final class Coefficients { + + final Imt imt; + final double c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11, c12, c13, c14, σReg; + + Coefficients(Imt imt, CoefficientContainer cc) { + this.imt = imt; + Map<String, Double> coeffs = cc.get(imt); + c1 = coeffs.get("c1"); + c2 = coeffs.get("c2"); + c3 = coeffs.get("c3"); + c4 = coeffs.get("c4"); + c5 = coeffs.get("c5"); + c6 = coeffs.get("c6"); + c7 = coeffs.get("c7"); + c8 = coeffs.get("c8"); + c9 = coeffs.get("c9"); + c10 = coeffs.get("c10"); + c11 = coeffs.get("c11"); + c12 = coeffs.get("c12"); + c13 = coeffs.get("c13"); + c14 = coeffs.get("c14"); + σReg = coeffs.get("sigma_reg"); + } + } + + private final Coefficients coeffs; + + ShahjoueiPezeshk_2016(final Imt imt) { + coeffs = new Coefficients(imt, COEFFS); + } + + @Override + public final ScalarGroundMotion calc(final GmmInput in) { + double μ = calcMean(coeffs, in.Mw, in.rJB); + double σ = calcStdDev(coeffs, in.Mw); + return DefaultScalarGroundMotion.create(μ, σ); + } + + private static double calcMean(final Coefficients c, final double Mw, final double rJB) { + double r = sqrt(rJB * rJB + c.c11 * c.c11); + double μ = c.c1 + + (c.c2 * Mw) + + (c.c3 * Mw * Mw) + + (c.c4 + c.c5 * Mw) * min(log10(r), log10(60.0)) + + (c.c6 + c.c7 * Mw) * max(min(log10(r / 60.0), log10(2.0)), 0.0) + + (c.c8 + c.c9 * Mw) * max(log10(r / 120.0), 0.0) + + (c.c10 * r); + return μ * BASE_10_TO_E; + } + + /* Aleatory sigma model only. */ + private static double calcStdDev(final Coefficients c, final double Mw) { + double ψ = c.imt == Imt.PGV ? SIGMA_FAC_PGV : SIGMA_FAC; + double σlnY = (Mw <= 6.5) ? c.c12 * Mw + c.c13 : ψ * Mw + c.c14; + return sqrt(σlnY * σlnY + c.σReg * c.σReg); + } + +} diff --git a/src/gov/usgs/earthquake/nshmp/gmm/coeffs/SP16.csv b/src/gov/usgs/earthquake/nshmp/gmm/coeffs/SP16.csv new file mode 100644 index 000000000..c9185d282 --- /dev/null +++ b/src/gov/usgs/earthquake/nshmp/gmm/coeffs/SP16.csv @@ -0,0 +1,25 @@ +T,c1,c2,c3,c4,c5,c6,c7,c8,c9,c10,c11,c12,c13,c14,sigma_reg,sigma_par +PGA,-0.3002,0.5066,-0.04526,-3.224,0.2998,-1.283,0.1045,-3.0856,0.2778,-0.0007711,3.81,-0.0554,0.978,0.663,0.1,0.288 +PGV,-2.3891,1.259,-0.07901,-0.029386,0.3034,-0.00929,-0.04605,-2.7548,0.3467,-0.0007623,-4.598,-0.41,0.876,0.611,0.194,0.373 +0.01,-0.3472,0.4838,-0.04093,-3.0832,0.2712,-0.9676,0.04983,-2.9695,0.2693,-0.0006695,-4.434,-0.056,0.982,0.664,0.132,0.281 +0.02,0.832,0.1934,-0.0206,-3.1134,0.2786,-1.133,0.05994,-3.5023,0.2901,-0.0005857,-4.412,-0.0559,0.983,0.665,0.0928,0.281 +0.03,1.185,0.1064,-0.01423,-3.1029,0.2792,-1.078,0.05239,-3.5722,0.2865,-0.000622,-4.353,-0.0577,1,0.676,0.0833,0.277 +0.04,1.246,0.08986,-0.01268,-3.0785,0.2773,-0.9743,0.0416,-3.5083,0.2769,-0.0006818,-4.303,-0.0577,1.01,0.688,0.0798,0.279 +0.05,1.1793,0.1037,-0.01321,-3.0488,0.2744,-0.8635,0.03077,-3.3986,0.2659,-0.0007439,-4.266,-0.0578,1.03,0.701,0.0776,0.272 +0.075,0.8045,0.1866,-0.01788,-2.9697,0.266,-0.6122,0.007491,-3.0852,0.2391,-0.0008801,-4.241,-0.0561,1.03,0.721,0.0738,0.252 +0.1,0.35,0.2871,-0.02381,-2.894,0.2576,-0.4123,-0.01012,-2.7947,0.2163,-0.0009848,4.201,-0.0565,1.05,0.732,0.0717,0.265 +0.15,-0.5264,0.4782,-0.03519,-2.761,0.2426,-0.01319,-0.03338,-2.3312,0.1818,-0.001125,4.239,-0.0559,1.04,0.724,0.0716,0.276 +0.2,-1.2884,0.6413,-0.04486,-2.6504,0.2301,0.04637,-0.0469,-1.9927,0.1576,-0.001209,4.325,-0.056,1.03,0.715,0.0743,0.258 +0.25,-1.9422,0.7789,-0.05295,-2.5573,0.2196,0.1631,-0.05478,-1.7399,0.1398,-0.001258,4.438,-0.0537,1.02,0.712,0.0779,0.268 +0.3,-2.5071,0.8961,-0.05976,-2.478,0.2107,0.2407,-0.05919,-1.547,0.1265,-0.001286,4.571,-0.0511,1.01,0.718,0.0815,0.0284 +0.4,-3.436,1.085,-0.07059,-2.3495,0.1961,0.3244,-0.06197,-1.2793,0.1085,-0.001304,-4.872,-0.047,0.987,0.725,0.0876,0.34 +0.5,-4.1699,1.231,-0.07878,-2.251,0.1849,0.3544,-0.06046,-1.1111,0.09757,-0.001294,-5.211,-0.0442,0.981,0.736,0.0923,0.357 +0.75,-5.4797,1.482,-0.09245,-2.0865,0.1659,0.3284,-0.04979,-0.9131,0.0857,-0.001219,-6.154,-0.0384,0.967,0.76,0.0991,0.374 +1,-6.3464,1.641,-0.1006,-1.9931,0.1546,0.253,-0.03709,-0.8641,0.08405,-0.001123,-7.174,-0.0314,0.933,0.77,0.102,0.392 +1.5,-7.4087,1.823,-0.1093,-1.9162,0.1438,0.09019,-0.01551,-0.92,0.09103,-0.0009407,-9.253,-0.0227,0.883,0.776,0.105,0.426 +2,-8.0057,1.916,-0.113,-1.9173,0.1418,-0.03828,-0.001252,-1.0327,0.1016,-0.0007926,-11.22,-0.0184,0.857,0.778,0.106,0.44 +3,-8.5793,1.985,-0.1146,-2.0184,0.1499,-0.1744,0.009393,-1.2453,0.1214,-0.0005919,14.38,-0.0189,0.859,0.777,0.107,0.58 +4,-8.8246,1.99,-0.1131,-2.1475,0.1635,-0.1844,0.003919,-1.3849,0.1357,-0.0004855,16.19,-0.016,0.83,0.766,0.107,0.589 +5,-8.9855,1.975,-0.1105,-2.2496,0.1764,-0.1043,-0.01187,-1.4511,0.1446,-0.0004439,16.71,-0.0153,0.826,0.766,0.107,0.631 +7.5,-9.3927,1.925,-0.1032,-2.3572,0.1973,0.3465,-0.07832,-1.3728,0.149,-0.0005176,14.58,-0.0143,0.815,0.762,0.113,0.721 +10,-9.735,1.879,-0.09666,-2.4139,0.2117,1.01,-0.1678,-1.0631,0.137,-0.000742,11.23,-0.017,0.822,0.752,0.14,0.739 \ No newline at end of file -- GitLab