Skip to content

Releases: lsst/rubin_sim

v2.2.0

18 Jan 03:56
ab59ca0
Compare
Choose a tag to compare

Updates with v2.2.0 --

IMPORTANT:
OpenOrb has been removed as a required dependency. This means, if you desire to use openorb to calculate ephemeris values (the utilities are still present in rubin_sim.moving_objects) you will need to install openorb separately.
This needed to happen to allow the overall Rubin environment (rubin_env) progress to Python 3.12, as the conda-forge distribution of openorb is not available for 3.12 at the moment. Work is in progress to update this, but it has been challenging. OpenOrb should still install for python 3.11 and numpy < 2, or from pip.
Hopefully, a future update will either restore openorb as a dependency or will move to an alternate python-compatible ephemeris generator.

Utilities added to support use of MAF or predicted values, now that visits are starting to arrive in the ConsDB:

  • Added DayObs and other time related stackers to support schedview relating to information about visits in the consdb -- i.e. dayObs is available as a stacker,
  • Added an "Age" metric was added to show the time since the last visit at a given point to support schedview plots
  • Function to calculate predicted zeropoints for any given observation are now available as functions in rubin_sim.phot_utils

Metric updates

  • An error in handling the stellar luminosity function when calculating crowding effects was fixed - this means stellar counts which include crowding will change if calculated with MAF 2.2.0 compared to earlier calculations.
  • The run_selfcal script is updated to send an appropriate subset of visits to the selfcal metric.
  • magtype is used to set cometary magnitudes for cometary populations properly.
  • Some plots that took significant time to generate are removed or simplified in the default metric outputs.
  • Some issues relating to calculating SNR in the SN metrics are updated, to allow for (more) variable exposure times.
  • Additional stackers to handle scheduler_note labels more easily for calculating statistics or identifying types of visits

Other work

  • The survey_start_mjd function was deprecated in rubin_scheduler and has been updated appropriately here to SURVEY_START_MJD.
  • scheduler_note is used by default instead of note.
  • Support for building a docker container for use at usdf-maf.slac.stanford.edu has been added.

What's Changed

New Contributors

Full Changelog: v2.1.0...v2.2.0

v2.1.0

18 Jun 20:37
eaed822
Compare
Choose a tag to compare

v2.1.0

In this update, significant new metrics have been added:

  • a photometric calibration metric (contributed by @erykoff)
  • an incremental template metric (contributed by @ebellm, building on prior work by the MAF team)
  • color-slope metrics were added to capture short timescale visit timings
  • updates to the DDF metrics, including coadded depths per night
  • Stackers that provide T_eff and dayobs values have been added, and the corresponding T_eff metrics updated

Significant changes occurred in the plotting methods:

  • plotters now return the matplotlib Figure objects, instead of just the "fig.num" integer values
  • a new set of plotters has been added that uses skyproj instead of healpy to create plots (this is in support of schedview, but is useful for projections beyond those provided by healpy)

Code maintenance and updates:

  • Use of palpy has now been replaced by astropy - rubin-sim now drops its dependency on palpy.
  • Several pandas and numpy deprecation warnings have been addressed
  • Default verbosity levels have been reduced
  • "get_baseline" should now be called from rubin-sim, not rubin-scheduler, and the sim_baseline is downloaded with rs_download_data from rubin-sim.

Significant documentation updates have been achieved - please see rubin-sim.lsst.io for the latest version.

rubin_sim is maintained by @rhiannonlynne, @yoachim, and @ehneilsen of the Rubin Survey Scheduling Team.
rubin_sim is an open-software project and we are grateful for the many contributions from our community.

What's Changed

New Contributors

Full Changelog: v2.0.0...v2.1.0

v2.0.0

29 Nov 03:17
Compare
Choose a tag to compare

This release is a major update, as portions of this package have now been moved to rubin_scheduler. In particular:

  • imports from rubin_sim.scheduler now become rubin_scheduler.scheduler
  • imports from rubin_sim.utils now become rubin_scheduler.utils
  • imports from rubin_sim.skybrightness_pre now become rubin_scheduler.skybrightness_pre
  • imports from rubin_sim.data now mostly become imports from rubin_scheduler.data -- with the caveat that "rs_download_data" and the dictionary of data files relevant to only rubin_sim still are held in rubin_sim.data.

Downloads of data should now include
scheduler_download_data as well as rs_download_data -- these two separate steps will download the necessary data for rubin_sim.

rubin_sim is maintained by @yoachim, @rhiannonlynne, @ehneilsen of the Rubin Survey Scheduling Team.
rubin_sim is an open-software project and we are grateful for the many contributions from our community.

What's Changed

  • tickets/PREOPS-4124 Support restricting the scheduler reward summary stats to a region of interest by @ehneilsen in #376
  • Address future Warning by @rhiannonlynne in #379
  • tickets/PREOPS-4503: replace nans in sky brightness array before IntRounded is applied by @ehneilsen in #378
  • tickets/PREOPS-4501: Do not delete old SkyModelPre attributes until we know if new ones are valid by @ehneilsen in #377
  • Use the same code for basis function & reward area by @ehneilsen in #380
  • lingering camel-snake-pep8 updates by @yoachim in #381
  • Tickets/opsim 1093 (split rubin_sim and rubin_scheduler) by @yoachim in #382

Full Changelog: 1.3.3...v2.0.0

v1.3.3

20 Oct 20:25
c3affd5
Compare
Choose a tag to compare

This update include a bug fix in the Skybrightness Model, so that SEDs returned by return_sed do not contain NaNs.

There is also some extension of "constant weather" options in site_models that is useful for work we're doing to build dashboards to interact with the scheduler in real-time at the telescope, as well as modifications in the "example_scheduler" code that should simplify incorporating future updates to the scheduler configurations used in simulations. This includes moving the survey_start_date provided by rubin_sim.utils.survey_start_date() to the date used in the most recent (v3.2 and v3.3) simulations and updating the sample of skybrightness_pre files provided in rubin-sim-data to match this date.

There is also an update in the DDF generation for simulations, that corrects a small bug that could arise with the DDF scheduling when the survey start date changes.

What's Changed

Full Changelog: 1.3.2...1.3.3

v1.3.2

05 Oct 05:48
0a6cd84
Compare
Choose a tag to compare

Updates with 1.3.2 -

rubin-sim /rubin_sim is now available on pypi!

There are rubin_sim_data updates as well -

  • skybrightness_pre contains a smaller set of default skybrightness files, to speed up download — the full skybrightness_pre files continue to be available via rs_download_sky.
  • site_models has an updated almanac, extending 20 years into the future
  • scheduler data contains a dust map, so now contains all of the data files necessary to set up the example_scheduler
    Running rs_download_data —versions will confirm which of your data files should be updated to match the current version of rubin_sim.

Full Changelog: 1.3.0...1.3.2

v1.3.0

19 Sep 02:14
6eb5518
Compare
Choose a tag to compare

Updates in v1.3.0

Please note that there is an associated rubin_sim_data update in v1.3.0. The new data files include updates in the throughputs , skybrightness and skybrightness_pre files. To get up to date copies of these data files, please run
rs_download_data --force --dirs throughputs,skybrightness,skybrightness_pre
You can check your data versions at any time by running rs_download_data --version (and then update whichever files are necessary).

The throughputs update in v1.3.0 brings the throughput files associated with rubin_sim from the Rubin throughput from release 1.7 to 1.9. These new files correspond to as-measured mirror coatings, filter throughputs, lens coatings and move to a "triple-silver" set of mirror coatings. For more information, please check the README in the syseng_throughputs repository. The skybrightness and skybrightness_pre files are updated to match these new throughput files.

Updates in MAF:

  • the dither stackers have been removed, as dithering is now implemented within the FBS. Some data columns that were used for these stackers are no longer available, which further complicated maintenance of this code.
  • a bugfix in the one-d slicer makes per-night counting metrics work as expected
  • an update in stackers allow rubin_sim.maf to import even without any data files available on disk (previously at least the throughput data files were required)
  • a bugfix in the coadd stacker (which allows coaddition of survey visits over a night) allows it to work even if the "note" column is passed in the data to the stacker
  • pandas h5 files are now compatible with the run comparison functions, instead of only csv files
  • the MAF m52snr function now calculates SNR according to equation 5 in the LSST Overview paper (having the effect of correctly calculating SNR for sources with SNR greater than about 15)
  • the astrometric precision function now optionally accepts a systematic noise floor value (instead of users having to include this separately in their metrics)
  • a y-band-only parallax metric has been added to the standard metrics calculated for astrometry

Updates in FBS:

  • the default behavior for the filter-change function is now to swap u band with y band during the lunar cycle (previous behavior was to swap u with z)
  • basis functions associated with the twilight (greedy and pairs_15) survey have been updated, reducing occasional rapid filter swaps that occurred in baseline_v3.2 and previous runs
  • the m5 basis function has been updated to work as-expected with the provided skybrightness_pre "dark sky" maps (this ensures that even with changes in the dark sky values, the appropriate weights per basis function are retained)
  • if the conditions MJD value is updated, the entire conditions object resets its value (previously, stale values could have been kept)
  • a (non-critical) warning issued when calculating skybrightness near or during twilight time has been fixed

rubin_sim is maintained by @yoachim, @rhiannonlynne, @ehneilsen, and @tribeiro
rubin_sim is an open-software project and we are grateful for the many contributions from our community.

v1.2.0

22 Aug 22:36
794a546
Compare
Choose a tag to compare

Updates v1.2.0

Between v1.1.0 and v1.2.0, some extensive updates in terms of docstrings, formatting, and imports took place. We’re working towards the documentation building without errors or warnings, although this is not there yet.

Code updates include:

  • adding a sun altitude limit for scheduled observations
  • updating the implementation of long gap (triplet) visits to only run for one blob per night, but also to work within the fbs implementation within the scheduler CSC module
  • Observation outputs now include “Target” as well as “note” (note is intended to be scheduler information; target would be more general user-information).
  • Survey names are more usefully/informationally generated automatically. This along with the previous may modify previous use of survey names
  • The ‘example scheduler’ creates a default survey strategy similar to baseline_v3.2.
  • rework the Bandpass class to remove automatic wavelength limit/wavelength step definitions: this is now a user responsibility to ensure they are appropriate, however it does facilitate using non-Rubin bandpass definitions more easily
  • the generation of moving object detections is updated to use pre-calculated rough (daily) grids of observations, if avaiable (note the addition of “pre-computed orbits” to rubin_sim_data). There were also updates in how moving object detections are stored on disk, and thus read in MAF.
  • the “uniformity” metric has a new generalized form, so can be used for more than just observation time/mjd.
  • the “TGapsMetric” has been replaced by the “Gaps” metric, for a more quantitative rather than relative measurement of time sampling at various timescales (primarily a few hours to a day)
  • Addition of a new “limited radar” metric set, which is a copy of a subset of metrics in ‘radar’ (aka “Science metrics”).

What's Changed

New Contributors

Full Changelog: 1.1.1...1.2.0

v1.1.0

30 Mar 22:21
c822f2f
Compare
Choose a tag to compare

What's changed from 1.0.0:

Many bug fixes, including cleanup of bugs from the major transition at v1.0.0.
This includes some updates to allow metrics such as the KNe and XRB metrics to know the start date of the survey.
Improvements to the gathering of summary stats from multiple simulation runs - 'gather_summaries' across multiple MAF output directories now runs much faster. When comparing summary stats, it is now possible to normalize to the median value of a given metric across all runs (instead of just to the metric value of a single run).
Updated our use of sqlalchemy so rubin_sim is now sqlalchemy2 compatible.

There were several updates to the 'scheduler' module to better enable observing with the fbs on AuxTel, as well as some bug fixes related to support of simulations and investigation of fbs state over short timescales. This includes enabling a mode to read back in acquired observations to the scheduler to significantly improve 'warm start' startup time.
Enhancements to the fbs (scheduler) code were made to improve "schedview" usage and insight into the state of the fbs.
The scheduler module also now includes code which will allow a user to set up a default survey that is similar to the current baseline.
We have also added a 47 year historical cloud database to rubin_sim_data/site_models, in addition to the previous 20 year model. These should be generally consistent, although not exactly the same, during the period of overlap.

rubin_sim is maintained by @yoachim, @rhiannonlynne, @ehneilsen, and @tribeiro
rubin_sim is also an open-software project and we are grateful for the many contributions from our community.

v1.0.0

28 Nov 23:23
3f3b6f6
Compare
Choose a tag to compare

v1.0.0
This is a breaking change to the API, with a refactor of the codebase to better conform to python naming standards.

In general, names that previously looked like "runAll" became "run_all", "readSED_flambda" is now "read_sed_flambda", "mafContrib" is "maf_contrib", etc. Locations of methods and classes should be the same, and functionality should be preserved -- this is primarily a deep naming change.

Other notable changes from v.0.12.0 include:

  • rubin_sim data is now downloaded from USDF
  • filter names in the scheduler can now be 40 characters
  • there is a satellite streak module (rubin_sim.satellite_constellations) which can be used to simulate satellite impacts and scheduler responses
  • the site_models module can now use a variety of cloud models, enabling testing of weather robustness
  • there has been considerably more verification of the DESC SNIa metric, resulting in consistent results between MAF and DESC
  • tweaks and updates to several other metrics
  • ongoing work in the scheduler to enable more use at AuxTel and better interaction with the on-the-fly monitoring tool schedview

rubin_sim is maintained by @yoachim, @rhiannonlynne, @ehneilsen, and @tribeiro
rubin_sim is also an open-software project and we are grateful for the many contributions from our (primarily astronomical) community.

0.14.0

28 Nov 19:54
8596858
Compare
Choose a tag to compare

v0.14.0
This is a last release pre v1.0.0 which will implement breaking changes in the API, due to refactoring the names to be more PEP8 compliant.