Skip to content
Snippets Groups Projects
XYZ_usage.md 1.89 KiB
Newer Older
Jeremy M Fee's avatar
Jeremy M Fee committed
XYZ Algorithm Usage
===================

The XYZ Algorithm rotates between `geographic`, `observatory`, and `magnetic`,
channel orientations.  Read more about the [XYZ Algorithm](./XYZ.md).
`geomag.py --algorithm xyz [--xyz-from {geo,mag,obs,obsd}] [--xyz-to {geo,mag,obs,obsd}]`
Jeremy M Fee's avatar
Jeremy M Fee committed
### Reference Frames

There are 3 reference frames in this library.

Jeremy M Fee's avatar
Jeremy M Fee committed
#### Geographic or cartesian
Jeremy M Fee's avatar
Jeremy M Fee committed
 - `geo` is `[X, Y, Z, F]`
Jeremy M Fee's avatar
Jeremy M Fee committed
#### Magnetic or cylindrical
Jeremy M Fee's avatar
Jeremy M Fee committed
 - `mag` is `[H, D, Z, F]`
Jeremy M Fee's avatar
Jeremy M Fee committed
#### Observatory
Jeremy M Fee's avatar
Jeremy M Fee committed
 - `obs` is `[H, E, Z, F]`
 - `obsd` is `[H, D, Z, F]`
Jeremy M Fee's avatar
Jeremy M Fee committed
### Example
Eddie McWhirter's avatar
Eddie McWhirter committed

To convert HEZF data in pcdcp files to XYZF for Tucson observatory for all of
March 2013 output to iaga2002 files:

      geomag.py --algorithm xyz --observatory TUC \
      --starttime 2013-03-01T00:00:00Z --endtime 2013-03-31T23:59:00Z \
      --input-pcdcp-url file://data-pcdcp/./%(OBS)s%(year)s%(julian)s.%(i)s \
      --output-iaga-url file://data-iaga/./$(obs)s%(Y)s%(j)s.%(i)s \
      --type variation --interval minute
Jeremy M Fee's avatar
Jeremy M Fee committed
### Library Notes
> Note: Within this library all channels are uppercase.
> We use context (ie obs vs. mag vs geo), to differentiate between h,H; e,E;
> and d,D. This mirrors the various data formats, (ie IAGA2002, etc).

The underlying library provides calculations for both the basic conversions,
such as get_geo_y_from_mag, which is based off of Y = H sin(D), and higher
level conversions, such as get_geo_from_mag. (Which converts HD to XY).
These are provided by `geomagio.ChannelConverter`.

Upper libraries only provide higher level conversions, ie get_geo_from_mag.
This is the level most users should be accessing.
These are provided by `geomagio.StreamConverter`.
> Note: this library internally represents data gaps as NaN, and factories
> convert to this where possible.
Eddie McWhirter's avatar
Eddie McWhirter committed
### [Algorithm Theoretical Basis for "Geomag XYZ"](XYZ.md) ###
Describes the theory behind the XYZ algorithm, as well as some implementation
issues and solutions.