| 1 | import numpy as np | 
|---|
| 2 | from checkfield import checkfield | 
|---|
| 3 | from fielddisplay import fielddisplay | 
|---|
| 4 | from lovenumbers import lovenumbers | 
|---|
| 5 | from MatlabFuncs import * | 
|---|
| 6 | from planetradius import planetradius | 
|---|
| 7 | from rotational import rotational | 
|---|
| 8 | from solidearthsettings import solidearthsettings | 
|---|
| 9 | from solidearthsolution import solidearthsolution | 
|---|
| 10 | from WriteData import WriteData | 
|---|
| 11 |  | 
|---|
| 12 |  | 
|---|
| 13 | class solidearth(object): | 
|---|
| 14 | """SOLIDEARTH class definition | 
|---|
| 15 |  | 
|---|
| 16 | Usage: | 
|---|
| 17 | solidearth = solidearth() | 
|---|
| 18 | solidearth = solidearth('earth') | 
|---|
| 19 |  | 
|---|
| 20 | TODO: | 
|---|
| 21 | - Update translation from solidearth.m | 
|---|
| 22 | """ | 
|---|
| 23 |  | 
|---|
| 24 | def __init__(self, *args):  # {{{ | 
|---|
| 25 | self.settings  = solidearthsettings() | 
|---|
| 26 | self.external  = None | 
|---|
| 27 | self.lovenumbers = lovenumbers() | 
|---|
| 28 | self.rotational = rotational() | 
|---|
| 29 | self.planetradius = planetradius('earth') | 
|---|
| 30 | self.requested_outputs = [] | 
|---|
| 31 | self.transitions = [] | 
|---|
| 32 | self.partitionice = [] | 
|---|
| 33 | self.partitionhydro = [] | 
|---|
| 34 | self.partitionocean = [] | 
|---|
| 35 |  | 
|---|
| 36 | nargs = len(args) | 
|---|
| 37 | if nargs == 0: | 
|---|
| 38 | self.setdefaultparameters('earth') | 
|---|
| 39 | elif nargs == 1: | 
|---|
| 40 | self.setdefaultparameters(args[0]) | 
|---|
| 41 | else: | 
|---|
| 42 | raise Exception('solidearth constructor error message: zero or one argument only!') | 
|---|
| 43 | # }}} | 
|---|
| 44 |  | 
|---|
| 45 | def __repr__(self):  # {{{ | 
|---|
| 46 | s = '   solidearthinputs, forcings and settings:\n' | 
|---|
| 47 | s += '{}\n'.format(fielddisplay(self, 'planetradius', 'planet radius [m]')) | 
|---|
| 48 | s += '{}\n'.format(fielddisplay(self, 'transitions', 'indices into parts of the mesh that will be icecaps')) | 
|---|
| 49 | s += '{}\n'.format(fielddisplay(self, 'requested_outputs', 'additional outputs requested')) | 
|---|
| 50 | s += '{}\n'.format(fielddisplay(self, 'partitionice', 'ice partition vector for barystatic contribution')) | 
|---|
| 51 | s += '{}\n'.format(fielddisplay(self, 'partitionhydro', 'hydro partition vector for barystatic contribution')) | 
|---|
| 52 | s += '{}\n'.format(fielddisplay(self, 'partitionocean', 'ocean partition vector for barystatic contribution')) | 
|---|
| 53 | if not self.external: | 
|---|
| 54 | s += '{}\n'.format(fielddisplay(self, 'external', 'external solution, of the type solidearthsolution')) | 
|---|
| 55 | print(self.settings) | 
|---|
| 56 | print(self.lovenumbers) | 
|---|
| 57 | print(self.rotational) | 
|---|
| 58 | try: | 
|---|
| 59 | print(self.external) | 
|---|
| 60 | except TypeError: | 
|---|
| 61 | pass | 
|---|
| 62 | return s | 
|---|
| 63 | # }}} | 
|---|
| 64 |  | 
|---|
| 65 | def setdefaultparameters(self, planet):  # {{{ | 
|---|
| 66 | # Output default | 
|---|
| 67 | self.requested_outputs = ['default'] | 
|---|
| 68 |  | 
|---|
| 69 | # Transitions should be a list | 
|---|
| 70 | self.transitions = [] | 
|---|
| 71 |  | 
|---|
| 72 | # No partitions requested for barystatic contribution | 
|---|
| 73 | self.partitionice = [] | 
|---|
| 74 | self.partitionhydro = [] | 
|---|
| 75 | self.partitionocean = [] | 
|---|
| 76 |  | 
|---|
| 77 | # No external solutions by default | 
|---|
| 78 | self.external = None | 
|---|
| 79 |  | 
|---|
| 80 | # Planet radius | 
|---|
| 81 | self.planetradius = planetradius(planet) | 
|---|
| 82 | # }}} | 
|---|
| 83 |  | 
|---|
| 84 | def checkconsistency(self, md, solution, analyses):  # {{{ | 
|---|
| 85 | if ('SealevelchangeAnalysis' not in analyses) or (solution == 'TransientSolution' and not md.transient.isslc): | 
|---|
| 86 | return md | 
|---|
| 87 |  | 
|---|
| 88 | md = checkfield(md, 'fieldname', 'solidearth.requested_outputs', 'stringrow', 1) | 
|---|
| 89 |  | 
|---|
| 90 | self.settings.checkconsistency(md, solution, analyses) | 
|---|
| 91 | self.lovenumbers.checkconsistency(md, solution, analyses) | 
|---|
| 92 | self.rotational.checkconsistency(md, solution, analyses) | 
|---|
| 93 | if self.external: | 
|---|
| 94 | if not isa(self.external, solidearthsolution): | 
|---|
| 95 | raise Exception('solidearth consistency check: external field should be a solidearthsolution') | 
|---|
| 96 | self.external.checkconsistency(md, solution, analyses) | 
|---|
| 97 | return md | 
|---|
| 98 | # }}} | 
|---|
| 99 |  | 
|---|
| 100 | def defaultoutputs(self, md):  # {{{ | 
|---|
| 101 | return ['Sealevel'] | 
|---|
| 102 | # }}} | 
|---|
| 103 |  | 
|---|
| 104 | def marshall(self, prefix, md, fid):  # {{{ | 
|---|
| 105 | WriteData(fid, prefix, 'object', self, 'fieldname', 'planetradius', 'format', 'Double') | 
|---|
| 106 | WriteData(fid, prefix, 'object', self, 'fieldname', 'transitions', 'format', 'MatArray') | 
|---|
| 107 |  | 
|---|
| 108 | if len(self.partitionice): | 
|---|
| 109 | npartice = np.max(self.partitionice) + 2 | 
|---|
| 110 | else: | 
|---|
| 111 | npartice = 0 | 
|---|
| 112 |  | 
|---|
| 113 | if len(self.partitionhydro): | 
|---|
| 114 | nparthydro = np.max(self.partitionhydro) + 2 | 
|---|
| 115 | else: | 
|---|
| 116 | nparthydro = 0 | 
|---|
| 117 |  | 
|---|
| 118 | if len(self.partitionocean): | 
|---|
| 119 | npartocean = np.max(self.partitionocean) + 2 | 
|---|
| 120 | else: | 
|---|
| 121 | npartocean = 0 | 
|---|
| 122 |  | 
|---|
| 123 | WriteData(fid, prefix, 'object', self, 'fieldname', 'partitionice', 'mattype', 1, 'format', 'DoubleMat'); | 
|---|
| 124 | WriteData(fid, prefix, 'data', npartice, 'format', 'Integer', 'name', 'md.solidearth.npartice'); | 
|---|
| 125 | WriteData(fid, prefix, 'object', self, 'fieldname', 'partitionhydro', 'mattype', 1, 'format', 'DoubleMat'); | 
|---|
| 126 | WriteData(fid, prefix, 'data', nparthydro,'format', 'Integer', 'name','md.solidearth.nparthydro'); | 
|---|
| 127 | WriteData(fid, prefix, 'object', self, 'fieldname', 'partitionocean', 'mattype', 1, 'format', 'DoubleMat'); | 
|---|
| 128 | WriteData(fid, prefix, 'data', npartocean,'format', 'Integer', 'name','md.solidearth.npartocean'); | 
|---|
| 129 |  | 
|---|
| 130 | self.settings.marshall(prefix, md, fid) | 
|---|
| 131 | self.lovenumbers.marshall(prefix, md, fid) | 
|---|
| 132 | self.rotational.marshall(prefix, md, fid) | 
|---|
| 133 | if self.external: | 
|---|
| 134 | WriteData(fid, prefix, 'data', 1, 'format', 'Integer', 'name', 'md.solidearth.isexternal') | 
|---|
| 135 | self.external.marshall(prefix, md, fid) | 
|---|
| 136 | else: | 
|---|
| 137 | WriteData(fid, prefix, 'data', 0, 'format', 'Integer', 'name', 'md.solidearth.isexternal') | 
|---|
| 138 |  | 
|---|
| 139 | # Process requested outputs | 
|---|
| 140 | outputs = self.requested_outputs | 
|---|
| 141 | pos = np.where(np.asarray(outputs) == 'default')[0] | 
|---|
| 142 | if len(pos): | 
|---|
| 143 | outputs = np.delete(outputs, pos) # remove 'default' from outputs | 
|---|
| 144 | outputs = np.append(outputs, self.defaultoutputs(md)) # add defaults | 
|---|
| 145 | WriteData(fid, prefix, 'data', outputs, 'name', 'md.solidearth.requested_outputs', 'format', 'StringArray') | 
|---|
| 146 | # }}} | 
|---|
| 147 |  | 
|---|
| 148 | def extrude(self, md):  # {{{ | 
|---|
| 149 | return self | 
|---|
| 150 | # }}} | 
|---|