.. toctree:: :hidden: .. _installLinux: Installing On Linux =================== The preferred method is to use Python 3. For now support is also provided to use the built-in Python 2, but Python 2 support is now a depreciated functionality. Software setup -------------- In order to run Basilisk, the following software will be necessary. This document outline how to install this support software. - `Cmake `__ - `Python `__ 3.7.x OR Python 2.7 (``numpy``, ``matplotlib``, ``pytest``, ``conan``, ``pandas``) - `SWIG `__ (version 3 or 4) - `GCC `__ Dependencies ------------ .. Note:: Depending on your system setup, administrative permissions (sudo or su) may be required to install these dependencies. Some distributions of Linux will use other package management commands such as ``yum``, ``dnf``, of ``pgk``. #. CMake: Available using CMake-GUI or CMake over the command line:: # GUI installation $ apt-get install cmake-gui # Command line installation $ apt-get install cmake #. Python 2.7 / Python 3.x with Pip:: $ apt-get install python2.7 $ apt-get install python3.x #. SWIG: Available using:: $ apt-get install swig3.0 #. A C/C++ Compiler: This is included by default with most Linux systems (``gcc``), but is necessary to build Basilisk. #. A Git compatible version control tool like `SourceTree `__ should be used to :ref:`pull/clone ` the Basilisk repository. #. A install of Conan. Install with pip, an example is below:: $ pip3 install conan Build Process via Terminal -------------------------- For Basilisk Python 2 and Python 3 inter-compatability, build using both following instructions then run using preferred python version. #. First step is to create the destination directory. This is ``dist3`` for Python 3 and ``dist`` for Python 2:: $ mkdir dist3 $ cd dist3 #. Setup Conan Repositories. These can be consolidated into a private conan server `conan getting started docs `__:: $ conan remote add bincrafters https://api.bintray.com/conan/bincrafters/public-conan $ conan remote add conan-community https://api #. CMake here in the build directory with Unix Makefiles, where the source code is located at: ``../src``:: $ cmake -G "Unix Makefiles" -DCMAKE_BUILD_TYPE=Release ../src The ``CMAKE_BUILD_TYPE`` argument can be changed to ``Debug`` as well, but the run-time performance will be significantly slower. #. Can do a multi core make by running ``make -j`` such as ``make -j5``. #. More information is available on Basilisk ``cmake`` :ref:`flag options `. #. To test your setup you can run one of the example scenario scripts. - For example, in the terminal window, make ``basilisk/src/examples/01-OrbitalSimulations`` the current directory. - Run one of the tutorial scenarios, such as:: $ python3 scenarioBasicOrbit.py Other packages some distributions of Linux may need --------------------------------------------------- :: # Update current software $ apt-get update # Helpful for Debian systems - all packages need to compile such as gcc and g++ compilers and other utils. $ apt-get install build-essential # Installing the header files for the Python C API $ apt-get install python-dev # Package development process library to facilitate packaging Python packages $ apt-get install python-setuptools # Tkinter $ apt-get install python-tk # Python PIP $ apt-get install python-pip # Python pytest $ pip install pytest