Giter VIP home page Giter VIP logo

erfa's Introduction

This is the source code repository for ERFA (Essential Routines for Fundamental Astronomy). ERFA is a C library containing key algorithms for astronomy, and is based on the SOFA library published by the International Astronomical Union (IAU).

ERFA is intended to replicate the functionality of SOFA (aside from possible bugfixes in ERFA that have not yet been included in SOFA), but is licensed under a three-clause BSD license to enable its compatibility with a wide range of open source licenses. Permission for this release has been obtained from the SOFA board, and is available in the LICENSE file included in this source distribution.

Differences from SOFA

This version of ERFA (v1.7.1) is based on SOFA version "20200721", with the differences outlined below.

ERFA branding

All references to "SOFA" in the source code have been changed to ERFA, and functions have the prefix era instead of iau.

C macro prefixes

All C macros used in ERFA are the same as their SOFA equivalents, but with an ERFA_ prefix to prevent namespace collisions.

Version information

ERFA provides a few utility functions for accessing version information at runtime which are not a part of SOFA. Specifically, these are the eraVersion, eraVersion*, and eraSofaVersion functions that are exposed in the erfaextra.h header.

Runtime leap second modification

ERFA provides the capability to modify at runtime the leap seconds assumed for various calculations. These are accessed via the eraGetLeapSeconds and eraSetLeapSeconds functions that are exposed in the erfaextra.h header. This functionality is currently considered somewhat experimental, meaning an improved API might be available in the future, but the current API can also be counted on for the near future.

Bug fixes

ERFA includes smaller changes that may or may not eventually make it into SOFA, addressing localized bugs or similar smaller issues:

  • ERFA 1.7.1 and SOFA "20200721"
    • Only bug fixes in the SOFA release. The only differences between ERFA 1.7.1 and SOFA "20200721" remain the added eraVersion, eraSofaVersion, and leap second functions noted above.
  • ERFA 1.7.0 and SOFA "20190722"
    • There are no differences between ERFA 1.7.0 and SOFA "20190722" except for the added eraVersion, eraSofaVersion, and leap second functions noted above.
  • ERFA 1.6.0 and SOFA "20190722"
    • There are no differences between ERFA 1.6.0 and SOFA "20190722" except for the eraVersion and eraSofaVersion functions added in ERFA 1.4.0.
  • ERFA 1.5.0 and SOFA "20180130"
    • There are no differences between ERFA 1.5.0 and SOFA "20180130" except for the eraVersion and eraSofaVersion functions added in ERFA 1.4.0.
  • ERFA 1.4.0 and SOFA "20170420"
    • ERFA 1.4.0 adds the eraVersion and eraSofaVersion functions to determine the installed version of ERFA (and the SOFA version it is derived from).
    • ERFA 1.4.0 includes some bug fixes contributed to ERFA after 1.3.0 but before 1.4.0. These were incorporated (with modification) into SOFA "20170420" (without attribution) and hence these are not differences between ERFA and SOFA. (See liberfa#40 and liberfa#41)
  • ERFA 1.3.0 and SOFA "20160503_a"
    • There are no differences between ERFA 1.3.0 and SOFA "20160503_a".
  • ERFA 1.2.0 and SOFA "20150209_a"
    • Typos have been corrected in the documentation of atco13 and atio13 (see liberfa#29).

Note that issues identified in ERFA should generally also be reported upstream to SOFA at [email protected].

Building and installing ERFA

To build and install a released version of ERFA in your OS's standard location, simply do:

./configure
make
make install

If you want to run the tests to make sure ERFA built correctly, before installing do:

make check

For developers

If you are using a developer version from github, you will need to first do ./bootstrap.sh before the above commands. This requires autoconf and libtool.

If you wish to build against the ERFA static library without installing, you will find it in $ERFAROOT/src/.libs/liberfa.a after running make.

Creating a single-file version of the source code

Alternatively, if you wish to bundle the ERFA source code with a separate package, you can use the source_flattener.py script from the erfa-fetch repository to combine the ERFA source code into just two files: a erfa.c source file, and an erfa.h include file. You should run this script like this:

cd /path/to/erfa-source-code
python /path/to/erfa-fetch/source_flattener.py src -n erfa

If possible, however, it is recommended that you provide an option to use any copy of the ERFA library that is already installed on the system.

Travis build status

https://travis-ci.org/liberfa/erfa.png

Cite As

erfa's People

Contributors

avalentino avatar david-terrett avatar eteq avatar jwoillez avatar mdboom avatar mhvk avatar olebole avatar phn avatar sergiopasra avatar timj avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.