From 7bf679fe696fcf5c7687f04eb26622fb023dc43a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lars=20Hin=C3=BCber?= <105521415+larshinueber@users.noreply.github.com> Date: Fri, 9 Aug 2024 17:22:47 +0200 Subject: [PATCH 1/3] update readme --- README.md | 264 ++++++++---------------------------------------------- 1 file changed, 38 insertions(+), 226 deletions(-) diff --git a/README.md b/README.md index 2602d162..654ad0fb 100644 --- a/README.md +++ b/README.md @@ -1,247 +1,59 @@ -![alt text](cover.png "Logo Title Text 1") +# ``tudat-space`` -# Foreword +This repository contains the source code for the `tudat-space` website, found under [docs.tudat.space](https://docs.tudat.space/). The website contains a getting-started section for new users, a comprehensive user-guide along with some background information on the Tudat project. It is built using -To the ongoing developers of tudat and its ecosystem: I apologise sincerely. The codebases have gone through a complete refractoring, but I will motivate and go through each and every one of them. I also give you my word that I will be here be here to ensure a smooth transition to the accepted changes of the codebase (I will refractor specific changes if it is so desired by the majority). There are changes to the development workflow and user workflow which concern both performance and conventions. Also, for the first time in my memory of the environment, we have versioning! +## Structure of `tudat-space` -# Table of Contents -1. [Repositories](#repositories) -2. [Changes](#changes) -2. [Users](#users) -3. [Developers](#developers) -4. [Goals](#goals) +The `tudat-space` directory contains the `docs` directory, which hosts all information required to build the `tudat-space` website: +1. `tudat-space/docs/source`, where the source of the website is written in `.rst` files. +2. `tudat-space/docs/environment.yaml`, which holds information to create the `tudat-docs` environment. This environment is used to build the website locally. +3. (If the documentation has been built locally): `tudat-space/docs/build`, which contains the local build in `.html` files + -# Repositories +## How to build the `tudat-space` website locally -This section briefly describes all repositories contained within the `tudat-team` organization. +The Sphinx build process is documented in the [tudat-developer-docs](https://tudat-developer.readthedocs.io/en/latest/primer/docs/sphinx.html). -## **[tudat-bundle](https://github.com/tudat-team/tudat-bundle)** -**A developers repository for the tudat environment.** If you're used to the original way of working with tudat, this -will be familiar. This repository bundles together all dependencies that are maintained by the tudat-team, with the -addition of pybind11. Boost and Eigen have well maintained packages on conda-forge which reduces compile time -(w.r.t. Boost), so their dependencies are met through specifying the `CMAKE_PREFIX_PATH=$CONDA_PREFIX`, for your chosen -conda environment. +In short, the `tudat-space` website can be built as follows: -## **[tudatpy](https://github.com/tudat-team/tudatpy)** -**A Python platform to perform astrodynamics and space research.** +1. Install the `tudat-docs` conda environment: -## **[tudat](https://github.com/tudat-team/tudat)** -**A C++ platform to perform astrodynamics and space research.** If the tudat environment were Io, the most geologically -active object in the solar system, then tudat would be the iron constituent of its core. It comprises of a powerful set -of C++ libraries aimed towards facilitating astrodynamics and space research. +```bash +conda env create -f docs/environment.yaml +``` -## **[tudat-resources](https://github.com/tudat-team/tudat-resources)** -**A curated resource manager to facilitate astrodynamics and space research.** There is a continuous demand to -incorporate readily available and accessible resources for tudat, as well as allow for unique analyses that may be rare. -For this purpose, all spice kernels, space weather data, gravity models (everything that can be classified as data -outside of a header file) have been separated from tudat. The end goal is to eventually have the package retrieve -resources on the fly, as requested, from the original source. (e.g. the spice kernels path will mirror the original -[source](https://naif.jpl.nasa.gov/pub/naif/generic_kernels/), downloading artifacts only when requested, or in advance -with user configuration). When `tudat-resources` is complete, it will: +2. Activate the `tudat-docs` environment: -- Ensure resources specified in a `resource-manifest.json` are downloaded and ready to use when requested. -- Download resources upon request. -- Provide a C++ and Python library to access the resources. +```bash +conda activate tudat-docs +``` -## **[sofa-cmake](https://github.com/tudat-team/sofa-cmake)** -`sofa-cmake` is a repository which contains the `SOFA` ANSI C source code, with additional -cmake files in order to interface with `tudat`. From The International Astronomical Union's SOFA service website: +3. Build the website: -> The International Astronomical Union's SOFA service has the task of establishing and maintaining an accessible and -> authoritative set of algorithms and procedures that implement standard models used in fundamental astronomy. The -> service is managed by an international panel, the SOFA Board, appointed through IAU Division A — Fundamental Astronomy. -> SOFA also works closely with the International Earth Rotation and Reference Systems Service (IERS). +The local build can be triggered from the command-line or using an IDE. For IDE-specific instructions, see the [tudat-developer-docs](https://tudat-developer.readthedocs.io/en/latest/primer/docs/sphinx.html#compiling-documentation-in-pycharm). -Bundled documentation from the source code is hosted at [tudat.space](http://tudat.space/). For further information on -`SOFA`, please see [iausofa.org](http://www.iausofa.org/). +The website is built using the `sphinx-build` command, specifying `html` as desired output. -## **[cspice-cmake](https://github.com/tudat-team/cspice-cmake)** -`cspice-cmake` is a repository which contains the `SPICE` toolkits for C, with additional -cmake files in order to interface with `tudat`. From the Navigation and Ancillary Information Facility (NAIF) website: +```bash +sphinx-build -b html docs/source docs/build +``` -> NASA's Navigation and Ancillary Information Facility (NAIF) offers NASA flight projects and NASA funded researchers -> the "SPICE" observation geometry information system to assist scientists in planning and interpreting scientific -> observations from space-based instruments aboard robotic planetary spacecraft. SPICE is also used in support of -> engineering tasks associated with these missions. While planetary missions were the original focus, today SPICE is -> also used on some heliophysics and earth science missions. +By default, this will only trigger a partial rebuild of the files with changes. +This might lead to issues when changing file names or after switching branches. +In that case, a full rebuild can be triggered by adding a `-E` flag: -Bundled documentation from the source code is hosted at [tudat.space](http://tudat.space/). For further information on -`SPICE`, please see [naif.jpl.nasa.gov](https://naif.jpl.nasa.gov/naif/index.html). +```bash +sphinx-build -b html docs/source docs/build -E +``` -## **[nrlmsise-00-cmake](https://github.com/tudat-team/nrlmsise-00-cmake)** -`nrlmsise-00-cmake` is a repository which contains the `NRLMSISE-00` Atmosphere Model in C, with additional -cmake files in order to interface with `tudat`. From wikipedia's -[paraphrasing](https://en.wikipedia.org/wiki/NRLMSISE-00) of -[J. M. Picone et al.](https://agupubs.onlinelibrary.wiley.com/doi/full/10.1029/2002JA009430): +For additional troubleshooting see the [Troubleshooting section](https://tudat-developer.readthedocs.io/en/latest/primer/docs/sphinx.html#troubleshooting) in the `tudat-developer-docs`. -> NRLMSISE-00 is an empirical, global reference atmospheric model of the Earth from ground to space. It models the -> temperatures and densities of the atmosphere's components. A primary use of this model is to aid predictions of -> satellite orbital decay due to atmospheric drag. This model has also been used by astronomers to calculate the mass -> of air between telescopes and laser beams in order to assess the impact of laser guide stars on the non-lasing -> telescopes. +4. View the local build: -# Changes -In an effort to modernised the repositories and provide capability to host prebuilt libraries on contemporary package -managers, many changes have been made. Some minor corrections, some styling and most related to the build process. -(See [Google C++ Style Guide](https://google.github.io/styleguide/cppguide.html)) +You can check your local build by opening the newly created `docs/build/index.html` with your preferred browser and navigating as desired. -## Conda support -- Conda package manager support for all repositories has been added (See [Anaconda Cloud](https://anaconda.org/tudat-team)). +## How to trigger a build of the online `tudat-space` website -## Styling -- Directory naming has been changed throughout the tudat source code. -- The `tudat::electro_magnetism` namespace has been changed to `tudat::electromagnetism`. - - -## CMake -- CMakeList.cmake files have been changed throughout the entirety of the tudat source code to provide relocatability -in addition the an install step. -- `yolo` cmake archive added which provided consistent functions to add tudat libraries, tests and executables. -(See [Github](https://github.com/tudat-team/tudat/tree/master/cmake_modules/yolo)) - - -# Users - -1. Download either the graphical *or* command line Anaconda installer [[link](https://www.anaconda.com/products/individual)]. -2. - - -## Documentation - -## Feature requests - -## Submit an issue - -# Developers - -## Packaging ([conda](https://docs.conda.io/en/latest/)) -From the [`conda`](https://docs.conda.io/en/latest/) website, `conda` is a: - -> Package, dependency and environment management for any language—Python, R, Ruby, Lua, Scala, Java, JavaScript, C/ C++, FORTRAN, and more. - -Minconda is solely the conda repository management system without packages, whereas Anaconda is the repository management -system packaged with some built in packages. If you want the bare minimum (bare in mind you will be installing some of -what comes with the base distribution in Anaconda), then install Miniconda -([Miniconda download](https://docs.conda.io/en/latest/miniconda.html)), otherwise you can install -the Graphical, or command line installer of Anaconda ([Anaconda download](https://www.anaconda.com/products/individual)). - -### Building ([conda-build](https://docs.conda.io/projects/conda-build/en/latest/)) -When designing the specifics of a build process for a repository across platforms, to be install by the `conda` package -manager, `conda-build` is concerned. From the [`conda-build`](https://docs.conda.io/projects/conda-build/en/latest/) -documentation: - -> Conda-build contains commands and tools to use conda to build your own packages. It also provides helpful tools to constrain or pin versions in recipes. Building a conda package requires installing conda-build and creating a conda recipe. You then use the conda build command to build the conda package from the conda recipe. - -At the heart of `conda-build` are `conda-recipes`. Within the `tudat-team` repositories, these can be found in the source -code as `.conda`. The `.conda` recipes are used for development purposes, whereas releases on conda are invoked by making -a PR to the master branches of any of the `feedstock` repositories (see below). For more information on `conda-build` -see their [docs](https://docs.conda.io/projects/conda-build/en/latest/index.html). - -Please see [`conda-build` recipes](https://docs.conda.io/projects/conda-build/en/latest/concepts/recipe.html) in -conjunction with the following examples. - -**Example 1**: [cspice-cmake](https://github.com/tudat-team/cspice-cmake) repository recipe. - -````$xslt -.conda -├── bld.bat -├── build.sh -├── conda_build_config.yaml -└── meta.yaml -```` - -The `build.sh` contains the build process for Linux and macOS. Worth noticing is the definition of `CMAKE_PREFIX_PATH`. -This tells `CMake` to install the build into `conda-build`'s `$PREFIX` path. The `$PREFIX` path is an important concept -and is equivalent to the `$CONDA_PREFIX` environment variable following installation of Anaconda or Miniconda. - -````$xslt -#!/usr/bin/env bash - -mkdir build - -cd build - -cmake \ - -DCMAKE_CXX_STANDARD=17 \ - -DCMAKE_BUILD_TYPE=Release \ - -DCMAKE_INSTALL_PREFIX="$PREFIX" \ - -DCMAKE_PREFIX_PATH="$PREFIX" \ - -DCSPICE_BUILD_STATIC_LIBRARY=1 \ - .. - -make -j2 - -ctest - -make install -```` - -The `$PREFIX` path definition fixes the following install tree structure in the compressed package on Anaconda Cloud. -(see the [cspice-cmake package](https://anaconda.org/tudat-team/cspice-cmake/files)). - -## Result -````$xslt -. -├── data -│   └── cspice -│   ├── cook_01.tc -| ... -| -├── include -│   └── cspice -│   ├── f2c.h -| ... -| -├── info -│   ├── about.json -│   ├── files -│   ├── git -│   ├── hash_input.json -│   ├── has_prefix -│   ├── index.json -│   ├── paths.json -│   └── recipe -│   ├── bld.bat -│   ├── build.sh -│   ├── conda_build_config.yaml -│   ├── meta.yaml -│   └── meta.yaml.template -└── lib - ├── cmake - │   └── cspice - │   ├── cspice-config.cmake - │   ├── cspice-config-version.cmake - │   ├── cspice_export.cmake - │   └── cspice_export-release.cmake - └── libcspice.a - -```` - - - - -### Deployment ([conda-smithy](https://github.com/conda-forge/conda-smithy)) -From the [`conda-smithy`](https://github.com/conda-forge/conda-smithy) repository: - -> `conda-smithy` is a tool for combining a conda recipe with configurations to build using freely hosted CI services into a single repository, also known as a feedstock. - -### Peer-review ([conda-forge](https://conda-forge.org/)) -From the [`conda-forge`](https://conda-forge.org/) website: - -> conda-forge is a GitHub organization containing repositories of conda recipes. - -## Versioning ([rever](https://regro.github.io/rever-docs/index.html)) -From the [`rever`](https://regro.github.io/rever-docs/index.html) documentation: - -> Rever is a xonsh-powered, cross-platform software release tool. The goal of rever is to provide sofware projects a standard mechanism for dealing with code releases. Rever aims to make the process of releasing a new version of a code base as easy as running a single command. - -Initiating `rever` in a repository: - - - -# Goals - -- Ease of Accessibility: -- Educational Environment: -- Research and Development: -- Machine Learning Integration: +The `tudat-space` website resides at [docs.tudat.space](https://docs.tudat.space/), where the ``stable`` version (see menu at lower left of this page) contains the docs of the `tudat-space` master branch, and the ``latest`` version of the `tudat-space` develop branch. +The website is rebuilt every time a new commit is pushed on one of the branches. +The progress and log of the online docs build can be found [here](https://readthedocs.org/projects/tudat-space/). \ No newline at end of file From f7851eb46fcb10c69903e0bd4ff1177ef1d72f8c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lars=20Hin=C3=BCber?= <105521415+larshinueber@users.noreply.github.com> Date: Fri, 9 Aug 2024 17:23:06 +0200 Subject: [PATCH 2/3] remove old readme --- docs/README.md | 6 ------ 1 file changed, 6 deletions(-) delete mode 100644 docs/README.md diff --git a/docs/README.md b/docs/README.md deleted file mode 100644 index 8c2df45f..00000000 --- a/docs/README.md +++ /dev/null @@ -1,6 +0,0 @@ -# Tudat-space documentation -This folder contains the docs that make up the documentation of the [tudat-space documentation website](https://tudat-space.readthedocs.io). - -Details on how to contribute to tudat-space documentation can be found at the following page: - -https://tudat-space.readthedocs.io/en/latest/_src_about/documentation.html From 8eabe9bbfb1823a95821fa6beb9e708b50f1f7b8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lars=20Hin=C3=BCber?= <105521415+larshinueber@users.noreply.github.com> Date: Sat, 17 Aug 2024 13:08:41 +0200 Subject: [PATCH 3/3] and project and readthedocs information --- README.md | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 654ad0fb..80da21c7 100644 --- a/README.md +++ b/README.md @@ -1,13 +1,16 @@ # ``tudat-space`` -This repository contains the source code for the `tudat-space` website, found under [docs.tudat.space](https://docs.tudat.space/). The website contains a getting-started section for new users, a comprehensive user-guide along with some background information on the Tudat project. It is built using +This repository contains the source code for the `tudat-space` website, found under [docs.tudat.space](https://docs.tudat.space/). The website contains a getting-started section for new users, a comprehensive user-guide along with some background information on the Tudat project. It is built using Sphinx. + +For more details on the Tudat project, we refer to the [project website](https://docs.tudat.space/en/latest/) and our [project Github page](https://github.com/tudat-team). ## Structure of `tudat-space` -The `tudat-space` directory contains the `docs` directory, which hosts all information required to build the `tudat-space` website: +The `tudat-space` repository contains the `docs` directory, which hosts all information required to build the `tudat-space` website: 1. `tudat-space/docs/source`, where the source of the website is written in `.rst` files. -2. `tudat-space/docs/environment.yaml`, which holds information to create the `tudat-docs` environment. This environment is used to build the website locally. -3. (If the documentation has been built locally): `tudat-space/docs/build`, which contains the local build in `.html` files +2. `tudat-space/docs/environment.yaml`, which holds information to create the `tudat-docs` environment. This environment is used to build the website locally and on [ReadtheDocs](https://readthedocs.org/projects/tudat-space/). +3. `tudat-space/.readthedocs.yml` contains the configuration for the online build on [ReadtheDocs](https://readthedocs.org/projects/tudat-space/). +4. (If the documentation has been built locally): `tudat-space/docs/build`, which contains the local build in `.html` files. ## How to build the `tudat-space` website locally