.. _bskReleaseNotes: Basilisk Release Notes ====================== .. Note:: We are very excited by the great capabilities that this software already has, and plan to be updating this software regularly. There is some documentation in terms of Sphinx generated HTML documentation, but also documentation within the code, and several Basilisk modules that are math heavy have LaTeX'd documentation folders as well. Best place to start is to run the integrated tutorial scripts inside the ``src/examples`` folder. More documentation and tutorial scripts are in development. .. sidebar:: In Progress Features - ability to integrate custom Basilisk modules that are kept outside of the core Basilisk folder - GPU based methods to evaluate solar radiation pressure forces and torques - atmospheric drag evaluation using multi-faceted spacecraft model - create modules to determine if a satellite can see a ground point such as a communication station - make a gravity gradient torque effector - upgrading :ref:`vizInterface` to support showing info panels and HUD multiple spacecraft with thruster - working on a new, faster, more capable, more robust and just plain awesome new build system - working on a new messaging system that is much faster to log, avoids ever connecting to the wrong message type, etc. Version 1.5.1 ------------- - Fixed an issue running :ref:`test_reactionWheelStateEffector_integrated` using Python 2 - fixed a ``cmake`` issue where the module renaming from ``viz_interface`` to ``vizInterface`` was applied Version 1.5.0 ------------- - Updated documentation for :ref:`eclipse` module with new RST format - Updated :ref:`fswModuleTemplate` documentation to show how to add equation numbers, cite equations, do bold math variables and cite a figure caption. - Updated :ref:`reactionWheelStateEffector` and :ref:`vscmgStateEffector` such that max speed and max torque are consistently initialized to -1. A negative value was supposed to turn of speed and torque saturation, but this wasn't consistenly applied. - Updated :ref:`reactionWheelStateEffector` such that the RW state output message was not hard-coded and un-changeable. Otherwise a BSK process could never have multiple spacecraft being simulated. Now, the rw effector ``ModelTag`` is added to the beginning of the output message. This auto-generate method of message output names is avoided if the user sets the vector of output names from Python during the simulation setup. **Note:** Any prior BSK script that was logging the old auto-generated RW state messages will need to update the msg name now to work again. See :ref:`bskKnownIssues` for more information. - Major enhancement to :ref:`vizInterface` where now multiple spacecraft can be added. You can create a list of spacecraft where :ref:`vizInterface` relies on common naming rules to find the right messages, or specify the messages for each spacecraft directly. This is demonstrated in :ref:`scenarioFormationBasic`. For now multiple craft with RW actuators are supported. Multi craft with thrusters will need to be added later. - New spacecraft formation flying scenario :ref:`scenarioFormationBasic` where 3 satellites are flying 10m apart in a lead-follower configuration. Each has a different number of RWs. This scenario is a nice script to demonstrate the new multi-spacecraft support in :ref:`vizard`. **Version 1.4.2** - added link to Basilisk facebook page to Sphinx-based documentation - made the html documentation compatible with dark mode on macOS, iOS and iPad OS browsers. If the user sets the system interface to dark mode, then the dark version of the web site is shown automatically. - added a fix to cmake to get around a ``lipsodium`` and ``conan`` issue we are seeing on a Linux system **Version 1.4.1** - added :ref:`Vizard scripting ` abilities to control the new spacecraft camera view panel behaviors - added :ref:`Vizard scripting ` abilities to specify custom CAD OBJ models to replace the default satellite shape - added :ref:`onboardDataHandling` modules for simulating data generated, downlinked, and stored by instruments, transmitters, and storage units onboard a spacecraft. See :ref:`scenarioDataDemo` for a demo. - updated :ref:`sunlineSuKF` with some general improvements - tweak to ``cmake`` file to make BSK be portable across Linux systems - changed the :ref:`bskLogging` level names to make them unique. This avoids potential variable name conflicts, especially on Windows. **Version 1.4.0** - updates to the Monte Carlo controller and plotting algorithms to make use of better use of Pandas and Datashader - Added a message to the heading estimator in order to perform OpNav pointing - added a general message to the Sphinx HTML documentation landing page - updated the :ref:`bskModuleCheckoutList` with updated information and expectations - added a new help page on :ref:`makeBskFork` - Added a fault detection module for optical navigation - Added camera module to own the message and to add corruptions to images - Added a new support document :ref:`makingNewBskModule` on getting started writing BSK modules - Added a new support document :ref:`addSphinxDoc` - Updated the :ref:`aboutBSK` page to include Basilisk highlights - Made sure the Monte Carlo unit tests didn't leave any temporary data files behind - Added new helper functions to the RW and Thruster factory classes to return the equivalent FSW configuration message. Updated :ref:`scenarioAttitudeFeedbackRW` simulation script to illustrate how to use such a helper function. - Added a new Basilisk logging system called :ref:`bskLogging`. This allows modules to print information with a variable verbosity level - Include a new example scenario :ref:`scenarioBskLog` to illustrate how to use variable verbosity BSK notices **Version 1.3.2** - added the ability to include the unit test python files, along with their documentation, within the sphinx html documentation - updated Vizard live streaming documentation - updated unit test templates to have better formatting of the html validation report obtained with ``pytest --report`` - exclude some un-needed files from the html documenation - general sphinx documentation related fixed and enhancements **Version 1.3.1** - small fixes to the new HTML documentation - correct the path includes in Monte Carlo Integrated tests - updated the ``MRP_Steering`` module documentation to include plots of all test cases **Version 1.3.0** - Update template illustrating how the validation accuracy can be recording in the ``pytest`` parameters. - Created a new method in ``SimulationBaseClass`` called ``pullMultiMessageLogData`` This is much faster in pulling the data log from multiple messages at once. - It is no longer necessary to call sim.TotalSim.terminateSimulation() at the beginning of Basilisk scripts. This call has been moved to the SimBaseClass constructor and removed from scripts in the repository. - A new module in the environments directory, SolarFlux, provides the solar flux value at a spacecraft location including (optionally) eclipse effects - New module in the navigation directory, PlanetHeading, provides the heading to a planet in the spacecraft body frame. There is a corresponding new message type BodyHeadingSimMsg. - New Sphinx/Breathe based BSK documentation system! All documentation is still stored in the ``basilisk/docs`` folder. The new system provides much better directory structure to access the BSK modules, and has a cleaner way to list the tutorial examples. **Version 1.2.1** - fixed an issued with the magnetometer module tests not passing on all platforms. The tolerances are now adjusted to pass everywhere. - various improvements to the ``OpNav`` modules and ``vizInterface`` **Version 1.2.0** - Making the Python 3 compile flag be turned on by default. To compile with Python 2 the ``cmake`` flag ``-DUSE_PYTHON3`` can still be set to ``OFF`` - Revised the FSW template module to use the updated in-line module documentation style which adds the description to the module ``*.h`` doxygen description, and adds the validation discussion as a doc-string to the ``test_xxx.py`` test file. - make sure ``mrpRotation`` is non-singular for any general referene rotation. - Created a Three-Axis-Magnetometer (TAM) sensor simulation model - Created a TAM FSW communication model - Changed the BSK ``ReadMessage()`` method to automatically zero the message memory space before reading in the data - Added a base classes for battery energy storage and power consumption/provider nodes - Added a simple power node module - Added a simpler battery module - Added a simple solar panel power module **Version 1.1.0** - The circle finding module using openCV has been cleaned up and the noise is now dynamically measured given the image - A new dispersion was added for Monte Carlo analysis which allows for per-axis control on an initial MRP value - Cleaned up opNav messages to be consistent with other messages, and simplified the limbFinding code. Only functionality change is Gaussian Blur. - Add new OpNav module using a planet limb. Algorithm developed by J. Christian - Added support for OpenCV v 4.1.1 and Eigen library 3.3.7 - fixed issue with Windows having trouble compiling due to use of ``uint`` - added instructions on how to use the new Xcode 11 on macOS. This requires installing 2 more tools. Updated the install and macOS FAW pages. - added the ability to ``pytest`` to use the ``--report`` flag to generate a comprehensive html test and validation document. All future modules should use this method to discuss the module validation. Legacy modules will be converted over time. - Corrected an issue with some some BSK modules in a low memory computer environment **Version 1.0.0 🍾🍾🍾🍾🍾** .. raw:: html **Version 0.9.1** .. raw:: html **Version 0.9.0** .. raw:: html **Version 0.8.1** .. raw:: html **Version 0.8.0** .. raw:: html **Version 0.7.2** .. raw:: html **Version 0.7.1** .. raw:: html **Version 0.7.0** .. raw:: html **Version 0.6.2** .. raw:: html **Version 0.6.1** .. raw:: html **Version 0.6.0** .. raw:: html **Version 0.5.1** .. raw:: html **Version 0.5.0** .. raw:: html **Version 0.4.1** .. raw:: html **Version 0.4.0** .. raw:: html **Version 0.3.3** .. raw:: html **Version 0.3.2** .. raw:: html **Version 0.3.1** .. raw:: html **Version 0.3.0** .. raw:: html **Version 0.2.3 (June 12, 2018)** .. raw:: html **Version 0.2.2 (May 14, 2018)** .. raw:: html **Version 0.2.1** .. raw:: html **Version 0.2.0 (First public beta)** .. raw:: html **Version 0.1.7** .. raw:: html **Version 0.1.6** .. raw:: html **Version 0.1.5** .. raw:: html **Version 0.1.4** .. raw:: html **Version 0.1.3** .. raw:: html **Version 0.1.2** .. raw:: html **Version 0.1.1** .. raw:: html **Version 0.1.0** Simulation modules include: ~~~~~~~~~~~~~~~~~~~~~~~~~~~ .. raw:: html The AVS Lab Flight Algorithm folder contains: ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - FSW template module - CSS based sun heading estimation module - UKF filter to determine inertial attitude - UKF filter to determine CSS based body-relative sun heading - Attitude Guidance modules: - Pointing towards two celestial objects - Inertial Pointing - Hill Frame Pointing - Euler rotation sequence to add dynamics capabilities to the attitude reference generation - Spinning about an inertially fixed axis - A raster manager module that can change the guidance module states - Velocity frame pointing - attitude tracking error evaluation module - Deadband module for attitude tracking error - DV guidance module - Effector Interfaces: - mapping of control torque onto RW motor torques - Converting RW motor torques to voltages - RW null motion module to equalize the wheel speeds continuously - Thruster (THR) firing logic using a Schmitt trigger - THR firing logic using a remainder calculation - mapping of a command torque onto a set of THR devices - module to evaluate the net momentum to dump with thrusters