pysmo
#
Pysmo types and corresponding Mini Classes.
The psymo base namespace exposes the protocol classes that are used as type
hints, as well as reference implementations of a generic class for each
protocol. The reference classes are subclasses of their respective protocol
classes that contain exactly the same attributes (though some extra methods may
be defined for convenience). They can be considered minimal implementations of
a class that can be used with pysmo protocols, and are therefore named "Mini" +
"name of protocol" (e.g. MiniSeismogram
is an
implementation of the Seismogram
type).
Classes, functions and other tools that make use of pysmo types and mini need to be imported from other modules.
Modules:
-
classes
–Classes that work with pysmo types.
-
functions
–Simple operations using pysmo types.
-
lib
–Pysmo library module.
-
tools
–Extra tools or topics that use pysmo types.
Classes:
-
Event
–Protocol class to define the
Event
type. -
MiniEvent
–Minimal class for use with the
Event
type. -
Location
–Protocol class to define the
Location
type. -
MiniLocation
–Minimal class for use with the
Location
type. -
LocationWithDepth
–Protocol class to define the
LocationWithDepth
type. -
MiniLocationWithDepth
–Minimal class for use with the
MiniLocationWithDepth
type. -
Seismogram
–Protocol class to define the
Seismogram
type. -
MiniSeismogram
–Minimal class for use with the
Seismogram
type. -
Station
–Protocol class to define the Station type.
-
MiniStation
–Minimal class for use with the Station type.
Event
#
Bases: LocationWithDepth
, Protocol
Protocol class to define the Event
type.
Attributes:
-
latitude
(float
) –Latitude in degrees.
-
longitude
(float
) –Longitude in degrees.
-
depth
(float
) –Location depth in metres.
-
time
(datetime
) –Event origin time.
Source code in pysmo/_types/_event.py
11 12 13 14 15 16 17 18 19 20 21 |
|
MiniEvent
#
Minimal class for use with the Event
type.
The MiniEvent
class provides a minimal implementation of class that is
compatible with the Event
type.
Examples:
>>> from pysmo import MiniEvent, Event, LocationWithDepth, Location
>>> from datetime import datetime, timezone
>>> now = datetime.now(timezone.utc)
>>> my_event = MiniEvent(latitude=-24.68, longitude=-26.73,
depth=15234.0, time=now)
>>> isinstance(my_event, Event)
True
>>> isinstance(my_event, Location)
True
>>> isinstance(my_event, LocationWithDepth)
True
Attributes:
-
time
(datetime
) –Event origin time.
-
latitude
(float | int
) –Event atitude from -90 to 90 degrees.
-
longitude
(float | int
) –Event longitude from -180 to 180 degrees.
-
depth
(float | int
) –Event depth in metres.
Source code in pysmo/_types/_event.py
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 |
|
time
class-attribute
instance-attribute
#
time: datetime = field(validator=[type_validator(), datetime_is_utc])
Event origin time.
latitude
class-attribute
instance-attribute
#
Event atitude from -90 to 90 degrees.
longitude
class-attribute
instance-attribute
#
Event longitude from -180 to 180 degrees.
Location
#
Bases: Protocol
Protocol class to define the Location
type.
Attributes:
Source code in pysmo/_types/_location.py
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
|
MiniLocation
#
Minimal class for use with the Location
type.
The MiniLocation
class provides a minimal implementation of class that
is compatible with the Location
type.
Examples:
>>> from pysmo import MiniLocation, Location
>>> my_location = MiniLocation(latitude=41.8781, longitude=-87.6298)
>>> isinstance(my_location, Location)
True
Attributes:
-
latitude
(float | int
) –Latitude from -90 to 90 degrees.
-
longitude
(float | int
) –Longitude from -180 to 180 degrees.
Source code in pysmo/_types/_location.py
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
|
latitude
class-attribute
instance-attribute
#
Latitude from -90 to 90 degrees.
LocationWithDepth
#
Protocol class to define the LocationWithDepth
type.
Attributes:
-
latitude
(float
) –Latitude in degrees.
-
longitude
(float
) –Longitude in degrees.
-
depth
(float
) –Location depth in metres.
Source code in pysmo/_types/_location_with_depth.py
9 10 11 12 13 14 15 16 17 18 19 |
|
MiniLocationWithDepth
#
Minimal class for use with the MiniLocationWithDepth
type.
The MiniLocationWithDepth
class provides a minimal implementation of class that
is compatible with the MiniLocationWithDepth
type.
Examples:
>>> from pysmo import MiniLocationWithDepth, LocationWithDepth, Location
>>> my_hypo = MiniLocationWithDepth(latitude=-24.68, longitude=-26.73, depth=15234.0)
>>> isinstance(my_hypo, LocationWithDepth)
True
>>> isinstance(my_hypo, Location)
True
Attributes:
-
latitude
(float | int
) –Location latitude from -90 to 90 degrees.
-
longitude
(float | int
) –Location longitude from -180 to 180 degrees.
-
depth
(float | int
) –Location depth in metres.
Source code in pysmo/_types/_location_with_depth.py
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 |
|
Seismogram
#
Bases: Protocol
Protocol class to define the Seismogram
type.
Examples:
Usage for a function that takes a Seismogram compatible class instance as argument and returns the begin time in isoformat:
>>> from pysmo import Seismogram
>>> from pysmo.classes import SAC # SAC is a class that "speaks" Seismogram
>>> def example_function(seis_in: Seismogram) -> str:
... return seis_in.begin_time.isoformat()
...
>>> my_sac = SAC.from_file('testfile.sac')
>>> my_seismogram = my_sac.seismogram
>>> example_function(my_seismogram)
'2005-03-02T07:23:02.160000'
Methods:
-
__len__
–The length of the Seismogram.
Attributes:
-
data
(NDArray
) –Seismogram data.
-
begin_time
(datetime
) –Seismogram begin time.
-
end_time
(datetime
) –Seismogram end time.
-
delta
(timedelta
) –The sampling interval.
Source code in pysmo/_types/_seismogram.py
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 |
|
MiniSeismogram
#
Minimal class for use with the Seismogram
type.
The MiniSeismogram
class provides a minimal implementation of class that
is compatible with the Seismogram
type.
Examples:
>>> from pysmo import MiniSeismogram, Seismogram
>>> from datetime import datetime, timedelta, timezone
>>> import numpy as np
>>> now = datetime.now(timezone.utc)
>>> delta0 = timedelta(seconds=0.1)
>>> my_seismogram = MiniSeismogram(begin_time=now, delta=delta,
data=np.random.rand(100))
>>> isinstance(my_seismogram, Seismogram)
True
Methods:
-
__len__
–The length of the Seismogram.
Attributes:
-
begin_time
(datetime
) –Seismogram begin time.
-
delta
(timedelta
) –Seismogram sampling interval.
-
data
(NDArray
) –Seismogram data.
-
end_time
(datetime
) –Seismogram end time.
Source code in pysmo/_types/_seismogram.py
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 |
|
begin_time
class-attribute
instance-attribute
#
begin_time: datetime = field(default=begin_time.value, validator=[type_validator(), datetime_is_utc])
Seismogram begin time.
delta
class-attribute
instance-attribute
#
Seismogram sampling interval.
data
class-attribute
instance-attribute
#
Seismogram data.
__len__
#
__len__() -> int
The length of the Seismogram.
Returns:
-
int
–Number of samples in the data array.
Source code in pysmo/_types/_seismogram.py
104 105 106 107 108 109 110 |
|
Station
#
Protocol class to define the Station type.
Attributes:
-
latitude
(float
) –Latitude in degrees.
-
longitude
(float
) –Longitude in degrees.
-
name
(str
) –Station name or identifier.
-
network
(str | None
) –Network name or identifier.
-
elevation
(float | None
) –Station elevation in metres.
Source code in pysmo/_types/_station.py
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 |
|
MiniStation
#
Minimal class for use with the Station type.
The MiniStation
class provides a minimal implementation of class that
is compatible with the Station
type.
Examples:
>>> from pysmo import MiniStation, Station, Location
>>> my_station = MiniStation(latitude=-21.680301, longitude=-46.732601,
name="CACB", network="BL")
>>> isinstance(my_station, Station)
True
>>> isinstance(my_station, Location)
True
Attributes:
-
name
(str
) –Station name.
-
network
(str | None
) –Network name.
-
latitude
(float | int
) –Station latitude from -90 to 90 degrees.
-
longitude
(float | int
) –Station longitude from -180 to 180 degrees.
-
elevation
(float | int | None
) –Station elevation.
Source code in pysmo/_types/_station.py
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 |
|