Skip to content

Commit

Permalink
Merge pull request #1510 from spacetelescope/develop
Browse files Browse the repository at this point in the history
v1.2.4 release candidate
  • Loading branch information
BradleySappington authored Mar 8, 2024
2 parents 021211d + cfeb073 commit 6fd9243
Show file tree
Hide file tree
Showing 83 changed files with 4,991 additions and 1,477 deletions.
2 changes: 1 addition & 1 deletion docs/source/database.rst
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,4 @@ reset_database.py
-----------------
.. automodule:: jwql.database.reset_database
:members:
:undoc-members:
:undoc-members:
8 changes: 7 additions & 1 deletion docs/source/website.rst
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,12 @@ monitor_views.py
:members:
:undoc-members:

monitor_models
--------------
.. automodule:: jwql.website.apps.jwql.monitor_models.common
:members:
:undoc-members:

settings.py
-----------
.. automodule:: jwql.website.jwql_proj.settings
Expand All @@ -60,4 +66,4 @@ views.py
--------
.. automodule:: jwql.website.apps.jwql.views
:members:
:undoc-members:
:undoc-members:
3 changes: 2 additions & 1 deletion environment_python_3.10.yml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ channels:
dependencies:
- astropy=5.3.4
- beautifulsoup4=4.12.2
- bokeh=2.4.3
- bokeh=3.3.0
- celery=5.3.4
- cryptography=41.0.4
- django=4.2.6
Expand Down Expand Up @@ -59,6 +59,7 @@ dependencies:
- astroquery==0.4.6
- bandit==1.7.5
- jwst==1.12.3
- jwst_backgrounds==1.2.0
- pysiaf==0.20.0
- pysqlite3==0.5.2
- pyvo==1.4.2
Expand Down
3 changes: 2 additions & 1 deletion environment_python_3.9.yml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ channels:
dependencies:
- astropy=5.3.3
- beautifulsoup4=4.12.2
- bokeh=2.4.3
- bokeh=3.3.0
- celery=5.3.4
- cryptography=41.0.4
- django=4.2.5
Expand Down Expand Up @@ -59,6 +59,7 @@ dependencies:
- astroquery==0.4.6
- bandit==1.7.5
- jwst==1.12.3
- jwst_backgrounds==1.2.0
- pysiaf==0.20.0
- pysqlite3==0.5.2
- pyvo==1.4.2
Expand Down
3 changes: 1 addition & 2 deletions jwql/bokeh_templating/factory.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,7 @@

# Figures get their own constructor so we remove references to Figures from
# the keyword maps.
Figure = mappings.pop("Figure")
del sequences["figure"]
Figure = mappings.pop("figure")


def mapping_factory(tool, element_type):
Expand Down
3 changes: 1 addition & 2 deletions jwql/database/database_interface.py
Original file line number Diff line number Diff line change
Expand Up @@ -84,10 +84,9 @@
from jwql.utils.constants import ANOMALIES_PER_INSTRUMENT
from jwql.utils.constants import FILE_SUFFIX_TYPES
from jwql.utils.constants import JWST_INSTRUMENT_NAMES
from jwql.utils.constants import ON_GITHUB_ACTIONS
from jwql.utils.utils import get_config

ON_GITHUB_ACTIONS = '/home/runner' in os.path.expanduser('~') or '/Users/runner' in os.path.expanduser('~')


# Monkey patch Query with data_frame method
@property
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,6 @@ MEDIAN, float
STDDEV, float
FRAC_MASKED, float
SKYFLAT_FILENAME, string
DOY, float
TOTAL_BKG, float
ENTRY_DATE, datetime
66 changes: 31 additions & 35 deletions jwql/edb/engineering_database.py
Original file line number Diff line number Diff line change
Expand Up @@ -58,20 +58,20 @@
from astroquery.mast import Mast
from bokeh.embed import components
from bokeh.layouts import column
from bokeh.models import BoxAnnotation, ColumnDataSource, DatetimeTickFormatter, HoverTool, Range1d
from bokeh.models import BoxAnnotation, ColumnDataSource, DatetimeTickFormatter, HoverTool
from bokeh.models import Range1d
from bokeh.plotting import figure, output_file, show, save
import numpy as np

from jwst.lib.engdb_tools import ENGDB_Service
from jwql.utils.constants import MIRI_POS_RATIO_VALUES
from jwql.utils.constants import ON_GITHUB_ACTIONS
from jwql.utils.credentials import get_mast_base_url, get_mast_token
from jwql.utils.utils import get_config

MAST_EDB_MNEMONIC_SERVICE = 'Mast.JwstEdb.Mnemonics'
MAST_EDB_DICTIONARY_SERVICE = 'Mast.JwstEdb.Dictionary'

# Temporary until JWST operations: switch to test string for MAST request URL
ON_GITHUB_ACTIONS = '/home/runner' in os.path.expanduser('~') or '/Users/runner' in os.path.expanduser('~')
if not ON_GITHUB_ACTIONS:
Mast._portal_api_connection.MAST_REQUEST_URL = get_config()['mast_request_url']

Expand Down Expand Up @@ -283,7 +283,7 @@ def __mul__(self, mnem):
before = np.where(common_dates == self.data['dates'][block])[0]

if len(before) > 0:
new_blocks.append(before[0]) # + 1)
new_blocks.append(before[0]) # + 1)
except IndexError:
# The final block value is usually equal to the length of the array, and will
# therefore cause an Index Error in the lines above. Ignore that error here.
Expand Down Expand Up @@ -421,7 +421,7 @@ def block_stats(self, sigma=3, ignore_vals=[], ignore_edges=False, every_change=
# calculated, remove those every change values and block values from the EdbMnemonic
# instance.
if every_change:
if len(remove_change_indexes) > 0:
if len(remove_change_indexes) > 0:
self.every_change_values = np.delete(self.every_change_values, remove_change_indexes)
self.blocks = np.delete(self.blocks, remove_change_indexes)

Expand All @@ -439,7 +439,7 @@ def block_stats(self, sigma=3, ignore_vals=[], ignore_edges=False, every_change=
stdevs.append(stdevval)
maxs.append(meanval)
mins.append(meanval)
#if hasattr(self, 'every_change_values'):
# if hasattr(self, 'every_change_values'):
# updated_every_change_vals.append(self.every_change_values[i + 1])
self.mean = means
self.median = medians
Expand Down Expand Up @@ -510,9 +510,9 @@ def block_stats_filter_positions(self, sigma=5):
self.data["euvalues"].data[index:self.blocks[i + 1]],
sigma=sigma)
if np.isfinite(meanval):
#this is preventing the nans above from being added. not sure what to do here.
#bokeh cannot deal with nans. but we need entries in order to have the blocks indexes
#remain correct. but maybe we dont care about the block indexes after averaging
# this is preventing the nans above from being added. not sure what to do here.
# bokeh cannot deal with nans. but we need entries in order to have the blocks indexes
# remain correct. but maybe we dont care about the block indexes after averaging
medtimes.append(calc_median_time(self.data["dates"].data[index:self.blocks[i + 1]][good]))
means.append(meanval)
medians.append(medianval)
Expand All @@ -523,7 +523,7 @@ def block_stats_filter_positions(self, sigma=5):
# If there were blocks composed entirely of bad data, meaning no mean values were
# calculated, remove those every change values and block values from the EdbMnemonic
# instance.
if len(remove_change_indexes) > 0:
if len(remove_change_indexes) > 0:
self.every_change_values = np.delete(self.every_change_values, remove_change_indexes)
self.blocks = np.delete(self.blocks, remove_change_indexes)

Expand Down Expand Up @@ -690,37 +690,33 @@ def bokeh_plot(self, show_plot=False, savefig=False, out_dir='./', nominal_value
if plot_mean:
source_mean = ColumnDataSource(data={'mean_x': self.median_times, 'mean_y': self.mean})
mean_data = fig.scatter(x='mean_x', y='mean_y', line_width=1, line_color='orange', alpha=0.75, source=source_mean)
mean_hover_tool = HoverTool(tooltips=[('Mean', '@mean_y'),
('Date', '@mean_x{%d %b %Y %H:%M:%S}')
], mode='mouse', renderers=[mean_data])
mean_hover_tool = HoverTool(tooltips=[('Mean', '@mean_y'), ('Date', '@mean_x{%d %b %Y %H:%M:%S}')],
mode='mouse', renderers=[mean_data])
mean_hover_tool.formatters = {'@mean_x': 'datetime'}
fig.tools.append(mean_hover_tool)

if plot_median:
source_median = ColumnDataSource(data={'median_x': self.median_times, 'median_y': self.median})
median_data = fig.scatter(x='median_x', y='median_y', line_width=1, line_color='orangered', alpha=0.75, source=source_median)
median_hover_tool = HoverTool(tooltips=[('Median', '@median_y'),
('Date', '@median_x{%d %b %Y %H:%M:%S}')
], mode='mouse', renderers=[median_data])
median_hover_tool = HoverTool(tooltips=[('Median', '@median_y'), ('Date', '@median_x{%d %b %Y %H:%M:%S}')],
mode='mouse', renderers=[median_data])
median_hover_tool.formatters = {'@median_x': 'datetime'}
fig.tools.append(median_hover_tool)

# If the max and min arrays are to be plotted, create columndata sources for them as well
# If the max and min arrays are to be plotted, create columndata sources for them as well
if plot_max:
source_max = ColumnDataSource(data={'max_x': self.median_times, 'max_y': self.max})
max_data = fig.scatter(x='max_x', y='max_y', line_width=1, color='black', line_color='black', source=source_max)
max_hover_tool = HoverTool(tooltips=[('Max', '@max_y'),
('Date', '@max_x{%d %b %Y %H:%M:%S}')
], mode='mouse', renderers=[max_data])
max_hover_tool = HoverTool(tooltips=[('Max', '@max_y'), ('Date', '@max_x{%d %b %Y %H:%M:%S}')],
mode='mouse', renderers=[max_data])
max_hover_tool.formatters = {'@max_x': 'datetime'}
fig.tools.append(max_hover_tool)

if plot_min:
source_min = ColumnDataSource(data={'min_x': self.median_times, 'min_y': self.min})
min_data = fig.scatter(x='min_x', y='min_y', line_width=1, color='black', line_color='black', source=source_min)
minn_hover_tool = HoverTool(tooltips=[('Min', '@min_y'),
('Date', '@min_x{%d %b %Y %H:%M:%S}')
], mode='mouse', renderers=[min_data])
minn_hover_tool = HoverTool(tooltips=[('Min', '@min_y'), ('Date', '@min_x{%d %b %Y %H:%M:%S}')],
mode='mouse', renderers=[min_data])
min_hover_tool.formatters = {'@min_x': 'datetime'}
fig.tools.append(min_hover_tool)

Expand All @@ -740,12 +736,12 @@ def bokeh_plot(self, show_plot=False, savefig=False, out_dir='./', nominal_value
fig = add_limit_boxes(fig, yellow=yellow_limits, red=red_limits)

# Make the x axis tick labels look nice
fig.xaxis.formatter = DatetimeTickFormatter(microseconds=["%d %b %H:%M:%S.%3N"],
seconds=["%d %b %H:%M:%S.%3N"],
hours=["%d %b %H:%M"],
days=["%d %b %H:%M"],
months=["%d %b %Y %H:%M"],
years=["%d %b %Y"]
fig.xaxis.formatter = DatetimeTickFormatter(microseconds="%d %b %H:%M:%S.%3N",
seconds="%d %b %H:%M:%S.%3N",
hours="%d %b %H:%M",
days="%d %b %H:%M",
months="%d %b %Y %H:%M",
years="%d %b %Y"
)
fig.xaxis.major_label_orientation = np.pi / 4

Expand Down Expand Up @@ -1206,12 +1202,12 @@ def plot_data_plus_devs(self, use_median=False, show_plot=False, savefig=False,
fig_dev.line(data_dates, dev, color='red')

# Make the x axis tick labels look nice
fig_dev.xaxis.formatter = DatetimeTickFormatter(microseconds=["%d %b %H:%M:%S.%3N"],
seconds=["%d %b %H:%M:%S.%3N"],
hours=["%d %b %H:%M"],
days=["%d %b %H:%M"],
months=["%d %b %Y %H:%M"],
years=["%d %b %Y"]
fig_dev.xaxis.formatter = DatetimeTickFormatter(microseconds="%d %b %H:%M:%S.%3N",
seconds="%d %b %H:%M:%S.%3N",
hours="%d %b %H:%M",
days="%d %b %H:%M",
months="%d %b %Y %H:%M",
years="%d %b %Y"
)
fig.xaxis.major_label_orientation = np.pi / 4

Expand Down
26 changes: 18 additions & 8 deletions jwql/example_config.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,31 @@
"admin_account" : "",
"auth_mast" : "",
"connection_string" : "",
"database" : {
"databases" : {
"engine" : "",
"name" : "",
"user" : "",
"password" : "",
"host" : "",
"port" : ""
},
"django_database" : {
"ENGINE" : "",
"NAME" : "",
"USER" : "",
"PASSWORD" : "",
"HOST" : "",
"PORT" : ""
"django_databases" : {
"default": {
"ENGINE" : "",
"NAME" : "",
"USER" : "",
"PASSWORD" : "",
"HOST" : "",
"PORT" : ""
},
"monitors": {
"ENGINE" : "",
"NAME" : "",
"USER" : "",
"PASSWORD" : "",
"HOST" : "",
"PORT" : ""
}
},
"jwql_dir" : "",
"jwql_version": "",
Expand Down
10 changes: 2 additions & 8 deletions jwql/instrument_monitors/common_monitors/bad_pixel_monitor.py
Original file line number Diff line number Diff line change
Expand Up @@ -105,19 +105,13 @@
from jwql.shared_tasks.shared_tasks import only_one, run_pipeline, run_parallel_pipeline
from jwql.utils import crds_tools, instrument_properties, monitor_utils
from jwql.utils.constants import DARKS_BAD_PIXEL_TYPES, DARK_EXP_TYPES, FLATS_BAD_PIXEL_TYPES, FLAT_EXP_TYPES
from jwql.utils.constants import JWST_INSTRUMENT_NAMES, JWST_INSTRUMENT_NAMES_MIXEDCASE
from jwql.utils.constants import JWST_INSTRUMENT_NAMES, JWST_INSTRUMENT_NAMES_MIXEDCASE, ON_GITHUB_ACTIONS
from jwql.utils.constants import ON_READTHEDOCS
from jwql.utils.logging_functions import log_info, log_fail
from jwql.utils.mast_utils import mast_query
from jwql.utils.permissions import set_permissions
from jwql.utils.utils import copy_files, create_png_from_fits, ensure_dir_exists, get_config, filesystem_path

# Determine if the code is being run by Github Actions
ON_GITHUB_ACTIONS = '/home/runner' in os.path.expanduser('~') or '/Users/runner' in os.path.expanduser('~')

# Determine if the code is being run as part of a Readthedocs build
ON_READTHEDOCS = False
if 'READTHEDOCS' in os.environ: # pragma: no cover
ON_READTHEDOCS = os.environ['READTHEDOCS']

if not ON_GITHUB_ACTIONS and not ON_READTHEDOCS:
from jwql.website.apps.jwql.monitor_pages.monitor_bad_pixel_bokeh import BadPixelPlots
Expand Down
Loading

0 comments on commit 6fd9243

Please sign in to comment.