redback 1.0.1__tar.gz → 1.0.3__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (207) hide show
  1. {redback-1.0.1 → redback-1.0.3}/PKG-INFO +46 -6
  2. {redback-1.0.1 → redback-1.0.3}/README.md +5 -2
  3. {redback-1.0.1 → redback-1.0.3}/redback/__init__.py +4 -0
  4. {redback-1.0.1 → redback-1.0.3}/redback/constraints.py +46 -25
  5. {redback-1.0.1 → redback-1.0.3}/redback/eos.py +1 -0
  6. {redback-1.0.1 → redback-1.0.3}/redback/get_data/fink.py +1 -1
  7. {redback-1.0.1 → redback-1.0.3}/redback/get_data/lasair.py +3 -4
  8. {redback-1.0.1 → redback-1.0.3}/redback/get_data/swift.py +7 -7
  9. {redback-1.0.1 → redback-1.0.3}/redback/interaction_processes.py +1 -4
  10. {redback-1.0.1 → redback-1.0.3}/redback/likelihoods.py +207 -21
  11. {redback-1.0.1 → redback-1.0.3}/redback/model_library.py +2 -2
  12. {redback-1.0.1 → redback-1.0.3}/redback/plotting.py +10 -10
  13. redback-1.0.3/redback/priors/bazin_sne.prior +5 -0
  14. redback-1.0.3/redback/priors/csm_interaction.prior +9 -0
  15. {redback-1.0.1 → redback-1.0.3}/redback/priors/csm_nickel.prior +3 -3
  16. redback-1.0.3/redback/priors/csm_shock_and_arnett.prior +11 -0
  17. redback-1.0.3/redback/priors/csm_shock_and_arnett_bolometric.prior +10 -0
  18. redback-1.0.3/redback/priors/csm_shock_breakout.prior +7 -0
  19. {redback-1.0.1 → redback-1.0.3}/redback/priors/nicholl_bns.prior +2 -1
  20. redback-1.0.3/redback/priors/one_comp_kne_rosswog_heatingrate.prior +5 -0
  21. redback-1.0.3/redback/priors/pwn.prior +7 -0
  22. redback-1.0.3/redback/priors/shocked_cocoon.prior +8 -0
  23. redback-1.0.1/redback/priors/tde_analytical.prior → redback-1.0.3/redback/priors/sn_fallback.prior +5 -5
  24. redback-1.0.3/redback/priors/stream_stream_tde.prior +10 -0
  25. redback-1.0.3/redback/priors/stream_stream_tde_bolometric.prior +9 -0
  26. redback-1.0.3/redback/priors/tde_analytical.prior +8 -0
  27. redback-1.0.3/redback/priors/tde_analytical_bolometric.prior +8 -0
  28. redback-1.0.3/redback/priors/tde_fallback.prior +9 -0
  29. redback-1.0.3/redback/priors/tde_fallback_bolometric.prior +6 -0
  30. redback-1.0.3/redback/priors/tde_synchrotron.prior +6 -0
  31. redback-1.0.3/redback/priors/tophat_from_emulator.prior +9 -0
  32. redback-1.0.3/redback/priors/two_comp_kne_rosswog_heatingrate.prior +9 -0
  33. {redback-1.0.1 → redback-1.0.3}/redback/priors/two_layer_stratified_kilonova.prior +1 -1
  34. redback-1.0.3/redback/priors/villar_sne.prior +7 -0
  35. {redback-1.0.1 → redback-1.0.3}/redback/priors.py +12 -1
  36. {redback-1.0.1 → redback-1.0.3}/redback/sed.py +194 -2
  37. {redback-1.0.1 → redback-1.0.3}/redback/simulate_transients.py +71 -35
  38. redback-1.0.3/redback/tables/GRBs_w_redshift.txt +430 -0
  39. {redback-1.0.1 → redback-1.0.3}/redback/tables/LGRB_table.txt +70 -6
  40. redback-1.0.3/redback/tables/SGRB_table.txt +139 -0
  41. {redback-1.0.1 → redback-1.0.3}/redback/tables/filters.csv +14 -0
  42. redback-1.0.3/redback/tables/qdot_rosswogkorobkin24.pck +0 -0
  43. redback-1.0.3/redback/tables/ztf.tar.gz +0 -0
  44. {redback-1.0.1 → redback-1.0.3}/redback/transient/afterglow.py +17 -7
  45. {redback-1.0.1 → redback-1.0.3}/redback/transient/kilonova.py +6 -3
  46. {redback-1.0.1 → redback-1.0.3}/redback/transient/prompt.py +14 -4
  47. {redback-1.0.1 → redback-1.0.3}/redback/transient/supernova.py +7 -3
  48. {redback-1.0.1 → redback-1.0.3}/redback/transient/tde.py +6 -3
  49. {redback-1.0.1 → redback-1.0.3}/redback/transient/transient.py +29 -12
  50. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/afterglow_models.py +152 -146
  51. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/combined_models.py +69 -48
  52. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/extinction_models.py +6 -6
  53. redback-1.0.3/redback/transient_models/general_synchrotron_models.py +518 -0
  54. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/integrated_flux_afterglow_models.py +2 -2
  55. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/kilonova_models.py +310 -61
  56. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/magnetar_driven_ejecta_models.py +2 -2
  57. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/magnetar_models.py +1 -1
  58. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/phenomenological_models.py +69 -1
  59. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/shock_powered_models.py +159 -110
  60. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/supernova_models.py +211 -43
  61. redback-1.0.3/redback/transient_models/tde_models.py +1469 -0
  62. {redback-1.0.1 → redback-1.0.3}/redback/utils.py +309 -16
  63. {redback-1.0.1 → redback-1.0.3}/redback.egg-info/PKG-INFO +46 -6
  64. {redback-1.0.1 → redback-1.0.3}/redback.egg-info/SOURCES.txt +18 -1
  65. redback-1.0.3/redback.egg-info/requires.txt +27 -0
  66. redback-1.0.3/setup.py +57 -0
  67. redback-1.0.1/redback/priors/csm_interaction.prior +0 -10
  68. redback-1.0.1/redback/priors/shocked_cocoon.prior +0 -8
  69. redback-1.0.1/redback/priors/tde_analytical_bolometric.prior +0 -6
  70. redback-1.0.1/redback/tables/GRBs_w_redshift.txt +0 -413
  71. redback-1.0.1/redback/tables/SGRB_table.txt +0 -135
  72. redback-1.0.1/redback/tables/ztf.tar.gz +0 -0
  73. redback-1.0.1/redback/tables/ztf_obslog.csv +0 -106649
  74. redback-1.0.1/redback/transient_models/tde_models.py +0 -499
  75. redback-1.0.1/setup.py +0 -23
  76. {redback-1.0.1 → redback-1.0.3}/LICENCE.md +0 -0
  77. {redback-1.0.1 → redback-1.0.3}/redback/analysis.py +0 -0
  78. {redback-1.0.1 → redback-1.0.3}/redback/constants.py +0 -0
  79. {redback-1.0.1 → redback-1.0.3}/redback/ejecta_relations.py +0 -0
  80. {redback-1.0.1 → redback-1.0.3}/redback/filters.py +0 -0
  81. {redback-1.0.1 → redback-1.0.3}/redback/get_data/__init__.py +0 -0
  82. {redback-1.0.1 → redback-1.0.3}/redback/get_data/batse.py +0 -0
  83. {redback-1.0.1 → redback-1.0.3}/redback/get_data/directory.py +0 -0
  84. {redback-1.0.1 → redback-1.0.3}/redback/get_data/fermi.py +0 -0
  85. {redback-1.0.1 → redback-1.0.3}/redback/get_data/getter.py +0 -0
  86. {redback-1.0.1 → redback-1.0.3}/redback/get_data/konus.py +0 -0
  87. {redback-1.0.1 → redback-1.0.3}/redback/get_data/open_data.py +0 -0
  88. {redback-1.0.1 → redback-1.0.3}/redback/get_data/utils.py +0 -0
  89. {redback-1.0.1 → redback-1.0.3}/redback/photosphere.py +0 -0
  90. {redback-1.0.1 → redback-1.0.3}/redback/plot_styles/paper.mplstyle +0 -0
  91. {redback-1.0.1 → redback-1.0.3}/redback/priors/alternativepowerlaw_redback.prior +0 -0
  92. {redback-1.0.1 → redback-1.0.3}/redback/priors/alternativepowerlaw_redback_refreshed.prior +0 -0
  93. {redback-1.0.1 → redback-1.0.3}/redback/priors/arnett.prior +0 -0
  94. {redback-1.0.1 → redback-1.0.3}/redback/priors/arnett_bolometric.prior +0 -0
  95. {redback-1.0.1 → redback-1.0.3}/redback/priors/basic_magnetar.prior +0 -0
  96. {redback-1.0.1 → redback-1.0.3}/redback/priors/basic_magnetar_powered.prior +0 -0
  97. {redback-1.0.1 → redback-1.0.3}/redback/priors/basic_magnetar_powered_bolometric.prior +0 -0
  98. {redback-1.0.1 → redback-1.0.3}/redback/priors/basic_mergernova.prior +0 -0
  99. {redback-1.0.1 → redback-1.0.3}/redback/priors/bulla_bns_kilonova.prior +0 -0
  100. {redback-1.0.1 → redback-1.0.3}/redback/priors/bulla_nsbh_kilonova.prior +0 -0
  101. {redback-1.0.1 → redback-1.0.3}/redback/priors/cocoon.prior +0 -0
  102. {redback-1.0.1 → redback-1.0.3}/redback/priors/collapsing_magnetar.prior +0 -0
  103. {redback-1.0.1 → redback-1.0.3}/redback/priors/collapsing_radiative_losses.prior +0 -0
  104. {redback-1.0.1 → redback-1.0.3}/redback/priors/cone_afterglow.prior +0 -0
  105. {redback-1.0.1 → redback-1.0.3}/redback/priors/cooling_envelope.prior +0 -0
  106. {redback-1.0.1 → redback-1.0.3}/redback/priors/doublegaussian_redback.prior +0 -0
  107. {redback-1.0.1 → redback-1.0.3}/redback/priors/doublegaussian_redback_refreshed.prior +0 -0
  108. {redback-1.0.1 → redback-1.0.3}/redback/priors/evolving_magnetar.prior +0 -0
  109. {redback-1.0.1 → redback-1.0.3}/redback/priors/evolving_magnetar_only.prior +0 -0
  110. {redback-1.0.1 → redback-1.0.3}/redback/priors/exponential_powerlaw_bolometric.prior +0 -0
  111. {redback-1.0.1 → redback-1.0.3}/redback/priors/five_component_powerlaw.prior +0 -0
  112. {redback-1.0.1 → redback-1.0.3}/redback/priors/four_component_powerlaw.prior +0 -0
  113. {redback-1.0.1 → redback-1.0.3}/redback/priors/full_magnetar.prior +0 -0
  114. {redback-1.0.1 → redback-1.0.3}/redback/priors/full_vacuum_dipole_magnetar.prior +0 -0
  115. {redback-1.0.1 → redback-1.0.3}/redback/priors/gaussian.prior +0 -0
  116. {redback-1.0.1 → redback-1.0.3}/redback/priors/gaussian_redback.prior +0 -0
  117. {redback-1.0.1 → redback-1.0.3}/redback/priors/gaussian_redback_refreshed.prior +0 -0
  118. {redback-1.0.1 → redback-1.0.3}/redback/priors/gaussiancore.prior +0 -0
  119. {redback-1.0.1 → redback-1.0.3}/redback/priors/gaussianrise_cooling_envelope.prior +0 -0
  120. {redback-1.0.1 → redback-1.0.3}/redback/priors/gaussianrise_cooling_envelope_bolometric.prior +0 -0
  121. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_magnetar.prior +0 -0
  122. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_magnetar_driven_supernova.prior +0 -0
  123. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_magnetar_driven_supernova_bolometric.prior +0 -0
  124. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_magnetar_slsn.prior +0 -0
  125. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_mergernova.prior +0 -0
  126. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_mergernova_evolution.prior +0 -0
  127. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_mergernova_thermalisation.prior +0 -0
  128. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_metzger_magnetar_driven.prior +0 -0
  129. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_metzger_magnetar_driven_evolution.prior +0 -0
  130. {redback-1.0.1 → redback-1.0.3}/redback/priors/general_metzger_magnetar_driven_thermalisation.prior +0 -0
  131. {redback-1.0.1 → redback-1.0.3}/redback/priors/gw_magnetar.prior +0 -0
  132. {redback-1.0.1 → redback-1.0.3}/redback/priors/homologous_expansion_supernova.prior +0 -0
  133. {redback-1.0.1 → redback-1.0.3}/redback/priors/kasen_bns_kilonova.prior +0 -0
  134. {redback-1.0.1 → redback-1.0.3}/redback/priors/kilonova_afterglow.prior +0 -0
  135. {redback-1.0.1 → redback-1.0.3}/redback/priors/kilonova_afterglow_nakarpiran.prior +0 -0
  136. {redback-1.0.1 → redback-1.0.3}/redback/priors/kilonova_afterglow_redback.prior +0 -0
  137. {redback-1.0.1 → redback-1.0.3}/redback/priors/magnetar_luminosity_evolution.prior +0 -0
  138. {redback-1.0.1 → redback-1.0.3}/redback/priors/magnetar_nickel.prior +0 -0
  139. {redback-1.0.1 → redback-1.0.3}/redback/priors/magnetar_only.prior +0 -0
  140. {redback-1.0.1 → redback-1.0.3}/redback/priors/metzger_kilonova_model.prior +0 -0
  141. {redback-1.0.1 → redback-1.0.3}/redback/priors/metzger_magnetar_driven_kilonova_model.prior +0 -0
  142. {redback-1.0.1 → redback-1.0.3}/redback/priors/mosfit_kilonova.prior +0 -0
  143. {redback-1.0.1 → redback-1.0.3}/redback/priors/mosfit_rprocess.prior +0 -0
  144. {redback-1.0.1 → redback-1.0.3}/redback/priors/one_component_ejecta_relation.prior +0 -0
  145. {redback-1.0.1 → redback-1.0.3}/redback/priors/one_component_ejecta_relation_projection.prior +0 -0
  146. {redback-1.0.1 → redback-1.0.3}/redback/priors/one_component_kilonova_model.prior +0 -0
  147. {redback-1.0.1 → redback-1.0.3}/redback/priors/one_component_nsbh_ejecta_relation.prior +0 -0
  148. {redback-1.0.1 → redback-1.0.3}/redback/priors/piecewise_radiative_losses.prior +0 -0
  149. {redback-1.0.1 → redback-1.0.3}/redback/priors/polytrope_eos_two_component_bns.prior +0 -0
  150. {redback-1.0.1 → redback-1.0.3}/redback/priors/power_law_stratified_kilonova.prior +0 -0
  151. {redback-1.0.1 → redback-1.0.3}/redback/priors/powerlaw_redback.prior +0 -0
  152. {redback-1.0.1 → redback-1.0.3}/redback/priors/powerlaw_redback_refreshed.prior +0 -0
  153. {redback-1.0.1 → redback-1.0.3}/redback/priors/powerlawcore.prior +0 -0
  154. {redback-1.0.1 → redback-1.0.3}/redback/priors/radiative_losses.prior +0 -0
  155. {redback-1.0.1 → redback-1.0.3}/redback/priors/radiative_losses_mdr.prior +0 -0
  156. {redback-1.0.1 → redback-1.0.3}/redback/priors/radiative_losses_smoothness.prior +0 -0
  157. {redback-1.0.1 → redback-1.0.3}/redback/priors/radiative_only.prior +0 -0
  158. {redback-1.0.1 → redback-1.0.3}/redback/priors/shock_cooling.prior +0 -0
  159. {redback-1.0.1 → redback-1.0.3}/redback/priors/shock_cooling_and_arnett.prior +0 -0
  160. {redback-1.0.1 → redback-1.0.3}/redback/priors/shock_cooling_bolometric.prior +0 -0
  161. {redback-1.0.1 → redback-1.0.3}/redback/priors/shocked_cocoon_bolometric.prior +0 -0
  162. {redback-1.0.1 → redback-1.0.3}/redback/priors/six_component_powerlaw.prior +0 -0
  163. {redback-1.0.1 → redback-1.0.3}/redback/priors/slsn.prior +0 -0
  164. {redback-1.0.1 → redback-1.0.3}/redback/priors/slsn_bolometric.prior +0 -0
  165. {redback-1.0.1 → redback-1.0.3}/redback/priors/smoothpowerlaw.prior +0 -0
  166. {redback-1.0.1 → redback-1.0.3}/redback/priors/sn_exponential_powerlaw.prior +0 -0
  167. {redback-1.0.1 → redback-1.0.3}/redback/priors/thermal_synchrotron_fluxdensity.prior +0 -0
  168. {redback-1.0.1 → redback-1.0.3}/redback/priors/thermal_synchrotron_lnu.prior +0 -0
  169. {redback-1.0.1 → redback-1.0.3}/redback/priors/thin_shell_supernova.prior +0 -0
  170. {redback-1.0.1 → redback-1.0.3}/redback/priors/three_component_kilonova_model.prior +0 -0
  171. {redback-1.0.1 → redback-1.0.3}/redback/priors/three_component_powerlaw.prior +0 -0
  172. {redback-1.0.1 → redback-1.0.3}/redback/priors/tophat.prior +0 -0
  173. {redback-1.0.1 → redback-1.0.3}/redback/priors/tophat_and_arnett.prior +0 -0
  174. {redback-1.0.1 → redback-1.0.3}/redback/priors/tophat_and_twocomponent.prior +0 -0
  175. {redback-1.0.1 → redback-1.0.3}/redback/priors/tophat_and_twolayerstratified.prior +0 -0
  176. {redback-1.0.1 → redback-1.0.3}/redback/priors/tophat_redback.prior +0 -0
  177. {redback-1.0.1 → redback-1.0.3}/redback/priors/tophat_redback_refreshed.prior +0 -0
  178. {redback-1.0.1 → redback-1.0.3}/redback/priors/trapped_magnetar.prior +0 -0
  179. {redback-1.0.1 → redback-1.0.3}/redback/priors/two_component_bns_ejecta_relation.prior +0 -0
  180. {redback-1.0.1 → redback-1.0.3}/redback/priors/two_component_kilonova_model.prior +0 -0
  181. {redback-1.0.1 → redback-1.0.3}/redback/priors/two_component_nsbh_ejecta_relation.prior +0 -0
  182. {redback-1.0.1 → redback-1.0.3}/redback/priors/two_component_powerlaw.prior +0 -0
  183. {redback-1.0.1 → redback-1.0.3}/redback/priors/twocomponent_redback.prior +0 -0
  184. {redback-1.0.1 → redback-1.0.3}/redback/priors/twocomponent_redback_refreshed.prior +0 -0
  185. {redback-1.0.1 → redback-1.0.3}/redback/priors/type_1a.prior +0 -0
  186. {redback-1.0.1 → redback-1.0.3}/redback/priors/type_1c.prior +0 -0
  187. {redback-1.0.1 → redback-1.0.3}/redback/priors/vacuum_dipole_magnetar_only.prior +0 -0
  188. {redback-1.0.1 → redback-1.0.3}/redback/redback_errors.py +0 -0
  189. {redback-1.0.1 → redback-1.0.3}/redback/result.py +0 -0
  190. {redback-1.0.1 → redback-1.0.3}/redback/sampler.py +0 -0
  191. {redback-1.0.1 → redback-1.0.3}/redback/tables/BATSE_4B_catalogue.csv +0 -0
  192. {redback-1.0.1 → redback-1.0.3}/redback/tables/BATSE_trigger_table.txt +0 -0
  193. {redback-1.0.1 → redback-1.0.3}/redback/tables/GRBcatalog.sqlite +0 -0
  194. {redback-1.0.1 → redback-1.0.3}/redback/tables/OAC_metadata.csv +0 -0
  195. {redback-1.0.1 → redback-1.0.3}/redback/tables/csm_table.txt +0 -0
  196. {redback-1.0.1 → redback-1.0.3}/redback/tables/rubin_baseline_v3.0_10yrs.tar.gz +0 -0
  197. {redback-1.0.1 → redback-1.0.3}/redback/tables/summary_general_swift_bat.txt +0 -0
  198. {redback-1.0.1 → redback-1.0.3}/redback/transient/__init__.py +0 -0
  199. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/__init__.py +0 -0
  200. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/fireball_models.py +0 -0
  201. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/gaussianprocess_models.py +0 -0
  202. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/phase_models.py +0 -0
  203. {redback-1.0.1 → redback-1.0.3}/redback/transient_models/prompt_models.py +0 -0
  204. {redback-1.0.1 → redback-1.0.3}/redback.egg-info/dependency_links.txt +0 -0
  205. {redback-1.0.1 → redback-1.0.3}/redback.egg-info/not-zip-safe +0 -0
  206. {redback-1.0.1 → redback-1.0.3}/redback.egg-info/top_level.txt +0 -0
  207. {redback-1.0.1 → redback-1.0.3}/setup.cfg +0 -0
@@ -1,17 +1,54 @@
1
- Metadata-Version: 2.1
1
+ Metadata-Version: 2.2
2
2
  Name: redback
3
- Version: 1.0.1
3
+ Version: 1.0.3
4
4
  Summary: A Bayesian inference pipeline for electromagnetic transients
5
5
  Home-page: https://github.com/nikhil-sarin/redback
6
6
  Author: Nikhil Sarin, Moritz Huebner
7
- Author-email: nikhil.sarin@su.se
7
+ Author-email: nsarin.astro@gmail.com
8
8
  License: GNU General Public License v3 (GPLv3)
9
9
  Classifier: Programming Language :: Python :: 3
10
10
  Classifier: License :: OSI Approved :: GNU General Public License v3 (GPLv3)
11
11
  Classifier: Operating System :: OS Independent
12
- Requires-Python: >=3.7
12
+ Requires-Python: >=3.10
13
13
  Description-Content-Type: text/markdown
14
14
  License-File: LICENCE.md
15
+ Requires-Dist: numpy==1.26.0
16
+ Requires-Dist: setuptools
17
+ Requires-Dist: pandas
18
+ Requires-Dist: scipy<1.14.0
19
+ Requires-Dist: selenium
20
+ Requires-Dist: matplotlib
21
+ Requires-Dist: astropy
22
+ Requires-Dist: extinction
23
+ Requires-Dist: requests
24
+ Requires-Dist: lxml
25
+ Requires-Dist: sphinx-rtd-theme
26
+ Requires-Dist: sphinx-tabs
27
+ Requires-Dist: bilby
28
+ Requires-Dist: regex
29
+ Requires-Dist: sncosmo
30
+ Requires-Dist: afterglowpy
31
+ Provides-Extra: all
32
+ Requires-Dist: nestle; extra == "all"
33
+ Requires-Dist: sherpa; extra == "all"
34
+ Requires-Dist: scikit-learn; extra == "all"
35
+ Requires-Dist: PyQt5; extra == "all"
36
+ Requires-Dist: lalsuite; extra == "all"
37
+ Requires-Dist: kilonova-heating-rate; extra == "all"
38
+ Requires-Dist: redback-surrogates; extra == "all"
39
+ Requires-Dist: kilonovanet; extra == "all"
40
+ Requires-Dist: astroquery; extra == "all"
41
+ Dynamic: author
42
+ Dynamic: author-email
43
+ Dynamic: classifier
44
+ Dynamic: description
45
+ Dynamic: description-content-type
46
+ Dynamic: home-page
47
+ Dynamic: license
48
+ Dynamic: provides-extra
49
+ Dynamic: requires-dist
50
+ Dynamic: requires-python
51
+ Dynamic: summary
15
52
 
16
53
  [![Documentation Status](https://readthedocs.org/projects/redback/badge/?version=latest)](https://redback.readthedocs.io/en/latest/?badge=latest)
17
54
  ![Python package](https://github.com/nikhil-sarin/redback/workflows/Python%20application/badge.svg)
@@ -45,9 +82,12 @@ Simulate single transients or populations or simulate a full survey including no
45
82
 
46
83
  ### Contributing
47
84
  If you are interested in contributing please join the redback
48
- [slack](https://join.slack.com/t/redback-group/shared_invite/zt-21rsoa26s-kibI8MiA1JiIKM0wCMp5rQ)
85
+ [slack](https://join.slack.com/t/redback-group/shared_invite/zt-2503mmkaq-EMEAgz7i3mY0pg1o~VUdqw)
49
86
  and email [Nikhil Sarin](mailto:nikhil.sarin@su.se?subject=Contributing%20to%20redback).
50
87
 
51
88
  To make changes to redback, we require users to use a merge request system.
52
89
 
53
-
90
+ ### User/Dev calls
91
+ We have regular calls for users and developers.
92
+ These include tutorials on specific redback functionality as well as discussions of new features/feature requests,
93
+ and Q/A. Please join the slack to get details of these calls.
@@ -30,9 +30,12 @@ Simulate single transients or populations or simulate a full survey including no
30
30
 
31
31
  ### Contributing
32
32
  If you are interested in contributing please join the redback
33
- [slack](https://join.slack.com/t/redback-group/shared_invite/zt-21rsoa26s-kibI8MiA1JiIKM0wCMp5rQ)
33
+ [slack](https://join.slack.com/t/redback-group/shared_invite/zt-2503mmkaq-EMEAgz7i3mY0pg1o~VUdqw)
34
34
  and email [Nikhil Sarin](mailto:nikhil.sarin@su.se?subject=Contributing%20to%20redback).
35
35
 
36
36
  To make changes to redback, we require users to use a merge request system.
37
37
 
38
-
38
+ ### User/Dev calls
39
+ We have regular calls for users and developers.
40
+ These include tutorials on specific redback functionality as well as discussions of new features/feature requests,
41
+ and Q/A. Please join the slack to get details of these calls.
@@ -2,3 +2,7 @@ from redback import analysis, constants, get_data, redback_errors, priors, resul
2
2
  transient_models, utils, photosphere, sed, interaction_processes, constraints, plotting, model_library, simulate_transients
3
3
  from redback.transient import afterglow, kilonova, prompt, supernova, tde
4
4
  from redback.sampler import fit_model
5
+ from redback.utils import setup_logger
6
+
7
+ __version__ = "1.0.2"
8
+ setup_logger(log_level='info')
@@ -2,6 +2,7 @@ import numpy as np
2
2
  import redback.eos as eos
3
3
  from redback.constants import *
4
4
  from redback.utils import calc_tfb
5
+ from scipy.interpolate import interp1d
5
6
 
6
7
  def slsn_constraint(parameters):
7
8
  """
@@ -23,7 +24,7 @@ def slsn_constraint(parameters):
23
24
  neutrino_energy = 1e51
24
25
  total_energy = kinetic_energy + neutrino_energy
25
26
  # ensure rotational energy is greater than total output energy
26
- converted_parameters['erot_constraint'] = rotational_energy - total_energy
27
+ converted_parameters['erot_constraint'] = total_energy/rotational_energy
27
28
  # ensure t_nebula is greater than 100 days
28
29
  converted_parameters['t_nebula_min'] = tnebula - 100
29
30
  return converted_parameters
@@ -43,7 +44,7 @@ def basic_magnetar_powered_sn_constraints(parameters):
43
44
  kinetic_energy = 0.5 * mej * vej**2
44
45
  rotational_energy = 2.6e52 * (mass_ns/1.4)**(3./2.) * p0**(-2)
45
46
  # ensure rotational energy is greater than total output energy
46
- converted_parameters['erot_constraint'] = rotational_energy - kinetic_energy
47
+ converted_parameters['erot_constraint'] = kinetic_energy/rotational_energy
47
48
  return converted_parameters
48
49
 
49
50
  def general_magnetar_powered_sn_constraints(parameters):
@@ -61,9 +62,24 @@ def general_magnetar_powered_sn_constraints(parameters):
61
62
  tau = parameters['tsd']
62
63
  rotational_energy = 2*l0*tau
63
64
  # ensure rotational energy is greater than total output energy
64
- converted_parameters['erot_constraint'] = rotational_energy - kinetic_energy
65
+ converted_parameters['erot_constraint'] = kinetic_energy/rotational_energy
65
66
  return converted_parameters
66
67
 
68
+ def vacuum_dipole_magnetar_powered_supernova_constraints(parameters):
69
+ """
70
+ Constraint so that magnetar rotational energy is smaller than some number
71
+
72
+ :param parameters: dictionary of parameters
73
+ :return: converted_parameters dictionary where the violated samples are thrown out
74
+ """
75
+ converted_parameters = parameters.copy()
76
+ l0 = parameters['l0']
77
+ tau = parameters['tau_sd']
78
+ rotational_energy = l0*tau
79
+ # ensure rotational energy is less than the maximum spin down energy
80
+ converted_parameters['erot_constraint'] = rotational_energy/1e53
81
+ return converted_parameters
82
+
67
83
  def general_magnetar_powered_supernova_constraints(parameters):
68
84
  """
69
85
  Constraint so that magnetar rotational energy is smaller than some number
@@ -77,7 +93,7 @@ def general_magnetar_powered_supernova_constraints(parameters):
77
93
  nn = parameters['nn']
78
94
  rotational_energy = (nn-1)*l0*tau/2.0
79
95
  # ensure rotational energy is less than the maximum spin down energy
80
- converted_parameters['erot_constraint'] = 1e53 - rotational_energy
96
+ converted_parameters['erot_constraint'] = rotational_energy/1e53
81
97
  return converted_parameters
82
98
 
83
99
  def tde_constraints(parameters):
@@ -91,7 +107,7 @@ def tde_constraints(parameters):
91
107
  rp = parameters['pericenter_radius']
92
108
  mass_bh = parameters['mass_bh']
93
109
  schwarzchild_radius = (2 * graviational_constant * mass_bh * solar_mass /(speed_of_light**2))/au_cgs
94
- converted_parameters['disruption_radius'] = rp - schwarzchild_radius
110
+ converted_parameters['disruption_radius'] = schwarzchild_radius/rp
95
111
  return converted_parameters
96
112
 
97
113
  def gaussianrise_tde_constraints(parameters):
@@ -103,13 +119,11 @@ def gaussianrise_tde_constraints(parameters):
103
119
  converted_parameters = parameters.copy()
104
120
  ms = parameters['stellar_mass']
105
121
  mbh6 = parameters['mbh_6']
106
- etamin = 0.01*(ms**(-7./15.))*(mbh6**(2./3.))
107
122
  betamax = 12.*(ms**(7./15.))*(mbh6**(-2./3.))
108
123
  tfb = calc_tfb(binding_energy_const=0.8, mbh_6=mbh6,stellar_mass=ms)/86400
109
124
  tfb_obs = tfb * (1 + parameters['redshift'])
110
- converted_parameters['eta_low'] = converted_parameters['eta'] - etamin
111
- converted_parameters['beta_high'] = betamax - converted_parameters['beta']
112
- converted_parameters['tfb_max'] = tfb_obs - converted_parameters['peak_time']
125
+ converted_parameters['beta_high'] = converted_parameters['beta']/betamax
126
+ converted_parameters['tfb_max'] = converted_parameters['peak_time']/tfb_obs
113
127
  return converted_parameters
114
128
 
115
129
  def nuclear_burning_constraints(parameters):
@@ -126,7 +140,7 @@ def nuclear_burning_constraints(parameters):
126
140
  kinetic_energy = 0.5 * mej * (vej / 2.0) ** 2
127
141
  excess_constant = -(56.0 / 4.0 * 2.4249 - 53.9037) / proton_mass * mev_cgs
128
142
  emax = excess_constant * mej * fnickel
129
- converted_parameters['emax_constraint'] = emax - kinetic_energy
143
+ converted_parameters['emax_constraint'] = kinetic_energy/emax
130
144
  return converted_parameters
131
145
 
132
146
  def simple_fallback_constraints(parameters):
@@ -149,7 +163,7 @@ def simple_fallback_constraints(parameters):
149
163
  neutrino_energy = 1e51
150
164
  total_energy = e_fallback + neutrino_energy
151
165
  # ensure total energy is greater than kinetic energy
152
- converted_parameters['en_constraint'] = total_energy - kinetic_energy
166
+ converted_parameters['en_constraint'] = kinetic_energy/total_energy
153
167
  # ensure t_nebula is greater than 100 days
154
168
  converted_parameters['t_nebula_min'] = tnebula - 100
155
169
  return converted_parameters
@@ -162,15 +176,18 @@ def csm_constraints(parameters):
162
176
  :param parameters: dictionary of parameters
163
177
  :return: converted_parameters dictionary where the violated samples are thrown out
164
178
  """
165
- from redback.utils import get_csm_properties
166
179
  converted_parameters = parameters.copy()
167
180
  mej = parameters['mej']
168
181
  csm_mass = parameters['csm_mass']
169
182
  kappa = parameters['kappa']
170
183
  r0 = parameters['r0']
171
184
  vej = parameters['vej']
172
- nn = parameters.get('nn', np.ones(len(mej)) * 12.)
173
- delta = parameters.get('delta', np.ones(len(mej)))
185
+ if hasattr(parameters['mej'], "__len__"):
186
+ nn = parameters.get('nn', np.ones(len(mej)) * 8.)
187
+ delta = parameters.get('delta', np.ones(len(mej)))
188
+ else:
189
+ nn = parameters.get('nn', 12.)
190
+ delta = parameters.get('delta', 0.)
174
191
  eta = parameters['eta']
175
192
  rho = parameters['rho']
176
193
 
@@ -180,12 +197,16 @@ def csm_constraints(parameters):
180
197
  vej = vej * km_cgs
181
198
  Esn = 3. * vej ** 2 * mej / 10.
182
199
 
183
- AA = np.zeros(len(mej))
184
- Bf = np.zeros(len(mej))
185
- for x in range(len(mej)):
186
- csm_properties = get_csm_properties(nn[x], eta[x])
187
- AA[x] = csm_properties.AA
188
- Bf[x] = csm_properties.Bf
200
+ ns = [6, 7, 8, 9, 10, 12, 14]
201
+ Bfs = [1.377, 1.299, 1.267, 1.250, 1.239, 1.226, 1.218]
202
+ As = [0.62, 0.27, 0.15, 0.096, 0.067, 0.038, 0.025]
203
+
204
+ Bf_func = interp1d(ns, Bfs)
205
+ A_func = interp1d(ns, As)
206
+
207
+ Bf = Bf_func(nn)
208
+ AA = A_func(nn)
209
+
189
210
  qq = rho * r0 ** eta
190
211
  # outer CSM shell radius
191
212
  radius_csm = ((3.0 - eta) / (4.0 * np.pi * qq) * csm_mass + r0 ** (3.0 - eta)) ** (
@@ -203,14 +224,14 @@ def csm_constraints(parameters):
203
224
  (3.0 - delta) * (nn - 3.0) * mej) ** ((nn - 5.0) / 2.0))
204
225
 
205
226
  tshock = ((radius_csm - r0) / Bf / (AA * g_n / qq) ** (
206
- 1. / (nn - eta))) ** ((nn - eta) /(nn - 3))
227
+ 1. / (nn - eta))) ** ((nn - eta) / (nn - 3))
207
228
 
208
- diffusion_time = np.sqrt(2. * kappa * mass_csm_threshold /(vej * 13.7 * 3.e10))
229
+ diffusion_time = np.sqrt(2. * kappa * mass_csm_threshold / (vej * 13.7 * 3.e10))
209
230
  # ensure shock crossing time is greater than diffusion time
210
- # converted_parameters['shock_time'] = tshock - diffusion_time
231
+ converted_parameters['shock_time'] = diffusion_time/tshock
211
232
  # ensure photospheric radius is within the csm i.e., r_photo < radius_csm and r_photo > r0
212
- converted_parameters['photosphere_constraint_1'] = radius_csm - r_photosphere
213
- converted_parameters['photosphere_constraint_2'] = r_photosphere - r0
233
+ converted_parameters['photosphere_constraint_1'] = r_photosphere/radius_csm
234
+ converted_parameters['photosphere_constraint_2'] = r0/r_photosphere
214
235
  return converted_parameters
215
236
 
216
237
  def piecewise_polytrope_eos_constraints(parameters):
@@ -78,6 +78,7 @@ class PiecewisePolytrope(object):
78
78
  radius, mass, k2 = lalsim.SimNeutronStarTOVODEIntegrate(central_pressure, polytrope)
79
79
 
80
80
  Lambda = (2 / 3) * k2 * (cc.c.si.value ** 2 * radius / (cc.G.si.value * mass)) ** 5
81
+ mass = mass / cc.M_sun.si.value
81
82
  return mass, Lambda
82
83
 
83
84
  def lambda_array_of_central_pressure(self, central_pressure_array, maximum_mass_lower_limit=2.01):
@@ -45,7 +45,7 @@ class FinkDataGetter(DataGetter):
45
45
  :return: The fink raw data url.
46
46
  :rtype: str
47
47
  """
48
- return "https://fink-portal.org/api/v1/objects"
48
+ return "https://api.fink-portal.org/api/v1/objects"
49
49
 
50
50
  @property
51
51
  def objectId(self) -> str:
@@ -58,8 +58,8 @@ class LasairDataGetter(DataGetter):
58
58
  f"Are you sure you are using the right alias?")
59
59
  data = pd.read_html(self.url)
60
60
  data = data[1]
61
- data['diff_magnitude'] = [data['magpsf'].iloc[x].split(" ")[0] for x in range(len(data))]
62
- data['diff_magnitude_error'] = [data['magpsf'].iloc[x].split(" ")[-1] for x in range(len(data))]
61
+ data['diff_magnitude'] = [data['unforced mag'].iloc[x].split(" ")[0] for x in range(len(data))]
62
+ data['diff_magnitude_error'] = [data['unforced mag'].iloc[x].split(" ")[-1] for x in range(len(data))]
63
63
 
64
64
  logger.warning('Using the difference magnitude to calculate quantities. '
65
65
  'Reduce the data yourself if you would like to use a reference magnitude')
@@ -67,7 +67,6 @@ class LasairDataGetter(DataGetter):
67
67
  # Change the dataframe to the correct raw dataframe format
68
68
  del data['UTC']
69
69
  del data['images']
70
- del data['magpsf']
71
70
  data.to_csv(self.raw_file_path, index=False)
72
71
  logger.info(f"Retrieved data for {self.transient}.")
73
72
 
@@ -83,7 +82,7 @@ class LasairDataGetter(DataGetter):
83
82
  return pd.read_csv(self.processed_file_path)
84
83
 
85
84
  raw_data = pd.read_csv(self.raw_file_path)
86
- raw_data = raw_data[raw_data['difference flux status'] != 'limit']
85
+ raw_data = raw_data[raw_data['unforced mag status'] != 'limit']
87
86
  lasair_to_general_bands = {"g": "ztfg", "r": "ztfr", "i":'ztfi'}
88
87
  processed_data = pd.DataFrame()
89
88
 
@@ -199,9 +199,9 @@ class SwiftDataGetter(GRBDataGetter):
199
199
  driver = fetch_driver()
200
200
  try:
201
201
  driver.get(self.grb_website)
202
- driver.find_element_by_xpath("//select[@name='xrtsub']/option[text()='no']").click()
202
+ driver.find_element("xpath", "//select[@name='xrtsub']/option[text()='no']").click()
203
203
  time.sleep(20)
204
- driver.find_element_by_id("xrt_DENSITY_makeDownload").click()
204
+ driver.find_element("id","xrt_DENSITY_makeDownload").click()
205
205
  time.sleep(20)
206
206
  grb_url = driver.current_url
207
207
  # scrape the data
@@ -227,19 +227,19 @@ class SwiftDataGetter(GRBDataGetter):
227
227
  # select option for BAT bin_size
228
228
  bat_binning = 'batxrtbin'
229
229
  if check_element(driver, bat_binning):
230
- driver.find_element_by_xpath("//select[@name='batxrtbin']/option[text()='SNR 4']").click()
230
+ driver.find_element("xpath", "//select[@name='batxrtbin']/option[text()='SNR 4']").click()
231
231
  # select option for subplot
232
232
  subplot = "batxrtsub"
233
233
  if check_element(driver, subplot):
234
- driver.find_element_by_xpath("//select[@name='batxrtsub']/option[text()='no']").click()
234
+ driver.find_element("xpath","//select[@name='batxrtsub']/option[text()='no']").click()
235
235
  # Select option for flux density
236
236
  flux_density1 = "batxrtband1"
237
237
  flux_density0 = "batxrtband0"
238
238
  if (check_element(driver, flux_density1)) and (check_element(driver, flux_density0)):
239
- driver.find_element_by_xpath(".//*[@id='batxrtband1']").click()
240
- driver.find_element_by_xpath(".//*[@id='batxrtband0']").click()
239
+ driver.find_element("xpath",".//*[@id='batxrtband1']").click()
240
+ driver.find_element("xpath",".//*[@id='batxrtband0']").click()
241
241
  # Generate data file
242
- driver.find_element_by_xpath(".//*[@id='batxrt_XRTBAND_makeDownload']").click()
242
+ driver.find_element("xpath",".//*[@id='batxrt_XRTBAND_makeDownload']").click()
243
243
  time.sleep(20)
244
244
  grb_url = driver.current_url
245
245
  driver.quit()
@@ -165,8 +165,6 @@ class CSMDiffusion(object):
165
165
  # photosphere radius
166
166
  r_photosphere = self.r_photosphere
167
167
 
168
- tau_diff = (self.kappa * self.csm_mass) / (13.8 * speed_of_light * r_photosphere) / day_to_s
169
-
170
168
  # mass of the optically thick CSM (tau > 2/3).
171
169
  mass_csm_threshold = self.mass_csm_threshold
172
170
 
@@ -180,7 +178,7 @@ class CSMDiffusion(object):
180
178
  lu = len(uniq_times)
181
179
 
182
180
  num = int(round(timesteps / 2.0))
183
- lsp = np.logspace(np.log10(tau_diff /self.dense_times[-1]) + minimum_log_spacing, 0, num)
181
+ lsp = np.logspace(np.log10(t0 /self.dense_times[-1]) + minimum_log_spacing, 0, num)
184
182
  xm = np.unique(np.concatenate((lsp, 1 - lsp)))
185
183
 
186
184
  int_times = tb + (uniq_times.reshape(lu, 1) - tb) * xm
@@ -192,7 +190,6 @@ class CSMDiffusion(object):
192
190
 
193
191
  uniq_lums = np.trapz(int_args, int_times, axis=1)
194
192
  uniq_lums *= np.exp(-int_tes/t0)/t0
195
-
196
193
  new_lums = uniq_lums[np.searchsorted(uniq_times, self.time)]
197
194
  return new_lums
198
195