Wavelength Adjustments for Running the Hubble Advanced Spectral Products (HASP) Script#

This Notebook is designed to walk you through making wavelength adjustments to COS & STIS data when running the Hubble Advanced Spectral Products (HASP) coadd script.#

Learning Goals:#

By the end of this tutorial, you will learn how to:

  • Determine if you must make wavelength adjustments based on your coadded product

  • Perform cross-correlation on X1D and SX1 files to determine the wavelength offset between datasets

  • Perform wavelength shifts on COS and STIS data using each instrument’s adjustment methods

  • Run the coadd code on new data and compare pre- and post-shift coadded spectra

Table of Contents#

0. Introduction

1. Performing Wavelength Adjustments on COS Data

- 1.1 Downloading and Organizing COS Data using Astroquery

- 1.2 Running the HASP Script on COS Data

- 1.3 Identifying a Wavelength Shift in COS Data

- 1.4 Performing Cross-Correlation on X1D COS data and Calculating Lag

- 1.5 Applying Shifts to COS data and Re-creating Coadd

- 1.6 Comparing Non-Shifted and Shifted COS Coadds

2. Performing Wavelength Adjustments on STIS data

- 2.1 Downloading and Organizing STIS Data using Astroquery

- 2.2 Running the HASP Script on STIS Data

- 2.3 Performing Cross-Correlation on STIS data and Calculating Lag

- 2.4 Applying Shifts to Raw STIS data and Re-creating Coadd

- 2.5 Comparing Non-Adjusted and Adjusted STIS Coadds

0. Introduction#

The Hubble Advanced Spectral Products (HASP) coadd code is a script that coadds spectra of the same target within a program. This software can coadd data taken with the spectrographs onboard the Hubble Space Telescope (HST): the Space Telescope Imaging Spectrograph (STIS) and the Cosmic Origins Spectrograph (COS). The Hubble Spectroscopic Legacy Archive (HSLA) uses this script to coadd these instruments’ data from The Mikulski Archive for Space Telescopes (MAST) to create high-quality spectra with a broad wavelength coverage that is publicly available for the scientific community. The script first coadds the observations for each grating for a given visit, then it combines all gratings for the observation set. Finally, it coadds the spectra of each observation set in the program to produce a fully coadded spectrum for each target in a program. Check out the COS 2024-1 ISR for more information about the HASP script and products.

Wavelength alignment between exposures is crucial for performing accurate spectroscopic analysis on your data. Wavelength offsets can occur for a variety of reasons, such as poor centering during target acquisition or thermal fluctuations in between exposures. In addition to inaccurate measurements and the misidentification of spectral features, incorrect wavelength registration can result in the wrong flux sensitivity being applied at each wavelength. For COS in particular, the wavelength throughput decreases for low-resolution spectra and rapidly at shorter wavelengths, thus being more affected by incorrect flux sensitivity applications. It is sometimes necessary for users to manually apply shifts to their raw data to ensure wavelength alignment between files. More information about the wavelength accuracies for the instruments can be found in Chapter 5 of the COS Instrument Handbook and Chapter 4 in the STIS Instrument Handbook.

This notebook will show users how to recognize if their data needs wavelength adjustments, and how to perform these corrections for both COS and STIS data. The example datasets that are used in this tutorial are abnormal – most cases of wavelength shifts are small. It assumes that the user knows how to download MAST data and how to run the coadd code. Check out our CoaddTutorial.ipynb notebook for a detailed explanation of how to do both of these things.

Please check out our Setup.ipynb notebook before running this tutorial to learn how to install and run the coadd code.

Imports#

We will be using multiple libraries to retrieve and analyze data. We will use:

  • os, shutil, Path.pathlib, and glob to work with our system’s directories and filepaths

  • matplotlib.pyplot to plot our data and shifts

  • numpy to perform analysis on our data

  • astroquery.mast to download our STIS and COS datasets for the exercises

  • astropy.io fits to read the corresponding FITS files

  • calcos and stistools to run the COS and STIS calibration pipelines, respectively

  • scipy.optimize to fit a Gaussian when determining the radial velocity

  • astropy.modeling and scipy.signal to help us fit a quadratic when calculating our shifts

We recommend creating a HASP-specific conda environment when coadding spectra. You can check out our Setup.ipynb notebook to create such an environment. Alternatively, you can also download the required dependencies to run this notebook with the terminal command:

pip install -r requirements.txt

This will download the dependencies that are necessary to run this current notebook. You will also need to install hstcal to run the STIS portion of this notebook. You can run the command below in your terminal after you’ve activated your conda environment:

conda install -y -c conda-forge hstcal==3.0.3

Or, similar to the requirements.txt file, you can run:

bash pre-requirements.sh

Let’s import all of the packages that we will use in this notebook and print our conda environment by running the next cell:

import os
import shutil
from pathlib import Path

import matplotlib.pyplot as plt
import numpy as np

from astroquery.mast import Observations
from astropy.io import fits

import calcos
import stistools

from astropy.modeling import fitting
from astropy.modeling.models import Polynomial1D

from scipy.signal import correlate
from scipy.signal import correlation_lags

from scipy import optimize
from IPython.display import clear_output

print("Currently active conda environment:", os.environ.get("CONDA_PREFIX"))
The following tasks in the stistools package can be run with TEAL:
   basic2d      calstis     ocrreject     wavecal        x1d          x2d
Currently active conda environment: /usr/share/miniconda/envs/hstcal
/opt/hostedtoolcache/Python/3.11.11/x64/lib/python3.11/site-packages/stsci/tools/nmpfit.py:8: UserWarning: NMPFIT is deprecated - stsci.tools v 3.5 is the last version to contain it.
  warnings.warn("NMPFIT is deprecated - stsci.tools v 3.5 is the last version to contain it.")
/opt/hostedtoolcache/Python/3.11.11/x64/lib/python3.11/site-packages/stsci/tools/gfit.py:18: UserWarning: GFIT is deprecated - stsci.tools v 3.4.12 is the last version to contain it.Use astropy.modeling instead.
  warnings.warn("GFIT is deprecated - stsci.tools v 3.4.12 is the last version to contain it."

Since we will be running both CalCOS and CalSTIS, we will need to set up environment variables for when we use the Calibration Reference Data System. Much of this is gone in detail in the COS notebook, Setup.ipynb notebook. We will download the STIS reference files in a later cell since we’ll need the data downloaded.

# We will set the CRDS_PATH environment_variable
# Creating path to where the files are saved
crds_path = os.path.join(os.environ["HOME"], "crds_cache")

# Setting the environment variable CRDS_PATH to our CRDS path
os.environ["CRDS_PATH"] = crds_path

# URL for the STScI CRDS page
crds_server_url = "https://hst-crds.stsci.edu"

# Setting env variable to URL
os.environ["CRDS_SERVER_URL"] = crds_server_url

# Set the lref environment variable (COS)
lref = os.path.join(crds_path, "references/hst/cos")
os.environ["lref"] = lref

!crds sync --contexts hst_cos_0359.imap --fetch-references
clear_output()

We will create a function to consolidate and organize our data since we will be utilizing it for two datasets in the tutorial. The coadd script requires all X1D and SX1 files to be in a single directory to be coadded. When downloading data from MAST, it creates multiple directories: ./mastDownload/HST and within this directory are sub-directories for each observation set. We will move all of the files in these sub-directories to the respective STIS/COS directory.

def consolidate_files(data_path):
    '''
    Consolidate all files to single directory; necessary for HASP script run.
    ---------------
    Input:
    Path data_path: Path object to the directory where the files should be moved.
    ---------------
    Output:
    None. Files moved to data_path. ./mastDownload/HST directory is deleted.
    '''
    # The path to all obs_id folders
    mast_path = data_path / Path("mastDownload/HST/")

    try:
        for obs_id_path in mast_path.iterdir():
            for file in obs_id_path.glob("*fits"):
                shutil.move(str(file), data_path / file.name)

        shutil.rmtree(mast_path.parent)

    except Exception as e:
        print(f"An error occurred: {e}")

1. Performing Wavelength Adjustments on COS Data#

During science exposures, the wavelength calibration aperture is illuminated by two Pt-Ne lamps, which are used as a template by CalCOS to assign wavelengths to positions on the COS detector. A zero-point shift is then applied to the science data to align the wavelength calibration exposure and the science exposure. These wavelength calibration exposures are taken simultaneously with science exposures (except LP6 exposures; more information about LP6 wavecals in Chapter 5.7.6 of the COS Instrument Handbook). Information about COS wavelength accuracies can be found in Chapter 5.1.11 of the COS Instrument Handbook.

We will create a few different directories for our COS example.

# To hold all of our COS example's output and data
cos_ex = Path("./cos_ex/")

# Contains the RAWTAG and ASN files
cos_data = Path("./cos_ex/cos_data/")

# Holds the unshifted X1Ds and the respective coadd
cos_unshifted = Path("./cos_ex/cos_unshifted/")
cos_unshifted_coadd = Path("./cos_ex/cos_unshifted/coadd/")

# Will contain the X1Ds created with the shift applied, and respective coadd
cos_shifted = Path("./cos_ex/cos_shifted/")
cos_shifted_coadd = Path("./cos_ex/cos_shifted/coadd/")

# If the directory doesn't exist, then create it
cos_ex.mkdir(exist_ok=True)

cos_data.mkdir(exist_ok=True)

cos_unshifted.mkdir(exist_ok=True)
cos_unshifted_coadd.mkdir(exist_ok=True)

cos_shifted.mkdir(exist_ok=True)
cos_shifted_coadd.mkdir(exist_ok=True)

We will be shifting COS FUV spectra of the target LMC079-1, a Wolf-Rayet star observed in the first visit of Program 15824. We will download the dataset from the first visit of this program, LE2701010, which observes the target at LP4 using the grating and central wavelength G160M/1577.

1.1 Downloading and Organizing COS Data using Astroquery#

We will start by downloading our dataset using astroquery.mast Observations module; we will go through this very briefly, so if you are unfamiliar with downloading MAST data using astroquery, please check out our CoaddTutorial.ipynb notebook.

To run the coadd script, we will need to download the X1D files. To perform our wavelength adjustments, we will need to download the RAWTAG and ASN files since we will be calculating the pixel offset between the X1D files and re-running the COS calibration pipeline (CalCOS). Let’s do so in the cell below:

# Querying MAST for our dataset
cos_query = Observations.query_criteria(
    obs_id="LE2701010"
)

# Getting a list of products for this dataset
cos_products = Observations.get_product_list(
    cos_query
)

# A list of files that we need to run the coadd script and CalCOS
necessary_filetypes = ["X1D", "RAWTAG_A", "RAWTAG_B", "ASN"]

# Downloading the products
Observations.download_products(
    cos_products,
    download_dir=str(cos_data),
    productSubGroupDescription=necessary_filetypes
)

# Moving all files to single directory and deleting mastDownload
consolidate_files(cos_data)

# Now moving all of the original X1Ds to cos_unshifted
for file in cos_data.glob("*x1d*"):
    shutil.move(str(file), cos_unshifted / file.name)
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701010_asn.fits to cos_ex/cos_data/mastDownload/HST/le2701010/le2701010_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q0q_rawtag_a.fits to cos_ex/cos_data/mastDownload/HST/le2701q0q/le2701q0q_rawtag_a.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q0q_rawtag_b.fits to cos_ex/cos_data/mastDownload/HST/le2701q0q/le2701q0q_rawtag_b.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q0q_x1d.fits to cos_ex/cos_data/mastDownload/HST/le2701q0q/le2701q0q_x1d.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q2q_rawtag_a.fits to cos_ex/cos_data/mastDownload/HST/le2701q2q/le2701q2q_rawtag_a.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q2q_rawtag_b.fits to cos_ex/cos_data/mastDownload/HST/le2701q2q/le2701q2q_rawtag_b.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q2q_x1d.fits to cos_ex/cos_data/mastDownload/HST/le2701q2q/le2701q2q_x1d.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q4q_rawtag_a.fits to cos_ex/cos_data/mastDownload/HST/le2701q4q/le2701q4q_rawtag_a.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q4q_rawtag_b.fits to cos_ex/cos_data/mastDownload/HST/le2701q4q/le2701q4q_rawtag_b.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q4q_x1d.fits to cos_ex/cos_data/mastDownload/HST/le2701q4q/le2701q4q_x1d.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q6q_rawtag_a.fits to cos_ex/cos_data/mastDownload/HST/le2701q6q/le2701q6q_rawtag_a.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q6q_rawtag_b.fits to cos_ex/cos_data/mastDownload/HST/le2701q6q/le2701q6q_rawtag_b.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/le2701q6q_x1d.fits to cos_ex/cos_data/mastDownload/HST/le2701q6q/le2701q6q_x1d.fits ...
 [Done]

1.2 Running the HASP Script on COS Data#

Now that we’ve downloaded our data, we can run our coadd code. We can run the HASP coadd script, saving our coadded data products to the ./cos_ex/cos_unshifted/coadd/ directory:

Note: Again, this notebook will not go into specifics about running the script and analyzing the output files. Please check out our CoaddTutorial.ipynb to learn more about running the script.

!swrapper -i ./cos_ex/cos_unshifted -o ./cos_ex/cos_unshifted/coadd
HASP version 1.0
Ullyses version 4.1.0
Creating list of unique modes from these files:
./cos_ex/cos_unshifted/le2701q0q_x1d.fits LMC079-1 COS FUV G160M PSA 15824 (15824, '01')
./cos_ex/cos_unshifted/le2701q2q_x1d.fits LMC079-1 COS FUV G160M PSA 15824 (15824, '01')
./cos_ex/cos_unshifted/le2701q4q_x1d.fits LMC079-1 COS FUV G160M PSA 15824 (15824, '01')
./cos_ex/cos_unshifted/le2701q6q_x1d.fits LMC079-1 COS FUV G160M PSA 15824 (15824, '01')
Looping over visits
Processing product (15824, '01')
Targets in visit (15824, '01'): ['LMC079-1']
Processing target LMC079-1 in visit (15824, '01')
Processing grating COS/G160M
Importing files ['./cos_ex/cos_unshifted/le2701q0q_x1d.fits', './cos_ex/cos_unshifted/le2701q2q_x1d.fits', './cos_ex/cos_unshifted/le2701q4q_x1d.fits', './cos_ex/cos_unshifted/le2701q6q_x1d.fits']
Processing file ./cos_ex/cos_unshifted/le2701q0q_x1d.fits
Processing file ./cos_ex/cos_unshifted/le2701q2q_x1d.fits
Processing file ./cos_ex/cos_unshifted/le2701q4q_x1d.fits
Processing file ./cos_ex/cos_unshifted/le2701q6q_x1d.fits
/opt/hostedtoolcache/Python/3.11.11/x64/lib/python3.11/site-packages/ullyses/coadd.py:563: RuntimeWarning: invalid value encountered in divide
  thru_nans = segment.data['net'] / segment.data['flux']
Using a maximum SNR of 20.0 in flux-based filtering
WARNING: VerifyWarning: Card is too long, comment will be truncated. [astropy.io.fits.card]
   Wrote ./cos_ex/cos_unshifted/coadd/hst_15824_cos_lmc079-1_g160m_le2701_cspec.fits
No need to create abutted product as < 2 single grating products
Looping over proposals
Processing product 15824
Targets in proposal 15824: ['LMC079-1']
Processing target LMC079-1 in proposal 15824
Processing grating COS/G160M
Importing files ['./cos_ex/cos_unshifted/le2701q0q_x1d.fits', './cos_ex/cos_unshifted/le2701q2q_x1d.fits', './cos_ex/cos_unshifted/le2701q4q_x1d.fits', './cos_ex/cos_unshifted/le2701q6q_x1d.fits']
Processing file ./cos_ex/cos_unshifted/le2701q0q_x1d.fits
Processing file ./cos_ex/cos_unshifted/le2701q2q_x1d.fits
Processing file ./cos_ex/cos_unshifted/le2701q4q_x1d.fits
Processing file ./cos_ex/cos_unshifted/le2701q6q_x1d.fits
/opt/hostedtoolcache/Python/3.11.11/x64/lib/python3.11/site-packages/ullyses/coadd.py:563: RuntimeWarning: invalid value encountered in divide
  thru_nans = segment.data['net'] / segment.data['flux']
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./cos_ex/cos_unshifted/coadd/hst_15824_cos_lmc079-1_g160m_le27_cspec.fits
Making a product from these gratings
COS/G160M 1342-1800 (Actual: 1383.5-1754.0)
Transition wavelengths tweaked
Starting at the short wavelength end with grating COS/G160M
Truncating current grating at 1753.9885046073168
./cos_ex/cos_unshifted/coadd/hst_15824_cos_lmc079-1_g160m_le27_cspec.fits already exists and overwrite=False, skipping write
   Wrote ./cos_ex/cos_unshifted/coadd/hst_15824_cos_lmc079-1_g160m_le27_cspec.fits

We have created two different coadded files by running our script. The file hst_15824_cos_lmc079-1_g160m_le27_cspec.fits is our fully coadded spectrum for this program. The other file, hst_15824_cos_lmc079-1_g160m_le2701_cspec.fits is the visit-level coadd; if we were to include other visits’ X1D files then there would be a similar file created for each visit. Each X1D was taken at a different grating offset (FPPOS), more information about FPPOS is in Section 5.8.2 of the COS Instrument Handbook. Let’s plot the coadd in the cell below with the X1D files:

# Coadd filename
coadd_cos = "hst_15824_cos_lmc079-1_g160m_le27_cspec.fits"

# List of X1D files
x1ds = cos_unshifted.glob("*x1d*")

plt.figure(figsize=(15, 6))

colors = ["blue", "red", "cyan", "orange"]

# Plotting each X1D file
for i, file in enumerate(sorted(x1ds)):
    with fits.open(file) as hdul:

        wl = hdul[1].data["WAVELENGTH"].ravel()
        flux = hdul[1].data["FLUX"].ravel()

        plt.plot(wl, flux,
                 lw=2,
                 label=f'FPPOS {hdul[0].header["FPPOS"]}',
                 color=colors[i],
                 alpha=0.6)

# Plotting the coadd
with fits.open(cos_unshifted_coadd / coadd_cos) as hdul:

    wl_coadd = hdul[1].data["WAVELENGTH"].ravel()
    flux_coadd = hdul[1].data["FLUX"].ravel()

    plt.plot(wl_coadd, flux_coadd,
             lw=2,
             label="Coadd",
             color="black",
             alpha=0.6)

# Formatting and titles
plt.title("Coadd and X1D files - LMC079-1 G160M")
plt.xlabel(r'Wavelength [$\AA$]')
plt.ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

plt.ylim(0, 1.5e-13)

plt.legend()

plt.show()
../../../_images/49cef9ef5b89bd5a67b3c7711300480b266a69b85e30bf1b260fadcda2f7a7f7.png

1.3 Identifying a Wavelength Shift in COS Data#

It is up to the user to determine if their data needs to be shifted, and there are multiple different ways to determine if you need to calculate and apply shifts. It can sometimes be visually apparent that there is a wavelength offset when looking at spectral features as you’ll see misalignment, but a more absolute method of determining if your data needs to be shifted is if you compare the coadd’s radial velocity to the literature value. In our COS example, we will compare the coadd’s radial velocity to the ULLYSES High-Level Science Product’s (HLSP) radial velocity. We will do a rough, quick calculation to demonstrate that there’s an actual shift between the datasets; there are more accurate methods of determining the radial velocity but it is outside the scope of this notebook. The ULLYSES team has created tutorial notebooks that detail how to download this data via astroquery. We will download the HLSP for our target, specifically the file hlsp_ullyses_hst_cos_lmc079-1_g160m_dr7_cspec.fits, which is the HLSP for the G160M grating.

ullyses_query = Observations.query_criteria(
    target_name="LMC079-1",
    provenance_name="ULLYSES",
)

ullyses_prodlist = Observations.get_product_list(
    ullyses_query
)

ullyses_prodlist = Observations.filter_products(
    ullyses_prodlist,
    productFilename="hlsp_ullyses_hst_cos_lmc079-1_g160m_dr7_cspec.fits"
)

Observations.download_products(
    ullyses_prodlist,
    download_dir=str(cos_ex)
)

download_dir = cos_ex / "mastDownload"
hlsp_dir = download_dir / "HLSP/hlsp_ullyses_hst_cos_lmc079-1_uv"
target_filename = "hlsp_ullyses_hst_cos_lmc079-1_g160m_dr7_cspec.fits"

source_path = hlsp_dir / target_filename
hlsp_path = cos_ex / target_filename

shutil.move(str(source_path), str(hlsp_path))

shutil.rmtree(cos_ex / "mastDownload")
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HLSP/ullyses/lmc079-1/dr7/hlsp_ullyses_hst_cos_lmc079-1_g160m_dr7_cspec.fits to cos_ex/mastDownload/HLSP/hlsp_ullyses_hst_cos_lmc079-1_uv/hlsp_ullyses_hst_cos_lmc079-1_g160m_dr7_cspec.fits ...
 [Done]

Now we can plot our coadd with the ULLYSES HLSP. We will zoom in on two different spectral features: SiII at 1526 Å and FeII at 1608 Å.

plt.figure(figsize=(15, 6))

wavelength_range = ([1607, 1611], [1525, 1530])

# Plotting the coadd
plt.plot(wl_coadd, flux_coadd,
         lw=2,
         label="Coadd",
         color="black",
         alpha=0.6)

# Plotting the ULLYSES HLSP
with fits.open(hlsp_path) as hdul:

    wl_hlsp = hdul[1].data["WAVELENGTH"].ravel()
    flux_hlsp = hdul[1].data["FLUX"].ravel()

plt.plot(wl_hlsp, flux_hlsp,
         lw=2,
         label="ULLYSES HLSP",
         color="blue",
         alpha=0.6)

plt.title("Coadd and ULLYSES HLSP - LMC079-1 G160M")
plt.xlabel(r'Wavelength [$\AA$]')
plt.ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

plt.legend()

plt.show()

# Zooming in on two spectral features
fig, ax = plt.subplots(1, 2, figsize=(15, 6))

for subplot in ax.ravel():

    # Plotting the coadd
    subplot.plot(wl_coadd, flux_coadd,
                 lw=2,
                 color="black",
                 alpha=0.6)

    # Plotting the HLSP
    subplot.plot(wl_hlsp, flux_hlsp,
                 lw=2,
                 color="blue",
                 alpha=0.6)

    subplot.set_xlabel(r'Wavelength [$\AA$]')
    subplot.set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

ax[0].set_xlim(wavelength_range[0])
ax[0].set_title(f"FUVA - ZOOMED {wavelength_range[0]} Å",
                fontweight="bold")

ax[1].set_xlim(wavelength_range[1])
ax[1].set_title(f"FUVB - ZOOMED {wavelength_range[1]} Å",
                fontweight="bold")

plt.show()
../../../_images/cfaae8c29d85abc2d252b598cc6f8be8b98dfdd781b051e36f157029b09f014b.png ../../../_images/ee6b27429502c1099dcb9871337316f92343d506fe6752592271cc5219e57cb2.png

We can see visually that there is a slight wavelength shift between the two data products. We will do a very rough estimate of the radial velocity using the SiII line at 1526.71 Å.

We will first fit a Gaussian to our spectral feature to determine the model fit parameters of the absorption feature. Let’s define the function below:

def fit_gaussian(wavelength, amplitude, mean, stddev):
    '''
    Fit a Gaussian to the data.
    Gaussian is defined as:
    f(x) = c + amplitude * np.exp(-(((wavelength - mean) / stddev)**2)/2)
    ----------
    Input:
    arr wavelength : Data of the independent variable (wl in our context)
    float amplitude : Amplitude of Gaussian. Represents the peak of the data
    float mean : Mean wl of Gaussian. Represents central wavelength of feature
    float stddev : Standard deviation of Gaussian. Represents function's width
    ----------
    Output:
    The value of flux at each wavelength using the fit.
    '''
    # An estimate of the continuum flux value
    c = 6.5e-14
    return c + amplitude * np.exp(-(((wavelength - mean) / stddev)**2)/2)

We will use scipy.optimize to help fit our model to the absorption feature by optimizing the parameters of the fit_gaussian function. We’ll calculate the radial velocity of the HLSP first. This will allow us to determine the exact wavelength corresponding to the peak of the fitted Gaussian, which we’ll use to calculate the radial velocity of the HLSP.

# Getting the indicies within the wavelength range
indicies = np.where((wl_hlsp >= 1525.1) & (wl_hlsp <= 1526.8))

trimmed_flux = flux_hlsp[indicies]
trimmed_wl = wl_hlsp[indicies]

# We need to make an initial guess for the parameter values
# The array is in form [PEAK OF GAUSSIAN, CENTRAL WAVELENGTH, WIDTH OF LINE]
p0 = [.8e-14, 1526.7, 0.0053]

popt_hlsp, _ = optimize.curve_fit(fit_gaussian,
                                  trimmed_wl,
                                  trimmed_flux,
                                  p0)

print(f"The SiII peak is fitted to be {np.round(popt_hlsp[1], 3)} Å")

# Plotting the absorption feature of the HLSP with our fit
plt.figure(figsize=(8, 6))

# Plotting the actual data
plt.plot(
    wl_hlsp,
    flux_hlsp,
    label="HLSP Data"
)

# Plotting our fit
plt.plot(
    wl_hlsp,
    fit_gaussian(wl_hlsp, *popt_hlsp),
    label="Model Fit",
    color="red",
    alpha=0.6
)

# Adding vertical lines to show fitted "peak"
plt.axvline(popt_hlsp[1],
            label='Model\'s Peak',
            color="black",
            linestyle="dotted")

plt.xlim(wavelength_range[1])
plt.legend()

plt.xlabel(r'Wavelength [$\AA$]')
plt.ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')
plt.title("HLSP of LMC079-1 with Modeled Fit",
          fontweight="bold")

plt.show()
The SiII peak is fitted to be 1526.619 Å
../../../_images/4329e2bda1ac8db226245cbb70bea7ba8b2828aab2ba9da821aff696d09c73c9.png

Now that we’ve determined the observed wavelength of the SiII line, we can calculate the radial velocity. The rest wavelength of this line is 1526.71 Å. We will use the equation below to calculate the radial velocity:

\( v_r = c \left( \frac{\lambda - \lambda_0}{\lambda_0} \right) \)

Where:

  • \( v_r \) is the radial velocity,

  • \( c \) is the speed of light (\( \approx 2.99 * 10^5 \) km/s),

  • \( \lambda \) is the observed wavelength of the spectral line,

  • \( \lambda_0 \) is the rest wavelength of the spectral line.

Let’s calculate it for the HLSP below:

# Speed of light (in km/s)
c = 2.99e5

# Getting the observed wavelength of our HLSP
observed_wavelength = popt_hlsp[1]

# Rest wavelength of SiII
rest_wavelength = 1526.71

v_r = c * ((observed_wavelength - rest_wavelength) / rest_wavelength)
v_r = np.round(v_r, 2)

print(f"The radial velocity of LMC079-1 using the HLSP is roughly {v_r} km/s")
The radial velocity of LMC079-1 using the HLSP is roughly -17.78 km/s

Now let’s calculate the radial velocity of our coadd using the same process.

# Getting the indicies within the wavelength range
indicies = np.where((wl_coadd >= 1525.) & (wl_coadd <= 1526.8))

trimmed_flux = flux_coadd[indicies]
trimmed_wl = wl_coadd[indicies]

# We need to make an initial guess for the parameter values
# The array is in form [PEAK OF GAUSSIAN, CENTRAL WAVELENGTH, WIDTH OF LINE]
p0 = [.75e-14, 1526.7, 0.0055]

popt, _ = optimize.curve_fit(fit_gaussian,
                             trimmed_wl,
                             trimmed_flux,
                             p0)

print(f"The SiII peak is fitted to be {np.round(popt[1], 3)} Å")

# Plotting the absorption feature of the HLSP with our fit
plt.figure(figsize=(8, 6))

# Plotting the actual data
plt.plot(
    wl_coadd,
    flux_coadd,
    label="Coadd Data"
)

# Plotting our fit
plt.plot(
    wl_coadd,
    fit_gaussian(wl_coadd, *popt),
    label="Model Fit",
    color="red",
    alpha=0.6
)

# Adding vertical lines to show fitted "peak"
plt.axvline(popt[1],
            label='Coadd Model\'s Peak',
            color="black",
            linestyle="dotted")

# Adding vertical line to show observed wl of HLSP
plt.axvline(popt_hlsp[1],
            label='HLSP Model\'s Peak',
            color="red",
            linestyle="dashed")

plt.xlim(wavelength_range[1])
plt.legend()

plt.xlabel(r'Wavelength [$\AA$]')
plt.ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

plt.title("Coadd of LMC079-1 with Modeled Fit",
          fontweight="bold")

plt.show()

# Getting the observed wavelength of our HLSP
observed_wavelength = popt[1]

v_r = c * ((observed_wavelength - rest_wavelength) / rest_wavelength)
v_r = np.round(v_r, 2)

print(f"The radial velocity of LMC079-1 using the coadd is roughly {v_r} km/s")
The SiII peak is fitted to be 1526.692 Å
../../../_images/375b5d035999fafe9a8a1170c39fbf3e451ff1ed0c969bbe09206e246ec894b1.png
The radial velocity of LMC079-1 using the coadd is roughly -3.5 km/s

We can see that there is a very significant difference between the target’s calculated radial velocity using the HLSP (roughly -17.78 km/s) and the coadd (roughly -3.5 km/s). This is an indicator that there is a wavelength offset between the coadd’s constituent X1D files. We will need to determine this wavelength offset between the X1D files, apply this shift when running CalCOS, and redo the coadd.

1.4 Performing Cross-Correlation on X1D COS Data to Calculate Lag#

We will determine the shift of our spectrum by cross-correlating one of the X1D files to the other files, determining the lag with the greatest cross-correlation coefficient, and then inputting this lag into CalCOS to re-generate the X1D files. We will need to calculate the shift, in pixels, for both the FUVA and FUVB segments of each X1D. Users will want to cross-correlate along a wavelength range that captures absorption features unique to the target and is free of instrumental effects. Additionally, cross-correlating across a unique feature of the spectrum rather than the entire spectrum greatly improves the cross-correlation accuracy.

We will cross-correlate along the ranges 1525 - 1530 Å for Segment FUVB and 1607 - 1611 Å for Segment FUVA, which capture SiII and FeII absorption features of this spectrum, respectively. Let’s take a closer look at these spectra:

fig, ax = plt.subplots(3, 1, figsize=(14, 15))

x1ds = cos_unshifted.glob("*x1d*")

for i, file in enumerate(sorted(x1ds)):

    # Getting the flux and wavelength for our dataset
    data = fits.open(file)[1].data
    wavelength = data["WAVELENGTH"].ravel()
    flux = data["FLUX"].ravel()

    fppos = fits.open(file)[0].header["FPPOS"]

    # ax[0] is plot with total spectrum, ax[1] is FUVB, ax[2] is FUVA
    for subplot in ax:
        # Plotting the spectrum
        subplot.plot(wavelength, flux,
                     lw=2,
                     alpha=0.6,
                     color=colors[i],
                     label=f"FP-POS {fppos}")

        subplot.set_xlabel(r'Wavelength [$\AA$]')
        subplot.set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

        subplot.set_ylim(0, 1.5e-13)

        subplot.legend()

# Adding formatting to the subplots
ax[0].set_title("Flux vs Wavelength, LMC079-1, both segments",
                fontweight="bold")
ax[1].set_title(f'Flux vs Wavelength, {wavelength_range[1]} Å, Seg FUVB',
                fontweight="bold")
ax[2].set_title(f'Flux vs Wavelength, {wavelength_range[0]} Å, Seg FUVA',
                fontweight="bold")

ax[1].set_xlim(wavelength_range[1])
ax[2].set_xlim(wavelength_range[0])

ax[0].legend()

fig.tight_layout()

plt.show()
../../../_images/c747054e10e8a6573664fdfaf7426ae520101b56176605d20baea6103ac6150c.png

We can see an apparent shift between the X1D files, especially between the FPPOS 1+2 and FPPOS 3+4 exposures.

We will now determine which X1D file will be the reference file. Users have different methods for determining the reference file best suited for your dataset. For this example, we will choose the reference file to be the X1D with a model peak closest to the HLSP’s peak of the SiII absorption feature.

We’ll define a function to help us fit the peaks:

def fit_model(i, p0, ax, wavelength_range, file):
    '''
    Fit the Gaussian to the feature, return the "peak" wavelength
    ----------
    arr i : The wavelength range to trim flux/wl to
    arr p0 : The initial guess for the Gaussian fit
    plt.subplot ax : A specific subplot, used for plotting each X1D
    arr wavelength_range : Wavelength range for the plot
    str file : Path to the X1D file
    '''
    with fits.open(file) as hdul:
        wl = hdul[1].data["WAVELENGTH"].ravel()
        flux = hdul[1].data["FLUX"].ravel()

    # Getting the indicies within the wavelength range
    indicies = np.where((wl >= i[0]) & (wl <= i[1]))

    trimmed_flux = flux[indicies]
    trimmed_wl = wl[indicies]

    popt, _ = optimize.curve_fit(fit_gaussian,
                                 trimmed_wl,
                                 trimmed_flux,
                                 p0)

    # Plotting the X1D's data
    ax.plot(
        wl,
        flux
    )

    # Plotting the fit
    ax.plot(
        wl,
        fit_gaussian(wl, *popt),
        label="Modeled Fit",
        color="purple"
    )

    # Adding vertical line to show peak wl of HLSP
    ax.axvline(popt_hlsp[1],
               label='HLSP Model\'s Peak',
               color="red",
               linestyle="dashed")

    # Adding vertical line to show peak wl of X1D
    ax.axvline(popt[1],
               label='X1D Model\'s Peak',
               color="black",
               linestyle="dotted")

    ax.set_xlim(wavelength_range)
    ax.set_ylim(0, 1.5e-13)

    ax.legend()

    fppos = fits.getval(file, "FPPOS")
    ax.set_title(f'Flux vs Wavelength with Fit, FPPOS {fppos}',
                 fontweight="bold")

    ax.set_xlabel(r'Wavelength [$\AA$]')
    ax.set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

    peak_diff = np.round(popt[1] - popt_hlsp[1], 3)

    ax.text(wavelength_range[1] - 1.35,
            1.2e-13,
            f'Difference in peak wavelength = {peak_diff} Å',
            ha='center', va='center')

    return peak_diff

Now we will determine the file to be used as a reference, which will be the file that has the smallest difference in peak wavelength for the SiII feature compared to the HLSP peak.

fig, axes = plt.subplots(2, 2, figsize=(16, 16))

x1ds = list(cos_unshifted.glob("*x1d*"))

# A placeholder reference file
ref_file = x1ds[0]

# A placeholder value for the smallest peak
smallest_peak = 10000

for file, ax in zip(sorted(x1ds), axes.ravel()):
    fppos = fits.getval(file, "FPPOS")
    i = [1525., 1525.8]

    if fppos == 1:
        p0 = [-6e-14, 1526.75, 0.13]

    elif fppos == 2:
        p0 = [-6e-14, 1526.75, 0.125]

    elif fppos == 3:
        p0 = [-5.75e-14, 1526.65, 0.125]

    elif fppos == 4:
        p0 = [-5.8e-14, 1526.62, 0.13]

    curr_peak = fit_model(i, p0, ax, wavelength_range[1], file)

    # Is the current iteration's file closer to the HLSP?
    if np.abs(curr_peak) < smallest_peak:
        smallest_peak = np.abs(curr_peak)
        ref_file = file

plt.show()

fppos = fits.getval(ref_file, "FPPOS")
print(f'The file to be used as reference was taken at FPPOS {fppos}')
/tmp/ipykernel_2061/1408116224.py:21: OptimizeWarning: Covariance of the parameters could not be estimated
  popt, _ = optimize.curve_fit(fit_gaussian,
../../../_images/6ebcb7b560457522cc8275ee4c1c6c7b00c6170cadfc8323438efbbab660b6f2.png
The file to be used as reference was taken at FPPOS 4

As we can see, the file that is closest to the HLSP is the observation taken at FPPOS 4.

We will now define a function to determine the lag and cross-correlation coefficient between our reference and shifted spectra. We will use the correlation_lags function from scipy.signal to compute the cross-correlation coefficient for each lag. The lag is the displacement (in pixels) between the reference and current spectra. The cross-correlation coefficient is in the range [-1, 1], a value of 1 being perfectly correlated, 0 being no correlation, and -1 being inversely correlated. The shift that we will input to CalCOS is going to be the lag at the maximum cross-correlation coefficient value. We will define the function to calculate the lag and cross-correlation coefficient in the cell below (this function is from the STIS Cross Correlation Notebook).

# From the STIS cross correlation notebook
def cross_correlate(ref_flux, shifted_flux):
    assert len(shifted_flux) == len(ref_flux), "Arrays must be same size"

    # Normalize inputs:
    shifted_flux = shifted_flux - shifted_flux.mean()
    shifted_flux /= shifted_flux.std()
    ref_flux = ref_flux - ref_flux.mean()
    ref_flux /= ref_flux.std()

    # centered at the median of len(a)
    lag = correlation_lags(len(shifted_flux), len(ref_flux), mode="same")
    # find the cross-correlation coefficient
    cc = correlate(shifted_flux, ref_flux, mode="same") / float(len(ref_flux))

    return lag, cc

Now we will define a function to calculate the shift between our reference file (FPPOS 4) and the FPPOS 1+2+3 exposures. We will plot the correlation coefficient vs lag as well. We will have to get shift values for each segment; for FUVA we will correlate to the wavelength range [1607, 1611], and for FUVB we will correlate to the wavelength range [1525, 1530]. Since our cross_correlate function returns only discrete value shifts, we will need to fit a curve to the correlation lag plot; the shift we will apply with CalCOS is at the maxima of this curve.

Note: You will need to experiment with different fits for your dataset.

def find_shift_normalized(ref_file, file, wl_range, segment, width, plot):
    '''
    Determine shift amount in pixels between the reference file and the file.
    Can also plot wavelength range and the correlation coeff. vs lag as well.
    ----------
    Input:
    Pathlib path ref_file : Path to reference file's spectrum to shift to.
    Pathlib path file : Path to file of spectrum to apply shifts to
    arr wl_range : Wavelength range to correlate to. Form: [START_WL, END_WL]
    str segment : The segment that is being correlated. Either 'FUVA' or 'FUVB'
    int width : Width of fit, needs to be greater than 2
    bool plot : Do you want to show plots?
    ----------
    Output:
    float shift : Calculated lag [px] between ref and current spectrum
    '''
    # Grabbing the reference spectrum's data
    with fits.open(ref_file) as hdul:
        seg_i = np.where(hdul[1].data["SEGMENT"] == segment)

        ref_wl = hdul[1].data["WAVELENGTH"][seg_i]
        ref_flux = hdul[1].data["FLUX"][seg_i]

    # Getting the flux data for the current FPPOS file
    with fits.open(file) as hdul:
        seg_i = np.where(hdul[1].data["SEGMENT"] == segment)
        flux = hdul[1].data["FLUX"][seg_i]

    range_i = np.where((ref_wl >= wl_range[0]) & (ref_wl <= wl_range[1]))

    # Trimming the flux and wavelength ranges to match the user inputted range
    flux = flux[range_i]
    ref_flux = ref_flux[range_i]

    wavelength = ref_wl[range_i]

    # Calculating lag and correlation coeff. using STIS notebook's function
    lag, cc = cross_correlate(ref_flux, flux)

    # Fitting a quadratic to the peak to find pixel shift
    fitter = fitting.LinearLSQFitter()

    # Getting the points near the peak
    low, hi = np.argmax(cc) - width//2, np.argmax(cc) + width//2 + 1
    fit = fitter(Polynomial1D(degree=2), x=lag[low:hi], y=cc[low:hi])

    x_c = np.arange(np.min(lag), np.max(lag), 0.01)

    # Determining the shift, in pixels
    shift1 = -fit.parameters[1] / (2. * fit.parameters[2])

    if segment == "FUVA":
        shift = shift1 + fits.getval(file, "SHIFT1A", ext=1)

    else:
        shift = shift1 + fits.getval(file, "SHIFT1B", ext=1)

    # If not plotting, then just return the shift
    if plot is False:
        return shift

    fppos = fits.getval(file, 'FPPOS')

    print(f"Shift for {segment} between ref and FPPOS {fppos} is {shift1} px")

    # Setting up the subplots
    fig, ax = plt.subplots(2, 1, figsize=(16, 8))

    ax[0].plot(
        wavelength,
        ref_flux,
        lw=2,
        label="Reference File"
    )

    ax[0].plot(
        wavelength,
        flux,
        lw=2,
        label=f'FPPOS {fits.getval(file, "FPPOS")}'
    )

    ax[1].plot(
        lag,
        cc,
        lw=2,
        color="black"
    )

    ax[1].plot(
        x_c,
        fit(x_c),
        lw=2,
        color="red",
        label="Fitted quadratic",
        alpha=0.6
    )

    ax[1].axvline(
        shift1,
        linestyle="dashed",
        label="Maxima",
    )

    ax[1].legend()
    ax[1].set_ylim(-0.3, 0.8)
    ax[1].set_xlim(shift1-100, shift1+100)

    # Adjusting formatting + adding titles
    ax[0].set_xlabel("Wavelength")
    ax[0].set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')
    ax[0].set_title(f'Flux vs Wavelength, FPPOS {fppos} & Ref, {segment}',
                    weight="bold")

    ax[1].set_xlabel("Lags (px)")
    ax[1].set_ylabel("Correlation Coeff.")
    ax[1].set_title(f'CC vs Lags (px), FPPOS {fppos} & Ref, {segment}',
                    weight="bold")

    ax[0].legend()

    plt.tight_layout()
    plt.show()

    return

Let’s calculate the shift of both segments for the FPPOS 1 exposure:

fppos1 = cos_unshifted / "le2701q0q_x1d.fits"

widths1 = [25, 25]

find_shift_normalized(ref_file,
                      fppos1,
                      wavelength_range[0],
                      "FUVA",
                      width=widths1[0],
                      plot=True)

find_shift_normalized(ref_file,
                      fppos1,
                      wavelength_range[1],
                      "FUVB",
                      width=widths1[1],
                      plot=True)
Shift for FUVA between ref and FPPOS 1 is 14.127291788136656 px
../../../_images/5708f7ba1371e5555e2f0ea9226eadd68f20271217d5d0b14d400d7f0fbb7669.png
Shift for FUVB between ref and FPPOS 1 is 10.149594904818544 px
../../../_images/7f2204066a8ddf25c9ac1129a8c7f6db3ffdd5be656529f1b591917ec6980ad0.png

Now we can do the same for our FPPOS 2 exposure:

fppos2 = cos_unshifted / "le2701q2q_x1d.fits"

widths2 = [25, 35]

find_shift_normalized(ref_file,
                      fppos2,
                      wavelength_range[0],
                      "FUVA",
                      width=widths2[0],
                      plot=True)

find_shift_normalized(ref_file,
                      fppos2,
                      wavelength_range[1],
                      "FUVB",
                      width=widths2[1],
                      plot=True)
Shift for FUVA between ref and FPPOS 2 is 14.655856093413052 px
../../../_images/bebde3c4e5b5e015d314d667d6a553b06db73509456d5db47d78e31f0f2d71be.png
Shift for FUVB between ref and FPPOS 2 is 9.414641664769572 px
../../../_images/71c7d5a0227c826768f074d593e9656e38c7c0da3fb7efa1053a026c184fba39.png

And finally, let’s calculate the shift for our FPPOS 3 exposure:

fppos3 = cos_unshifted / "le2701q4q_x1d.fits"

widths3 = [25, 30]

find_shift_normalized(ref_file,
                      fppos3,
                      wavelength_range[0],
                      "FUVA",
                      width=widths3[0],
                      plot=True)

find_shift_normalized(ref_file,
                      fppos3,
                      wavelength_range[1],
                      "FUVB",
                      width=widths3[1],
                      plot=True)
Shift for FUVA between ref and FPPOS 3 is -1.2887920062544729 px
../../../_images/27f2896f4761c4c23033420cb74bc9319fce1bc260ea9b6cca649ed6d97474a7.png
Shift for FUVB between ref and FPPOS 3 is 0.08679990676566517 px
../../../_images/af6a34eda1b6c2502033f5745509774b321f013b37f66de88a1e6c42b3121d31.png

1.5 Applying Shifts to COS data and Re-creating Coadd#

Now that we’ve determined the shift in pixels, we will re-calibrate our data using CalCOS. There are two ways that we can apply our shifts: we can either modify the corrtag files, or we can put them in a .txt file and feed that into CalCOS. We will do the latter option in this tutorial. The shift value that we will write in the .txt file is the sum of the shift we calculated using the above function and the value of the SHIFT1A header keyword of the X1D file (SHIFT1A for FUVA, SHIFT1B for FUVB).

The shifts.txt file must have the following columns:

- ROOTNAME

- FPOFFSET

- FLASH/STRIPE/SEGMENT

- New SHIFT1 value in pixels (dispersion direction shift)

- New SHIFT2 value in pixels (cross-dispersion direction shift)**

**Note: including the SHIFT2 value is optional

If the ROOTNAME is not the association’s rootname, then you can specify FPOFFSET as any in the file. This goes for FLASH/STRIPE/SEGMENT as well, but we will be specifying the segment in our example because we had to calculate the shifts for each segment. More information about running CalCOS when applying the shifts can be found in Section 5.3.2 of the COS Data Handbook.

Running the cell below will create a shifts.txt file, which will be inputted into CalCOS to apply the new shifts to the datasets.

with open(cos_data / "shifts.txt", "w") as shift_file:
    widths = (widths1, widths2, widths3)
    for file, width in zip([fppos1, fppos2, fppos3], widths):

        rootname = fits.getval(file, "ROOTNAME")

        shift_fuva = find_shift_normalized(ref_file,
                                           file,
                                           wavelength_range[0],
                                           "FUVA",
                                           width=width[0],
                                           plot=False)

        shift_file.write(f'{rootname} any any FUVA {shift_fuva}\n')

        shift_fuvb = find_shift_normalized(ref_file,
                                           file,
                                           wavelength_range[1],
                                           "FUVB",
                                           width=width[1],
                                           plot=False)

        shift_file.write(f'{rootname} any any FUVB {shift_fuvb}\n')

Now we can run CalCOS on our data to perform the shift. Check out the COS team’s CalCOS notebook for a tutorial on how to run CalCOS.

try:
    calcos.calcos(f"{cos_data}/le2701010_asn.fits",
                  outdir=str(cos_shifted),
                  shift_file=f"{cos_data}/shifts.txt")
    
except RuntimeError as e:
    print('An error occured', e)
CALCOS version 3.6.0
numpy version 2.2.1
astropy version 7.0.0
Begin 31-Dec-2024 16:50:43 UTC
Association file = cos_ex/cos_data/le2701010_asn.fits
Don't add simulated wavecal because association has no exp_swave members

TIME-TAG calibration -- 31-Dec-2024 16:50:43 UTC
Input     cos_ex/cos_data/le2701q0q_rawtag_a.fits
OutTag    cos_ex/cos_shifted/le2701q0q_corrtag_a.fits
OutFlt    cos_ex/cos_shifted/le2701q0q_flt_a.fits
OutCounts cos_ex/cos_shifted/le2701q0q_counts_a.fits
OutFlash  cos_ex/cos_shifted/le2701q0q_lampflash_a.fits
wavecal shifts overridden by file cos_ex/cos_data/shifts.txt
DETECTOR  FUV, segment A
EXPTYPE   EXTERNAL/SCI
OPT_ELEM  G160M, CENWAVE 1577, FPOFFSET -2
APERTURE  PSA

BADTCORR  PERFORM
BADTTAB = lref$8141834il_badt.fits
RANDCORR  PERFORM
RANDSEED = 1
TEMPCORR  PERFORM
BRFTAB  = lref$x1u1459il_brf.fits
GEOCORR   PERFORM
GEOFILE = lref$x1u1459gl_geo.fits
IGEOCORR  PERFORM
DGEOCORR  PERFORM
DGEOFILE= lref$15c2018fl_dgeo.fits
IGEOCORR  PERFORM
XWLKCORR  PERFORM
XWLKFILE= lref$14o2013ql_xwalk.fits
YWLKCORR  PERFORM
YWLKFILE= lref$88m17269l_ywalk.fits
DEADCORR  PERFORM
DEADTAB = lref$s7g1700gl_dead.fits
PHACORR   PERFORM
PHATAB  = lref$wc318317l_pha.fits
DOPPCORR  PERFORM
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
BRFTAB  = lref$x1u1459il_brf.fits
FLATCORR  PERFORM
FLATFILE= lref$19m1548ql_flat.fits
HVDSCORR  PERFORM
HVDSTAB = lref$87t2019dl_hvds.fits
WAVECORR  PERFORM
Process tagflash wavecal
WCPTAB  = lref$14o20140l_wcp.fits
LAMPTAB = lref$2bj2256ol_lamp.fits
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
lamp on, off, duration, median time:
1:  0.6  12.6  12.0  6.7
2:  545.6  557.0  11.4  551.3
  segment    cross-disp           dispersion direction
            shift (locn)      shift err  [orig.]    FP   chi sq (n)
  -------   -------------     -------------------------  ----------
 1 FUVA       0.3 (518.7)    -485.1 0.00 [  6.0] -504.9  519358.1 (2750)  # user-specified
 2 FUVA      -0.1 (518.3)    -485.1 0.00 [  5.5] -504.9  1656814.6 (2680)  # user-specified
LAMPUSED = NONE, which is incorrect; the value will be reset to P1.
HELCORR   PERFORM for computing wavelengths for the corrtag table
BRSTCORR  OMIT
TRCECORR  PERFORM
TRACETAB= lref$2bj2256jl_trace.fits
ALGNCORR  PERFORM
PROFTAB = lref$2bj2256ql_profile.fits
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to -487, 0
Shifting to -486, 0
Shifting to -485, 0
Shifting to -485, 0
Calculating centroid
Lower wavelength limit of 900.000000 corresponds to column -54112
Upper wavelength limit of 2100.000000 corresponds to column 43871
Starting center = 419.120000
13240 good columns
Background regions are from 565 to 595
and from 615 to 645
Adopted background in science data = 0.000782
Centroid = 421.130321
13237 good columns
Background regions are from 567 to 597
and from 617 to 647
Adopted background in science data = 0.000797
Centroid = 421.140427
13237 good columns
Background regions are from 567 to 597
and from 617 to 647
Adopted background in science data = 0.000797
Centroid = 421.140427
Centroid calculation converged
Background regions are from 567 to 597
and from 617 to 647
Error on centroid = 0.009376
Using profile reference file /home/runner/crds_cache/references/hst/cos/2bj2256ql_profile.fits
Input Reference centroid = 419.124786, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 375 to 405
Adopted background regions for reference profile:
Rows 325 to 355, and rows 375 to 405
Background = 0.000000
Measured reference centroid = 418.778551
Input Reference centroid = 418.778551, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 375 to 405
Adopted background regions for reference profile:
Rows 325 to 355, and rows 375 to 405
Background = 0.000000
Measured reference centroid = 418.778551
Reference centroid calculation converged
Using calculated offset of -2.361875
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to -487, 0
Shifting to -486, 0
Shifting to -485, 0
Shifting to -485, 0
STATFLAG  T
Append a TIMELINE extension.
Warning:  spt file not found, so TIMELINE extension is incomplete

Spectral Extraction -- 31-Dec-2024 16:50:58 UTC
Input     cos_ex/cos_shifted/le2701q0q_flt_a.fits
Incounts  cos_ex/cos_shifted/le2701q0q_counts_a.fits
Output    cos_ex/cos_shifted/le2701q0q_x1d_a.fits

Info:  find-target option = no
X1DCORR   PERFORM
Extraction algorithm = TWOZONE
TWOZXTAB= lref$2bj2256nl_2zx.fits
PROFTAB = lref$2bj2256ql_profile.fits
DISPTAB = lref$2bj2256ml_disp.fits
HELCORR   PERFORM
BACKCORR  PERFORM
STATFLAG  T
FLUXCORR  PERFORM
FLUXTAB = lref$83j20455l_phot.fits
TDSCORR   PERFORM
TDSTAB  = lref$83j20454l_tds.fits
Two-zone extraction method
Using profile centroid of 418.778551
Calculating background for reference profile
Warning:  Background region outside array
Warning:  Background region outside array
Warning:  Background region 2 is outside data array
Using extraction percentiles of:
0.500000 and 99.500000 (outer region)
and 10.000000 and 90.000000 (inner region)
Don't add simulated wavecal because association has no exp_swave members

TIME-TAG calibration -- 31-Dec-2024 16:51:00 UTC
Input     cos_ex/cos_data/le2701q0q_rawtag_b.fits
OutTag    cos_ex/cos_shifted/le2701q0q_corrtag_b.fits
OutFlt    cos_ex/cos_shifted/le2701q0q_flt_b.fits
OutCounts cos_ex/cos_shifted/le2701q0q_counts_b.fits
OutFlash  cos_ex/cos_shifted/le2701q0q_lampflash_b.fits
wavecal shifts overridden by file cos_ex/cos_data/shifts.txt
DETECTOR  FUV, segment B
EXPTYPE   EXTERNAL/SCI
OPT_ELEM  G160M, CENWAVE 1577, FPOFFSET -2
APERTURE  PSA

BADTCORR  PERFORM
BADTTAB = lref$8141834il_badt.fits
RANDCORR  PERFORM
RANDSEED = 1
TEMPCORR  PERFORM
BRFTAB  = lref$x1u1459il_brf.fits
GEOCORR   PERFORM
GEOFILE = lref$x1u1459gl_geo.fits
IGEOCORR  PERFORM
DGEOCORR  PERFORM
DGEOFILE= lref$15c2018fl_dgeo.fits
IGEOCORR  PERFORM
XWLKCORR  PERFORM
XWLKFILE= lref$14o2013ql_xwalk.fits
YWLKCORR  PERFORM
YWLKFILE= lref$88m17269l_ywalk.fits
DEADCORR  PERFORM
DEADTAB = lref$s7g1700gl_dead.fits
PHACORR   PERFORM
PHATAB  = lref$wc318317l_pha.fits
DOPPCORR  PERFORM
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
BRFTAB  = lref$x1u1459il_brf.fits
FLATCORR  PERFORM
FLATFILE= lref$19m1548ql_flat.fits
HVDSCORR  PERFORM
HVDSTAB = lref$87t2019dl_hvds.fits
WAVECORR  PERFORM
Process tagflash wavecal
WCPTAB  = lref$14o20140l_wcp.fits
LAMPTAB = lref$2bj2256ol_lamp.fits
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
lamp on, off, duration, median time:
1:  0.6  12.6  12.0  6.6
2:  545.6  557.0  11.4  551.3
  segment    cross-disp           dispersion direction
            shift (locn)      shift err  [orig.]    FP   chi sq (n)
  -------   -------------     -------------------------  ----------
 1 FUVB       0.4 (581.8)    -491.1 0.00 [  6.0] -507.1  251318.4 (4814)  # user-specified
 2 FUVB       0.2 (581.6)    -491.1 0.00 [  5.8] -507.1  269671.4 (4811)  # user-specified
LAMPUSED = NONE, which is incorrect; the value will be reset to P1.
HELCORR   PERFORM for computing wavelengths for the corrtag table
BRSTCORR  OMIT
TRCECORR  PERFORM
TRACETAB= lref$2bj2256jl_trace.fits
ALGNCORR  PERFORM
PROFTAB = lref$2bj2256ql_profile.fits
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to -493, 0
Shifting to -492, 0
Shifting to -491, 0
Shifting to -491, 0
Calculating centroid
Lower wavelength limit of 900.000000 corresponds to column -38777
Upper wavelength limit of 2100.000000 corresponds to column 59278
Starting center = 478.110000
13710 good columns
Background regions are from 401 to 435
and from 605 to 639
Adopted background in science data = 0.001217
Centroid = 479.717801
13710 good columns
Background regions are from 403 to 437
and from 607 to 641
Adopted background in science data = 0.001223
Centroid = 479.730991
13710 good columns
Background regions are from 403 to 437
and from 607 to 641
Adopted background in science data = 0.001223
Centroid = 479.730991
Centroid calculation converged
Background regions are from 403 to 437
and from 607 to 641
Error on centroid = 0.004458
Using profile reference file /home/runner/crds_cache/references/hst/cos/2bj2256ql_profile.fits
Input Reference centroid = 478.110870, row_0 = 299
Adopted background regions for reference profile:
Rows 102 to 136, and rows 306 to 340
Background = 0.000000
Measured reference centroid = 477.943328
Input Reference centroid = 477.943328, row_0 = 299
Adopted background regions for reference profile:
Rows 102 to 136, and rows 306 to 340
Background = 0.000000
Measured reference centroid = 477.943328
Reference centroid calculation converged
Using calculated offset of -1.787663
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to -493, 0
Shifting to -492, 0
Shifting to -491, 0
Shifting to -491, 0
STATFLAG  T
Append a TIMELINE extension.
Warning:  spt file not found, so TIMELINE extension is incomplete

Spectral Extraction -- 31-Dec-2024 16:52:08 UTC
Input     cos_ex/cos_shifted/le2701q0q_flt_b.fits
Incounts  cos_ex/cos_shifted/le2701q0q_counts_b.fits
Output    cos_ex/cos_shifted/le2701q0q_x1d_b.fits

Info:  find-target option = no
X1DCORR   PERFORM
Extraction algorithm = TWOZONE
TWOZXTAB= lref$2bj2256nl_2zx.fits
PROFTAB = lref$2bj2256ql_profile.fits
DISPTAB = lref$2bj2256ml_disp.fits
HELCORR   PERFORM
BACKCORR  PERFORM
STATFLAG  T
FLUXCORR  PERFORM
FLUXTAB = lref$83j20455l_phot.fits
TDSCORR   PERFORM
TDSTAB  = lref$83j20454l_tds.fits
Two-zone extraction method
Using profile centroid of 477.943328
Calculating background for reference profile
Using extraction percentiles of:
0.500000 and 99.500000 (outer region)
and 10.000000 and 90.000000 (inner region)
Don't add simulated wavecal because association has no exp_swave members

TIME-TAG calibration -- 31-Dec-2024 16:52:10 UTC
Input     cos_ex/cos_data/le2701q2q_rawtag_a.fits
OutTag    cos_ex/cos_shifted/le2701q2q_corrtag_a.fits
OutFlt    cos_ex/cos_shifted/le2701q2q_flt_a.fits
OutCounts cos_ex/cos_shifted/le2701q2q_counts_a.fits
OutFlash  cos_ex/cos_shifted/le2701q2q_lampflash_a.fits
wavecal shifts overridden by file cos_ex/cos_data/shifts.txt
DETECTOR  FUV, segment A
EXPTYPE   EXTERNAL/SCI
OPT_ELEM  G160M, CENWAVE 1577, FPOFFSET -1
APERTURE  PSA

BADTCORR  PERFORM
BADTTAB = lref$8141834il_badt.fits
RANDCORR  PERFORM
RANDSEED = 1
TEMPCORR  PERFORM
BRFTAB  = lref$x1u1459il_brf.fits
GEOCORR   PERFORM
GEOFILE = lref$x1u1459gl_geo.fits
IGEOCORR  PERFORM
DGEOCORR  PERFORM
DGEOFILE= lref$15c2018fl_dgeo.fits
IGEOCORR  PERFORM
XWLKCORR  PERFORM
XWLKFILE= lref$14o2013ql_xwalk.fits
YWLKCORR  PERFORM
YWLKFILE= lref$88m17269l_ywalk.fits
DEADCORR  PERFORM
DEADTAB = lref$s7g1700gl_dead.fits
PHACORR   PERFORM
PHATAB  = lref$wc318317l_pha.fits
DOPPCORR  PERFORM
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
BRFTAB  = lref$x1u1459il_brf.fits
FLATCORR  PERFORM
FLATFILE= lref$19m1548ql_flat.fits
HVDSCORR  PERFORM
HVDSTAB = lref$87t2019dl_hvds.fits
WAVECORR  PERFORM
Process tagflash wavecal
WCPTAB  = lref$14o20140l_wcp.fits
LAMPTAB = lref$2bj2256ol_lamp.fits
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
lamp on, off, duration, median time:
1:  0.6  12.4  11.8  6.6
2:  545.6  557.0  11.4  551.4
  segment    cross-disp           dispersion direction
            shift (locn)      shift err  [orig.]    FP   chi sq (n)
  -------   -------------     -------------------------  ----------
 1 FUVA       0.1 (518.5)    -181.4 0.00 [ -6.1] -189.4  88906.1 (2762)  # user-specified
 2 FUVA      -0.0 (518.4)    -181.4 0.00 [ -7.2] -189.4  95717.9 (2737)  # user-specified
LAMPUSED = NONE, which is incorrect; the value will be reset to P1.
HELCORR   PERFORM for computing wavelengths for the corrtag table
BRSTCORR  OMIT
TRCECORR  PERFORM
TRACETAB= lref$2bj2256jl_trace.fits
ALGNCORR  PERFORM
PROFTAB = lref$2bj2256ql_profile.fits
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to -182, 0
Shifting to -181, 0
Shifting to -180, 0
Shifting to -182, 0
Shifting to -181, 0
Calculating centroid
Lower wavelength limit of 900.000000 corresponds to column -54112
Upper wavelength limit of 2100.000000 corresponds to column 43871
Starting center = 419.120000
13231 good columns
Background regions are from 565 to 595
and from 615 to 645
Adopted background in science data = 0.000783
Centroid = 421.131506
13229 good columns
Background regions are from 567 to 597
and from 617 to 647
Adopted background in science data = 0.000783
Centroid = 421.143252
13229 good columns
Background regions are from 567 to 597
and from 617 to 647
Adopted background in science data = 0.000783
Centroid = 421.143252
Centroid calculation converged
Background regions are from 567 to 597
and from 617 to 647
Error on centroid = 0.009420
Using profile reference file /home/runner/crds_cache/references/hst/cos/2bj2256ql_profile.fits
Input Reference centroid = 419.124786, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 375 to 405
Adopted background regions for reference profile:
Rows 325 to 355, and rows 375 to 405
Background = 0.000000
Measured reference centroid = 418.779285
Input Reference centroid = 418.779285, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 375 to 405
Adopted background regions for reference profile:
Rows 325 to 355, and rows 375 to 405
Background = 0.000000
Measured reference centroid = 418.779285
Reference centroid calculation converged
Using calculated offset of -2.363967
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to -182, 0
Shifting to -181, 0
Shifting to -180, 0
Shifting to -182, 0
Shifting to -181, 0
STATFLAG  T
Append a TIMELINE extension.
Warning:  spt file not found, so TIMELINE extension is incomplete

Spectral Extraction -- 31-Dec-2024 16:52:25 UTC
Input     cos_ex/cos_shifted/le2701q2q_flt_a.fits
Incounts  cos_ex/cos_shifted/le2701q2q_counts_a.fits
Output    cos_ex/cos_shifted/le2701q2q_x1d_a.fits

Info:  find-target option = no
X1DCORR   PERFORM
Extraction algorithm = TWOZONE
TWOZXTAB= lref$2bj2256nl_2zx.fits
PROFTAB = lref$2bj2256ql_profile.fits
DISPTAB = lref$2bj2256ml_disp.fits
HELCORR   PERFORM
BACKCORR  PERFORM
STATFLAG  T
FLUXCORR  PERFORM
FLUXTAB = lref$83j20455l_phot.fits
TDSCORR   PERFORM
TDSTAB  = lref$83j20454l_tds.fits
Two-zone extraction method
Using profile centroid of 418.779285
Calculating background for reference profile
Warning:  Background region outside array
Warning:  Background region outside array
Warning:  Background region 2 is outside data array
Using extraction percentiles of:
0.500000 and 99.500000 (outer region)
and 10.000000 and 90.000000 (inner region)
Don't add simulated wavecal because association has no exp_swave members

TIME-TAG calibration -- 31-Dec-2024 16:52:27 UTC
Input     cos_ex/cos_data/le2701q2q_rawtag_b.fits
OutTag    cos_ex/cos_shifted/le2701q2q_corrtag_b.fits
OutFlt    cos_ex/cos_shifted/le2701q2q_flt_b.fits
OutCounts cos_ex/cos_shifted/le2701q2q_counts_b.fits
OutFlash  cos_ex/cos_shifted/le2701q2q_lampflash_b.fits
wavecal shifts overridden by file cos_ex/cos_data/shifts.txt
DETECTOR  FUV, segment B
EXPTYPE   EXTERNAL/SCI
OPT_ELEM  G160M, CENWAVE 1577, FPOFFSET -1
APERTURE  PSA

BADTCORR  PERFORM
BADTTAB = lref$8141834il_badt.fits
RANDCORR  PERFORM
RANDSEED = 1
TEMPCORR  PERFORM
BRFTAB  = lref$x1u1459il_brf.fits
GEOCORR   PERFORM
GEOFILE = lref$x1u1459gl_geo.fits
IGEOCORR  PERFORM
DGEOCORR  PERFORM
DGEOFILE= lref$15c2018fl_dgeo.fits
IGEOCORR  PERFORM
XWLKCORR  PERFORM
XWLKFILE= lref$14o2013ql_xwalk.fits
YWLKCORR  PERFORM
YWLKFILE= lref$88m17269l_ywalk.fits
DEADCORR  PERFORM
DEADTAB = lref$s7g1700gl_dead.fits
PHACORR   PERFORM
PHATAB  = lref$wc318317l_pha.fits
DOPPCORR  PERFORM
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
BRFTAB  = lref$x1u1459il_brf.fits
FLATCORR  PERFORM
FLATFILE= lref$19m1548ql_flat.fits
HVDSCORR  PERFORM
HVDSTAB = lref$87t2019dl_hvds.fits
WAVECORR  PERFORM
Process tagflash wavecal
WCPTAB  = lref$14o20140l_wcp.fits
LAMPTAB = lref$2bj2256ol_lamp.fits
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
lamp on, off, duration, median time:

1:  0.6  12.6  12.0  6.6
2:  545.6  557.0  11.4  551.2
  segment    cross-disp           dispersion direction
            shift (locn)      shift err  [orig.]    FP   chi sq (n)
  -------   -------------     -------------------------  ----------
 1 FUVB       0.2 (581.6)    -186.5 0.00 [ -5.9] -189.9  258710.4 (4816)  # user-specified
 2 FUVB       0.3 (581.7)    -186.5 0.00 [ -6.3] -189.9  220208.2 (4810)  # user-specified
LAMPUSED = NONE, which is incorrect; the value will be reset to P1.
HELCORR   PERFORM for computing wavelengths for the corrtag table
BRSTCORR  OMIT
TRCECORR  PERFORM
TRACETAB= lref$2bj2256jl_trace.fits
ALGNCORR  PERFORM
PROFTAB = lref$2bj2256ql_profile.fits
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to -187, 0
Shifting to -186, 0
Shifting to -185, 0
Shifting to -187, 0
Shifting to -186, 0
Calculating centroid
Lower wavelength limit of 900.000000 corresponds to column -38777
Upper wavelength limit of 2100.000000 corresponds to column 59278
Starting center = 478.110000
13706 good columns
Background regions are from 401 to 435
and from 605 to 639
Adopted background in science data = 0.001285
Centroid = 479.698823
13706 good columns
Background regions are from 403 to 437
and from 607 to 641
Adopted background in science data = 0.001287
Centroid = 479.710935
13706 good columns
Background regions are from 403 to 437
and from 607 to 641
Adopted background in science data = 0.001287
Centroid = 479.710935
Centroid calculation converged
Background regions are from 403 to 437

and from 607 to 641
Error on centroid = 0.004482
Using profile reference file /home/runner/crds_cache/references/hst/cos/2bj2256ql_profile.fits
Input Reference centroid = 478.110870, row_0 = 299
Adopted background regions for reference profile:
Rows 102 to 136, and rows 306 to 340
Background = 0.000000
Measured reference centroid = 477.943197
Input Reference centroid = 477.943197, row_0 = 299
Adopted background regions for reference profile:
Rows 102 to 136, and rows 306 to 340
Background = 0.000000
Measured reference centroid = 477.943197
Reference centroid calculation converged
Using calculated offset of -1.767739
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to -187, 0
Shifting to -186, 0
Shifting to -185, 0
Shifting to -187, 0
Shifting to -186, 0
STATFLAG  T
Append a TIMELINE extension.
Warning:  spt file not found, so TIMELINE extension is incomplete

Spectral Extraction -- 31-Dec-2024 16:53:36 UTC
Input     cos_ex/cos_shifted/le2701q2q_flt_b.fits
Incounts  cos_ex/cos_shifted/le2701q2q_counts_b.fits
Output    cos_ex/cos_shifted/le2701q2q_x1d_b.fits

Info:  find-target option = no
X1DCORR   PERFORM
Extraction algorithm = TWOZONE
TWOZXTAB= lref$2bj2256nl_2zx.fits
PROFTAB = lref$2bj2256ql_profile.fits
DISPTAB = lref$2bj2256ml_disp.fits
HELCORR   PERFORM
BACKCORR  PERFORM
STATFLAG  T
FLUXCORR  PERFORM
FLUXTAB = lref$83j20455l_phot.fits
TDSCORR   PERFORM
TDSTAB  = lref$83j20454l_tds.fits
Two-zone extraction method
Using profile centroid of 477.943197
Calculating background for reference profile
Using extraction percentiles of:
0.500000 and 99.500000 (outer region)
and 10.000000 and 90.000000 (inner region)
Don't add simulated wavecal because association has no exp_swave members

TIME-TAG calibration -- 31-Dec-2024 16:53:38 UTC
Input     cos_ex/cos_data/le2701q4q_rawtag_a.fits
OutTag    cos_ex/cos_shifted/le2701q4q_corrtag_a.fits
OutFlt    cos_ex/cos_shifted/le2701q4q_flt_a.fits
OutCounts cos_ex/cos_shifted/le2701q4q_counts_a.fits
OutFlash  cos_ex/cos_shifted/le2701q4q_lampflash_a.fits
wavecal shifts overridden by file cos_ex/cos_data/shifts.txt
DETECTOR  FUV, segment A
EXPTYPE   EXTERNAL/SCI
OPT_ELEM  G160M, CENWAVE 1577, FPOFFSET 0
APERTURE  PSA

BADTCORR  PERFORM
BADTTAB = lref$8141834il_badt.fits
RANDCORR  PERFORM
RANDSEED = 1
TEMPCORR  PERFORM
BRFTAB  = lref$x1u1459il_brf.fits
GEOCORR   PERFORM
GEOFILE = lref$x1u1459gl_geo.fits
IGEOCORR  PERFORM
DGEOCORR  PERFORM
DGEOFILE= lref$15c2018fl_dgeo.fits
IGEOCORR  PERFORM
XWLKCORR  PERFORM
XWLKFILE= lref$14o2013ql_xwalk.fits
YWLKCORR  PERFORM
YWLKFILE= lref$88m17269l_ywalk.fits
DEADCORR  PERFORM
DEADTAB = lref$s7g1700gl_dead.fits
PHACORR   PERFORM
PHATAB  = lref$wc318317l_pha.fits
DOPPCORR  PERFORM
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
BRFTAB  = lref$x1u1459il_brf.fits
FLATCORR  PERFORM
FLATFILE= lref$19m1548ql_flat.fits
HVDSCORR  PERFORM
HVDSTAB = lref$87t2019dl_hvds.fits
WAVECORR  PERFORM
Process tagflash wavecal
WCPTAB  = lref$14o20140l_wcp.fits
LAMPTAB = lref$2bj2256ol_lamp.fits
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
lamp on, off, duration, median time:

1:  0.6  12.6  12.0  6.6
  segment    cross-disp           dispersion direction
            shift (locn)      shift err  [orig.]    FP   chi sq (n)
  -------   -------------     -------------------------  ----------
 1 FUVA       0.3 (518.7)      20.5 0.00 [ 21.8]    0.0  5137.8 (2406)  # user-specified
LAMPUSED = NONE, which is incorrect; the value will be reset to P1.
HELCORR   PERFORM for computing wavelengths for the corrtag table
BRSTCORR  OMIT
TRCECORR  PERFORM
TRACETAB= lref$2bj2256jl_trace.fits
ALGNCORR  PERFORM
PROFTAB = lref$2bj2256ql_profile.fits
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to 18, 0
Shifting to 19, 0
Shifting to 20, 0
Shifting to 21, 0
Calculating centroid
Lower wavelength limit of 900.000000 corresponds to column -54112
Upper wavelength limit of 2100.000000 corresponds to column 43871
Starting center = 419.120000
13227 good columns
Background regions are from 565 to 595
and from 615 to 645
Adopted background in science data = 0.000711
Centroid = 419.582955
13232 good columns
Background regions are from 566 to 596
and from 616 to 646
Adopted background in science data = 0.000715
Centroid = 419.592172
13232 good columns
Background regions are from 566 to 596
and from 616 to 646
Adopted background in science data = 0.000715
Centroid = 419.592172
Centroid calculation converged
Background regions are from 566 to 596
and from 616 to 646
Error on centroid = 0.009470
Using profile reference file /home/runner/crds_cache/references/hst/cos/2bj2256ql_profile.fits
Input Reference centroid = 419.124786, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 376 to 406
Adopted background regions for reference profile:
Rows 326 to 356, and rows 376 to 406
Background = 0.000000
Measured reference centroid = 418.787492
Input Reference centroid = 418.787492, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 375 to 405
Adopted background regions for reference profile:
Rows 325 to 355, and rows 375 to 405
Background = 0.000000
Measured reference centroid = 418.782456
Input Reference centroid = 418.782456, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 375 to 405
Adopted background regions for reference profile:
Rows 325 to 355, and rows 375 to 405
Background = 0.000000
Measured reference centroid = 418.782456
Reference centroid calculation converged
Using calculated offset of -0.809715
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to 18, 0
Shifting to 19, 0
Shifting to 20, 0
Shifting to 21, 0
STATFLAG  T
Append a TIMELINE extension.
Warning:  spt file not found, so TIMELINE extension is incomplete

Spectral Extraction -- 31-Dec-2024 16:53:52 UTC
Input     cos_ex/cos_shifted/le2701q4q_flt_a.fits
Incounts  cos_ex/cos_shifted/le2701q4q_counts_a.fits
Output    cos_ex/cos_shifted/le2701q4q_x1d_a.fits

Info:  find-target option = no
X1DCORR   PERFORM
Extraction algorithm = TWOZONE
TWOZXTAB= lref$2bj2256nl_2zx.fits
PROFTAB = lref$2bj2256ql_profile.fits
DISPTAB = lref$2bj2256ml_disp.fits
HELCORR   PERFORM
BACKCORR  PERFORM
STATFLAG  T
FLUXCORR  PERFORM
FLUXTAB = lref$83j20455l_phot.fits
TDSCORR   PERFORM
TDSTAB  = lref$83j20454l_tds.fits
Two-zone extraction method
Using profile centroid of 418.782456
Calculating background for reference profile
Warning:  Background region outside array
Warning:  Background region outside array
Warning:  Background region 2 is outside data array
Using extraction percentiles of:
0.500000 and 99.500000 (outer region)
and 10.000000 and 90.000000 (inner region)
Don't add simulated wavecal because association has no exp_swave members

TIME-TAG calibration -- 31-Dec-2024 16:53:54 UTC
Input     cos_ex/cos_data/le2701q4q_rawtag_b.fits
OutTag    cos_ex/cos_shifted/le2701q4q_corrtag_b.fits
OutFlt    cos_ex/cos_shifted/le2701q4q_flt_b.fits
OutCounts cos_ex/cos_shifted/le2701q4q_counts_b.fits
OutFlash  cos_ex/cos_shifted/le2701q4q_lampflash_b.fits
wavecal shifts overridden by file cos_ex/cos_data/shifts.txt
DETECTOR  FUV, segment B
EXPTYPE   EXTERNAL/SCI
OPT_ELEM  G160M, CENWAVE 1577, FPOFFSET 0
APERTURE  PSA

BADTCORR  PERFORM
BADTTAB = lref$8141834il_badt.fits
RANDCORR  PERFORM
RANDSEED = 1
TEMPCORR  PERFORM
BRFTAB  = lref$x1u1459il_brf.fits
GEOCORR   PERFORM
GEOFILE = lref$x1u1459gl_geo.fits
IGEOCORR  PERFORM
DGEOCORR  PERFORM
DGEOFILE= lref$15c2018fl_dgeo.fits
IGEOCORR  PERFORM
XWLKCORR  PERFORM
XWLKFILE= lref$14o2013ql_xwalk.fits
YWLKCORR  PERFORM
YWLKFILE= lref$88m17269l_ywalk.fits
DEADCORR  PERFORM
DEADTAB = lref$s7g1700gl_dead.fits
PHACORR   PERFORM
PHATAB  = lref$wc318317l_pha.fits
DOPPCORR  PERFORM
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
BRFTAB  = lref$x1u1459il_brf.fits
FLATCORR  PERFORM
FLATFILE= lref$19m1548ql_flat.fits
HVDSCORR  PERFORM
HVDSTAB = lref$87t2019dl_hvds.fits
WAVECORR  PERFORM
Process tagflash wavecal
WCPTAB  = lref$14o20140l_wcp.fits
LAMPTAB = lref$2bj2256ol_lamp.fits
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
lamp on, off, duration, median time:
1:  0.6  12.6  12.0  6.6
  segment    cross-disp           dispersion direction
            shift (locn)      shift err  [orig.]    FP   chi sq (n)
  -------   -------------     -------------------------  ----------
 1 FUVB       0.1 (581.5)      23.1 0.00 [ 23.0]    0.0  11160.3 (4270)  # user-specified
LAMPUSED = NONE, which is incorrect; the value will be reset to P1.
HELCORR   PERFORM for computing wavelengths for the corrtag table
BRSTCORR  OMIT
TRCECORR  PERFORM
TRACETAB= lref$2bj2256jl_trace.fits
ALGNCORR  PERFORM
PROFTAB = lref$2bj2256ql_profile.fits
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to 21, 0
Shifting to 22, 0
Shifting to 23, 0
Calculating centroid
Lower wavelength limit of 900.000000 corresponds to column -38777
Upper wavelength limit of 2100.000000 corresponds to column 59278
Starting center = 478.110000
13716 good columns
Background regions are from 401 to 435
and from 605 to 639
Adopted background in science data = 0.001209
Centroid = 478.718142
13716 good columns
Background regions are from 402 to 436
and from 606 to 640
Adopted background in science data = 0.001214
Centroid = 478.724797
13716 good columns
Background regions are from 402 to 436
and from 606 to 640
Adopted background in science data = 0.001214
Centroid = 478.724797
Centroid calculation converged
Background regions are from 402 to 436
and from 606 to 640
Error on centroid = 0.004495
Using profile reference file /home/runner/crds_cache/references/hst/cos/2bj2256ql_profile.fits
Input Reference centroid = 478.110870, row_0 = 299
Adopted background regions for reference profile:
Rows 102 to 136, and rows 306 to 340
Background = 0.000000
Measured reference centroid = 477.943168
Input Reference centroid = 477.943168, row_0 = 299
Adopted background regions for reference profile:
Rows 102 to 136, and rows 306 to 340
Background = 0.000000
Measured reference centroid = 477.943168
Reference centroid calculation converged
Using calculated offset of -0.781628
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to 21, 0
Shifting to 22, 0
Shifting to 23, 0
STATFLAG  T
Append a TIMELINE extension.
Warning:  spt file not found, so TIMELINE extension is incomplete

Spectral Extraction -- 31-Dec-2024 16:55:03 UTC
Input     cos_ex/cos_shifted/le2701q4q_flt_b.fits
Incounts  cos_ex/cos_shifted/le2701q4q_counts_b.fits
Output    cos_ex/cos_shifted/le2701q4q_x1d_b.fits

Info:  find-target option = no
X1DCORR   PERFORM
Extraction algorithm = TWOZONE
TWOZXTAB= lref$2bj2256nl_2zx.fits
PROFTAB = lref$2bj2256ql_profile.fits
DISPTAB = lref$2bj2256ml_disp.fits
HELCORR   PERFORM
BACKCORR  PERFORM
STATFLAG  T
FLUXCORR  PERFORM
FLUXTAB = lref$83j20455l_phot.fits
TDSCORR   PERFORM
TDSTAB  = lref$83j20454l_tds.fits
Two-zone extraction method
Using profile centroid of 477.943168
Calculating background for reference profile
Using extraction percentiles of:
0.500000 and 99.500000 (outer region)
and 10.000000 and 90.000000 (inner region)
Don't add simulated wavecal because association has no exp_swave members

TIME-TAG calibration -- 31-Dec-2024 16:55:04 UTC
Input     cos_ex/cos_data/le2701q6q_rawtag_a.fits
OutTag    cos_ex/cos_shifted/le2701q6q_corrtag_a.fits
OutFlt    cos_ex/cos_shifted/le2701q6q_flt_a.fits
OutCounts cos_ex/cos_shifted/le2701q6q_counts_a.fits
OutFlash  cos_ex/cos_shifted/le2701q6q_lampflash_a.fits
wavecal shifts overridden by file cos_ex/cos_data/shifts.txt
DETECTOR  FUV, segment A
EXPTYPE   EXTERNAL/SCI
OPT_ELEM  G160M, CENWAVE 1577, FPOFFSET 1
APERTURE  PSA

BADTCORR  PERFORM
BADTTAB = lref$8141834il_badt.fits
RANDCORR  PERFORM
RANDSEED = 1
TEMPCORR  PERFORM
BRFTAB  = lref$x1u1459il_brf.fits
GEOCORR   PERFORM
GEOFILE = lref$x1u1459gl_geo.fits
IGEOCORR  PERFORM
DGEOCORR  PERFORM
DGEOFILE= lref$15c2018fl_dgeo.fits
IGEOCORR  PERFORM
XWLKCORR  PERFORM
XWLKFILE= lref$14o2013ql_xwalk.fits
YWLKCORR  PERFORM
YWLKFILE= lref$88m17269l_ywalk.fits
DEADCORR  PERFORM
DEADTAB = lref$s7g1700gl_dead.fits
PHACORR   PERFORM
PHATAB  = lref$wc318317l_pha.fits
DOPPCORR  PERFORM
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
BRFTAB  = lref$x1u1459il_brf.fits
FLATCORR  PERFORM
FLATFILE= lref$19m1548ql_flat.fits
HVDSCORR  PERFORM
HVDSTAB = lref$87t2019dl_hvds.fits
WAVECORR  PERFORM
Process tagflash wavecal
WCPTAB  = lref$14o20140l_wcp.fits
LAMPTAB = lref$2bj2256ol_lamp.fits
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
lamp on, off, duration, median time:
1:  0.6  12.6  12.0  6.6
  segment    cross-disp           dispersion direction
            shift (locn)      shift err  [orig.]    FP   chi sq (n)
  -------   -------------     -------------------------  ----------
 1 FUVA       0.0 (518.4)     303.1 1.35 [ -3.2]  306.3  5041.2 (2464)
LAMPUSED = NONE, which is incorrect; the value will be reset to P1.
HELCORR   PERFORM for computing wavelengths for the corrtag table
BRSTCORR  OMIT
TRCECORR  PERFORM
TRACETAB= lref$2bj2256jl_trace.fits
ALGNCORR  PERFORM
PROFTAB = lref$2bj2256ql_profile.fits
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to 302, 0
Shifting to 303, 0
Shifting to 303, 0
Calculating centroid
Lower wavelength limit of 900.000000 corresponds to column -54112
Upper wavelength limit of 2100.000000 corresponds to column 43871
Starting center = 419.120000
13249 good columns
Background regions are from 565 to 595
and from 615 to 645
Adopted background in science data = 0.000767
Centroid = 419.863315
13247 good columns
Background regions are from 566 to 596
and from 616 to 646
Adopted background in science data = 0.000777
Centroid = 419.869234
13247 good columns
Background regions are from 566 to 596
and from 616 to 646
Adopted background in science data = 0.000777
Centroid = 419.869234
Centroid calculation converged
Background regions are from 566 to 596
and from 616 to 646
Error on centroid = 0.009497
Using profile reference file /home/runner/crds_cache/references/hst/cos/2bj2256ql_profile.fits
Input Reference centroid = 419.124786, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 375 to 405
Adopted background regions for reference profile:
Rows 325 to 355, and rows 375 to 405
Background = 0.000000
Measured reference centroid = 418.784531
Input Reference centroid = 418.784531, row_0 = 240
Unable to extract background region #2 from reference profile
Requested rows: 375 to 405
Adopted background regions for reference profile:
Rows 325 to 355, and rows 375 to 405
Background = 0.000000
Measured reference centroid = 418.784531
Reference centroid calculation converged
Using calculated offset of -1.084703
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to 302, 0
Shifting to 303, 0
Shifting to 303, 0
STATFLAG  T
Append a TIMELINE extension.
Warning:  spt file not found, so TIMELINE extension is incomplete

Spectral Extraction -- 31-Dec-2024 16:55:19 UTC
Input     cos_ex/cos_shifted/le2701q6q_flt_a.fits
Incounts  cos_ex/cos_shifted/le2701q6q_counts_a.fits
Output    cos_ex/cos_shifted/le2701q6q_x1d_a.fits

Info:  find-target option = no
X1DCORR   PERFORM
Extraction algorithm = TWOZONE
TWOZXTAB= lref$2bj2256nl_2zx.fits
PROFTAB = lref$2bj2256ql_profile.fits
DISPTAB = lref$2bj2256ml_disp.fits
HELCORR   PERFORM
BACKCORR  PERFORM
STATFLAG  T
FLUXCORR  PERFORM
FLUXTAB = lref$83j20455l_phot.fits
TDSCORR   PERFORM
TDSTAB  = lref$83j20454l_tds.fits
Two-zone extraction method
Using profile centroid of 418.784531
Calculating background for reference profile
Warning:  Background region outside array
Warning:  Background region outside array
Warning:  Background region 2 is outside data array
Using extraction percentiles of:
0.500000 and 99.500000 (outer region)
and 10.000000 and 90.000000 (inner region)
Don't add simulated wavecal because association has no exp_swave members

TIME-TAG calibration -- 31-Dec-2024 16:55:21 UTC
Input     cos_ex/cos_data/le2701q6q_rawtag_b.fits
OutTag    cos_ex/cos_shifted/le2701q6q_corrtag_b.fits
OutFlt    cos_ex/cos_shifted/le2701q6q_flt_b.fits
OutCounts cos_ex/cos_shifted/le2701q6q_counts_b.fits
OutFlash  cos_ex/cos_shifted/le2701q6q_lampflash_b.fits
wavecal shifts overridden by file cos_ex/cos_data/shifts.txt
DETECTOR  FUV, segment B
EXPTYPE   EXTERNAL/SCI
OPT_ELEM  G160M, CENWAVE 1577, FPOFFSET 1
APERTURE  PSA

BADTCORR  PERFORM
BADTTAB = lref$8141834il_badt.fits
RANDCORR  PERFORM
RANDSEED = 1
TEMPCORR  PERFORM
BRFTAB  = lref$x1u1459il_brf.fits
GEOCORR   PERFORM
GEOFILE = lref$x1u1459gl_geo.fits
IGEOCORR  PERFORM
DGEOCORR  PERFORM
DGEOFILE= lref$15c2018fl_dgeo.fits
IGEOCORR  PERFORM
XWLKCORR  PERFORM
XWLKFILE= lref$14o2013ql_xwalk.fits
YWLKCORR  PERFORM
YWLKFILE= lref$88m17269l_ywalk.fits
DEADCORR  PERFORM
DEADTAB = lref$s7g1700gl_dead.fits
PHACORR   PERFORM
PHATAB  = lref$wc318317l_pha.fits
DOPPCORR  PERFORM
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
BRFTAB  = lref$x1u1459il_brf.fits
FLATCORR  PERFORM
FLATFILE= lref$19m1548ql_flat.fits
HVDSCORR  PERFORM
HVDSTAB = lref$87t2019dl_hvds.fits
WAVECORR  PERFORM
Process tagflash wavecal
WCPTAB  = lref$14o20140l_wcp.fits
LAMPTAB = lref$2bj2256ol_lamp.fits
XTRACTAB= lref$2bj2256il_1dx.fits
DISPTAB = lref$2bj2256ml_disp.fits
lamp on, off, duration, median time:
1:  0.6  12.6  12.0  6.6
  segment    cross-disp           dispersion direction
            shift (locn)      shift err  [orig.]    FP   chi sq (n)
  -------   -------------     -------------------------  ----------
 1 FUVB       0.4 (581.8)     302.0 0.34 [ -3.2]  305.2  10757.8 (4350)
LAMPUSED = NONE, which is incorrect; the value will be reset to P1.
HELCORR   PERFORM for computing wavelengths for the corrtag table
BRSTCORR  OMIT
TRCECORR  PERFORM
TRACETAB= lref$2bj2256jl_trace.fits
ALGNCORR  PERFORM
PROFTAB = lref$2bj2256ql_profile.fits
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to 301, 0
Shifting to 302, 0
Shifting to 302, 0
Calculating centroid
Lower wavelength limit of 900.000000 corresponds to column -38777
Upper wavelength limit of 2100.000000 corresponds to column 59278
Starting center = 478.110000
13717 good columns
Background regions are from 401 to 435
and from 605 to 639
Adopted background in science data = 0.001280
Centroid = 478.318632
13717 good columns
Background regions are from 401 to 435
and from 605 to 639
Adopted background in science data = 0.001280
Centroid = 478.318632
Centroid calculation converged
Background regions are from 401 to 435

and from 605 to 639
Error on centroid = 0.004483
Using profile reference file /home/runner/crds_cache/references/hst/cos/2bj2256ql_profile.fits
Input Reference centroid = 478.110870, row_0 = 299
Adopted background regions for reference profile:
Rows 102 to 136, and rows 306 to 340
Background = 0.000000
Measured reference centroid = 477.942683
Input Reference centroid = 477.942683, row_0 = 299
Adopted background regions for reference profile:
Rows 102 to 136, and rows 306 to 340
Background = 0.000000
Measured reference centroid = 477.942683
Reference centroid calculation converged
Using calculated offset of -0.375949
DQICORR   PERFORM
BPIXTAB = lref$69m20528l_bpix.fits
GSAGTAB = lref$8991635ql_gsag.fits
SPOTTAB = lref$69f20032l_spot.fits
Shifting to 301, 0
Shifting to 302, 0
Shifting to 302, 0
STATFLAG  T
Append a TIMELINE extension.
Warning:  spt file not found, so TIMELINE extension is incomplete

Spectral Extraction -- 31-Dec-2024 16:56:30 UTC
Input     cos_ex/cos_shifted/le2701q6q_flt_b.fits
Incounts  cos_ex/cos_shifted/le2701q6q_counts_b.fits
Output    cos_ex/cos_shifted/le2701q6q_x1d_b.fits

Info:  find-target option = no
X1DCORR   PERFORM
Extraction algorithm = TWOZONE
TWOZXTAB= lref$2bj2256nl_2zx.fits
PROFTAB = lref$2bj2256ql_profile.fits
DISPTAB = lref$2bj2256ml_disp.fits
HELCORR   PERFORM
BACKCORR  PERFORM
STATFLAG  T
FLUXCORR  PERFORM
FLUXTAB = lref$83j20455l_phot.fits
TDSCORR   PERFORM
TDSTAB  = lref$83j20454l_tds.fits
Two-zone extraction method
Using profile centroid of 477.942683
Calculating background for reference profile
Using extraction percentiles of:
0.500000 and 99.500000 (outer region)
and 10.000000 and 90.000000 (inner region)
SPWCSTAB= lref$49g17154l_spwcs.fits

Average 1-D spectra -- 31-Dec-2024 16:56:34 UTC
Input     ['cos_ex/cos_shifted/le2701q0q_x1d.fits', 'cos_ex/cos_shifted/le2701q2q_x1d.fits', 'cos_ex/cos_shifted/le2701q4q_x1d.fits', 'cos_ex/cos_shifted/le2701q6q_x1d.fits']
Output    cos_ex/cos_shifted/le2701010_x1dsum.fits
Warning:  Flat field extends beyond the data array; the flat will be truncated.
Warning:  Flat field extends beyond the data array; the flat will be truncated.
Warning:  Flat field extends beyond the data array; the flat will be truncated.
Warning:  Flat field extends beyond the data array; the flat will be truncated.
Warning:  Flat field extends beyond the data array; the flat will be truncated.
Warning:  Flat field extends beyond the data array; the flat will be truncated.
Warning:  Flat field extends beyond the data array; the flat will be truncated.
Warning:  Flat field extends beyond the data array; the flat will be truncated.

Average 1-D spectra -- 31-Dec-2024 16:56:35 UTC
Input     ['cos_ex/cos_shifted/le2701q0q_x1d.fits']
Output    cos_ex/cos_shifted/le2701010_x1dsum1.fits

Average 1-D spectra -- 31-Dec-2024 16:56:35 UTC
Input     ['cos_ex/cos_shifted/le2701q2q_x1d.fits']
Output    cos_ex/cos_shifted/le2701010_x1dsum2.fits

Average 1-D spectra -- 31-Dec-2024 16:56:35 UTC
Input     ['cos_ex/cos_shifted/le2701q4q_x1d.fits']
Output    cos_ex/cos_shifted/le2701010_x1dsum3.fits

Average 1-D spectra -- 31-Dec-2024 16:56:35 UTC
Input     ['cos_ex/cos_shifted/le2701q6q_x1d.fits']
Output    cos_ex/cos_shifted/le2701010_x1dsum4.fits
Warning:  spt file not found, so not copied to product
End   31-Dec-2024 16:56:35 UTC

Let’s compare the pre-shifted and shifted wavelength ranges of our observations for both segments:

fig, ax = plt.subplots(2, 2, figsize=(16, 8))

# Plotting the unshifted data on the top row
for i, file in enumerate(sorted(cos_unshifted.glob("*x1d.fits*"))):

    with fits.open(file) as hdul:
        wavelength = hdul[1].data["WAVELENGTH"].flatten()
        flux = hdul[1].data["FLUX"].flatten()

    for j in range(0, 2):
        ax[0][j].plot(
            wavelength,
            flux,
            lw=2,
            alpha=0.6,
            label=f'FPPOS {fits.getval(file, "FPPOS")}',
            color=colors[i]
        )

# Now plotting the shifted data on the bottom row
for i, file in enumerate(sorted(cos_shifted.glob("*x1d.fits*"))):
    with fits.open(file) as hdul:

        wavelength = hdul[1].data["WAVELENGTH"].flatten()
        flux = hdul[1].data["FLUX"].flatten()

    for j in range(0, 2):
        ax[1][j].plot(
            wavelength,
            flux,
            lw=2,
            alpha=0.6,
            label=f'FPPOS {fits.getval(file, "FPPOS")}',
            color=colors[i]
        )

# Adding titles
fig.suptitle("Flux vs Wavelength, Pre-shifted (top) and Shifted (bottom)",
             weight="bold",
             fontsize=14)

ax[0][0].set_title(f"Pre-shifted, FUVA, {wavelength_range[0]}")
ax[0][1].set_title(f"Pre-shifted, FUVB, {wavelength_range[1]}")

ax[1][0].set_title(f"Shifted, FUVA, {wavelength_range[0]}")
ax[1][1].set_title(f"Shifted, FUVB, {wavelength_range[1]}")

# Setting xlimits
ax[0][0].set_xlim(wavelength_range[0])
ax[0][1].set_xlim(wavelength_range[1][0], wavelength_range[1][1])

ax[1][0].set_xlim(wavelength_range[0])
ax[1][1].set_xlim(wavelength_range[1][0], wavelength_range[1][1])

# Adding a legend and setting ylim
for subplot in ax.flatten():
    subplot.legend()
    subplot.set_ylim(0, 1.5e-13)

plt.tight_layout()
plt.show()
../../../_images/f48ccc6ae79665c356f9838a162b76c9ea8cd929d5d2469d0f1e5f9217956f3d.png

We can visually see a clear improvement in the spectral features when we applied our shifts to CalCOS as the two absorption features have lined up for all FPPOS.

1.6 Comparing Non-Shifted and Shifted COS Coadds#

Now that we’ve successfully shifted our data, let’s re-create our coadd. We will calculate the radial velocity of the new coadd as well and compare it with our values from the earlier section.

!swrapper -i ./cos_ex/cos_shifted -o ./cos_ex/cos_shifted/coadd
clear_output()

Let’s see the flux and SNR of our coadd now that we’ve recalibrated:

coadd = "hst_15824_cos_lmc079-1_g160m_le27_cspec.fits"

# The paths to both of our coadds
preshift = cos_unshifted_coadd / coadd
shifted = cos_shifted_coadd / coadd

# Getting the data for our pre- and post-shifted coadd
with fits.open(preshift) as hdul:
    pre_wl = hdul[1].data["WAVELENGTH"].ravel()
    pre_flux = hdul[1].data["FLUX"].ravel()
    pre_snr = hdul[1].data["SNR"].ravel()

with fits.open(shifted) as hdul:
    shifted_wl = hdul[1].data["WAVELENGTH"].ravel()
    shifted_flux = hdul[1].data["FLUX"].ravel()
    shifted_snr = hdul[1].data["SNR"].ravel()

fig, ax = plt.subplots(2, 2, figsize=(14, 8))

# Interpolating flux and SNR arrays since difference shapes from pre-shifted
shifted_flux = np.interp(pre_wl, shifted_wl, shifted_flux)
shifted_snr = np.interp(pre_wl, shifted_wl, shifted_snr)

# Plotting flux vs wavelength
ax[0][0].plot(
    pre_wl,
    pre_flux,
    label="Unshifted",
    lw=2,
    alpha=0.6,
    color="red"
)

ax[0][0].plot(
    pre_wl,
    shifted_flux,
    label="Shifted",
    lw=2,
    alpha=0.6,
    color="blue"
)

# Plotting SNR vs wavelength
ax[0][1].plot(
    pre_wl,
    pre_snr,
    label="Unshifted",
    lw=2,
    alpha=0.6,
    color="red"
)

ax[0][1].plot(
    pre_wl,
    shifted_snr,
    label="Shifted",
    lw=2,
    alpha=0.6,
    color="blue"
)

# Plotting flux residuals
ax[1][0].plot(
    pre_wl,
    shifted_flux-pre_flux,
    lw=2,
    color="black",
    alpha=0.8
)

# Plotting snr residuals
ax[1][1].plot(
    pre_wl,
    shifted_snr-pre_snr,
    lw=2,
    color="black",
    alpha=0.8
)

for subplot in ax.ravel():
    subplot.set_xlabel(r'Wavelength [$\AA$]')
    subplot.legend()

ax[0][0].set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')
ax[1][0].set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

ax[0][1].set_ylabel(r'SNR')
ax[1][1].set_ylabel(r'SNR')

ax[0][0].set_title("Flux vs Wavelength, Unshifted and Shifted",
                   fontweight="bold")
ax[1][0].set_title("Flux Residuals",
                   fontweight="bold")

ax[0][1].set_title("SNR vs Wavelength, Unshifted and Shifted",
                   fontweight="bold")
ax[1][1].set_title("SNR Residuals",
                   fontweight="bold")

plt.tight_layout()

plt.show()
/tmp/ipykernel_2061/3098637481.py:82: UserWarning: No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.
  subplot.legend()
../../../_images/eb66f80d9ec35f2aa821fd789a79284752b67a517a5ff6174c9ee6a7d06f1a48.png

While you won’t necessarily see a big improvement in the SNR with a shift, we will see that our coadd has a better wavelength solution by calculating the radial velocity below:

new_coadd = cos_shifted_coadd / "hst_15824_cos_lmc079-1_g160m_le27_cspec.fits"

with fits.open(new_coadd) as hdul:
    data_new_coadd = hdul[1].data
    wl_new_coadd = data_new_coadd["WAVELENGTH"].ravel()
    flux_new_coadd = data_new_coadd["FLUX"].ravel()

# Getting the indicies within the wavelength range
indicies = np.where((wl_new_coadd >= 1525.) & (wl_new_coadd <= 1525.75))

trimmed_flux = flux_new_coadd[indicies]
trimmed_wl = wl_new_coadd[indicies]

# We need to make an initial guess for the parameter values
# The array is in form [PEAK OF GAUSSIAN, CENTRAL WAVELENGTH, WIDTH OF LINE]
p0 = [-0.58e-13, 1526.63, 0.12]

popt, _ = optimize.curve_fit(fit_gaussian,
                             trimmed_wl,
                             trimmed_flux,
                             p0)

print(f"The SiII peak is fitted to be {np.round(popt[1], 3)} Å")

# Plotting the absorption feature of the HLSP with our fit
plt.figure(figsize=(8, 6))

# Plotting the actual data
plt.plot(
    wl_new_coadd,
    flux_new_coadd,
    label="Coadd Data"
)

# Plotting our fit
plt.plot(
    wl_new_coadd,
    fit_gaussian(wl_new_coadd, *popt),
    label="Model Fit",
    color="red",
    alpha=0.6
)

# Adding vertical lines to show fitted "peak"
plt.axvline(popt[1],
            label='Coadd Model\'s Peak',
            color="black",
            linestyle="dotted")

# Adding vertical line to show observed wl of HLSP
plt.axvline(popt_hlsp[1],
            label='HLSP Model\'s Peak',
            color="red",
            linestyle="dashed")

plt.xlim(wavelength_range[1])
plt.legend()

plt.xlabel(r'Wavelength [$\AA$]')
plt.ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

plt.title("Coadd of LMC079-1 with Modeled Fit",
          fontweight="bold")

plt.show()

# Getting the observed wavelength of our HLSP
observed_wavelength = popt[1]

v_r = c * ((observed_wavelength - rest_wavelength) / rest_wavelength)
v_r = np.round(v_r, 2)

print(f"The radial velocity of LMC079-1 using the coadd is roughly {v_r} km/s")
The SiII peak is fitted to be 1526.63 Å
/tmp/ipykernel_2061/3490721434.py:18: OptimizeWarning: Covariance of the parameters could not be estimated
  popt, _ = optimize.curve_fit(fit_gaussian,
../../../_images/9fcd11b23b91b95cea04399c691537f6cee62a0ff247f7bdb8e5d87b1c40afd2.png
The radial velocity of LMC079-1 using the coadd is roughly -15.67 km/s

The radial velocity of the coadd created with the shifted X1D files (-15.67 km/s) is a lot closer to the HLSP’s radial velocity (-17.78 km/s) compared to the radial velocity of the pre-shifted coadd (-3.5 km/s). We can now move on to the STIS example.

2. Performing Wavelength Adjustments on STIS Data#

At the beginning of a science exposure, two Pt-Cr/Ne line lamps are flashed to obtain wavelength calibration exposures and assign a zero-point for the wavelength scale. These wavecals are taken at the beginning of virtually every exposure and are automatically taken at each 2300sec interval thereafter. Similar to COS, shifts between exposures can occur due to imperfect target acquisitions, repositioning of the grating, and thermal flexure. In these instances, users will need to manually shift their spectra to ensure the correct wavelength and flux calibrations are being performed. Echelle data and low-resolution spectra are suspectable to rapid sensitivity changes with wavelength, which makes accurate wavelength solutions even more important. Information about STIS wavelength accuracies can be found in Chapter 4.2 of the STIS Instrument Handbook.

We will be shifting data taken with the STIS/CCD, using the 52X2 aperture. There is a small pixel shift between data taken at the nominal position and data taken at the E1 pseudo-aperture position for this STIS mode (mentioned in Joyce 2018). We will download our data using astroquery, run the HASP script, cross-correlate the spectra in the dataset to the brightest observation to calculate the wavelength shift, and then apply this shift using CalSTIS.

Note: many of the cross-correlation steps outlined in this notebook are detailed in the STIS Cross-Correlation Jupyter Notebook

2.1 Downloading and Organizing STIS Data using Astroquery#

We will be downloading STIS/CCD G430L data for the object, AGK+81D266, a spectrophotometric target taken in Program 14423. Let’s create a few directories for our investigation:

# To hold all of our STIS example's output and data
stis_ex = Path("./stis_ex")

# To contain the raw files necessary to run CalSTIS
stis_data = Path("./stis_ex/stis_data/")

# To hold the unshifted data products and coadds
stis_unshifted = Path("./stis_ex/stis_unshifted/")
stis_unshifted_coadd = Path("./stis_ex/stis_unshifted/coadd/")

# To contain the shifted data products and coadds
stis_shifted = Path("./stis_ex/stis_shifted/")
stis_shifted_coadd = Path("./stis_ex/stis_shifted/coadd/")

# If the directory doesn't exist then create it
stis_ex.mkdir(exist_ok=True)

stis_data.mkdir(exist_ok=True)

stis_unshifted.mkdir(exist_ok=True)
stis_unshifted_coadd.mkdir(exist_ok=True)

stis_shifted.mkdir(exist_ok=True)
stis_shifted_coadd.mkdir(exist_ok=True)

We can use astroquery to query our datasets, get a list of associated products, and download the data to our ./stis_data directory. This is similar to how we downloaded the COS data in the previous example.

# Querying our datasets
stis_query = Observations.query_criteria(
    proposal_id=14423,
    instrument_name="STIS/CCD",
    filters="G430L",
    target_name="AGK+81D266"
)

# Getting the list of products for our datasets
stis_prodlist = Observations.get_product_list(
    stis_query
)

# Some of the files aren't coadded by default because POSTARG != 0
# We won't download these to save memory space
bad_obsids = [
    "od1am1090",
    "od1am10a0",
    "od1am10c0",
    "od1am10d0",
    "od1am10f0"
]

stis_prodlist = stis_prodlist[~np.isin(stis_prodlist["obs_id"], bad_obsids)]

# Filtering the product list to only get the required files
stis_prodlist = Observations.filter_products(
    stis_prodlist,
    productSubGroupDescription=["SX1", "RAW", "ASN", "FLT"]
)

# Downloading them to ./stis_data
Observations.download_products(
    stis_prodlist,
    download_dir=str(stis_data),
)

# Moving all sub-folders to stis_data and deleting mastDownload folder
consolidate_files(stis_data)

# Moving all sx1 to stis_unshifted
for file in stis_data.glob("*sx1.fits*"):
    # New path for file
    newpath = stis_unshifted / fits.getval(file, 'FILENAME')

    # Moving the actual file
    shutil.move(file, newpath)
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al1030_asn.fits to stis_ex/stis_data/mastDownload/HST/od1al1030/od1al1030_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al1030_flt.fits to stis_ex/stis_data/mastDownload/HST/od1al1030/od1al1030_flt.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al1030_raw.fits to stis_ex/stis_data/mastDownload/HST/od1al1030/od1al1030_raw.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al1030_sx1.fits to stis_ex/stis_data/mastDownload/HST/od1al1030/od1al1030_sx1.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al1040_asn.fits to stis_ex/stis_data/mastDownload/HST/od1al1040/od1al1040_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al1040_flt.fits to stis_ex/stis_data/mastDownload/HST/od1al1040/od1al1040_flt.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al1040_raw.fits to stis_ex/stis_data/mastDownload/HST/od1al1040/od1al1040_raw.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al1040_sx1.fits to stis_ex/stis_data/mastDownload/HST/od1al1040/od1al1040_sx1.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al2030_asn.fits to stis_ex/stis_data/mastDownload/HST/od1al2030/od1al2030_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al2030_flt.fits to stis_ex/stis_data/mastDownload/HST/od1al2030/od1al2030_flt.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al2030_raw.fits to stis_ex/stis_data/mastDownload/HST/od1al2030/od1al2030_raw.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al2030_sx1.fits to stis_ex/stis_data/mastDownload/HST/od1al2030/od1al2030_sx1.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al2040_asn.fits to stis_ex/stis_data/mastDownload/HST/od1al2040/od1al2040_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al2040_flt.fits to stis_ex/stis_data/mastDownload/HST/od1al2040/od1al2040_flt.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al2040_raw.fits to stis_ex/stis_data/mastDownload/HST/od1al2040/od1al2040_raw.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al2040_sx1.fits to stis_ex/stis_data/mastDownload/HST/od1al2040/od1al2040_sx1.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al4030_asn.fits to stis_ex/stis_data/mastDownload/HST/od1al4030/od1al4030_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al4030_flt.fits to stis_ex/stis_data/mastDownload/HST/od1al4030/od1al4030_flt.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al4030_raw.fits to stis_ex/stis_data/mastDownload/HST/od1al4030/od1al4030_raw.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al4030_sx1.fits to stis_ex/stis_data/mastDownload/HST/od1al4030/od1al4030_sx1.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al4040_asn.fits to stis_ex/stis_data/mastDownload/HST/od1al4040/od1al4040_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al4040_flt.fits to stis_ex/stis_data/mastDownload/HST/od1al4040/od1al4040_flt.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al4040_raw.fits to stis_ex/stis_data/mastDownload/HST/od1al4040/od1al4040_raw.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1al4040_sx1.fits to stis_ex/stis_data/mastDownload/HST/od1al4040/od1al4040_sx1.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1am10b0_asn.fits to stis_ex/stis_data/mastDownload/HST/od1am10b0/od1am10b0_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1am10b0_flt.fits to stis_ex/stis_data/mastDownload/HST/od1am10b0/od1am10b0_flt.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1am10b0_raw.fits to stis_ex/stis_data/mastDownload/HST/od1am10b0/od1am10b0_raw.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1am10b0_sx1.fits to stis_ex/stis_data/mastDownload/HST/od1am10b0/od1am10b0_sx1.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1am10e0_asn.fits to stis_ex/stis_data/mastDownload/HST/od1am10e0/od1am10e0_asn.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1am10e0_flt.fits to stis_ex/stis_data/mastDownload/HST/od1am10e0/od1am10e0_flt.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1am10e0_raw.fits to stis_ex/stis_data/mastDownload/HST/od1am10e0/od1am10e0_raw.fits ...
 [Done]
Downloading URL https://mast.stsci.edu/api/v0.1/Download/file?uri=mast:HST/product/od1am10e0_sx1.fits to stis_ex/stis_data/mastDownload/HST/od1am10e0/od1am10e0_sx1.fits ...
 [Done]

Now we will go and download the reference files needed for running CalSTIS:

# We will set the CRDS_PATH environment_variable
# Creating path to where the files are saved
crds_path = os.path.join(os.environ["HOME"], "crds_cache")

# Setting the environment variable CRDS_PATH to our CRDS path
os.environ["CRDS_PATH"] = crds_path

# URL for the STScI CRDS page
crds_server_url = "https://hst-crds.stsci.edu"

# Setting env variable to URL
os.environ["CRDS_SERVER_URL"] = crds_server_url

# Set the oref environment variable (STIS)
oref = os.path.join(crds_path, "references/hst/stis/")
os.environ["oref"] = oref

!crds bestrefs --update-bestrefs --sync-references=1 --files ./stis_ex/stis_data/*_raw.fits
clear_output()

2.2 Running the HASP Script on STIS Data#

Now that we have our data downloaded, we can run the coadd script and create abutted products. Check out our CoaddTutorial.ipynb notebook for a more detailed look as to how to run the script and change the flag parameters.

!swrapper -i ./stis_ex/stis_unshifted -o ./stis_ex/stis_unshifted/coadd
HASP version 1.0
Ullyses version 4.1.0
Creating list of unique modes from these files:
./stis_ex/stis_unshifted/od1al1030_sx1.fits AGK+81D266 STIS CCD G430L 52X2 14423 (14423, 'l1')
./stis_ex/stis_unshifted/od1al1040_sx1.fits AGK+81D266 STIS CCD G430L 52X2E1 14423 (14423, 'l1')
./stis_ex/stis_unshifted/od1al2030_sx1.fits AGK+81D266 STIS CCD G430L 52X2 14423 (14423, 'l2')
./stis_ex/stis_unshifted/od1al2040_sx1.fits AGK+81D266 STIS CCD G430L 52X2E1 14423 (14423, 'l2')
./stis_ex/stis_unshifted/od1al4030_sx1.fits AGK+81D266 STIS CCD G430L 52X2 14423 (14423, 'l4')
./stis_ex/stis_unshifted/od1al4040_sx1.fits AGK+81D266 STIS CCD G430L 52X2E1 14423 (14423, 'l4')
./stis_ex/stis_unshifted/od1am10b0_sx1.fits AGK+81D266 STIS CCD G430L 52X2 14423 (14423, 'm1')
./stis_ex/stis_unshifted/od1am10e0_sx1.fits AGK+81D266 STIS CCD G430L 52X2E1 14423 (14423, 'm1')
Looping over visits
Processing product (14423, 'l1')
Targets in visit (14423, 'l1'): ['AGK+81D266']
Processing target AGK+81D266 in visit (14423, 'l1')
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_unshifted/od1al1030_sx1.fits', './stis_ex/stis_unshifted/od1al1040_sx1.fits']
Processing file ./stis_ex/stis_unshifted/od1al1030_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1al1040_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
WARNING: VerifyWarning: Card is too long, comment will be truncated. [astropy.io.fits.card]
   Wrote ./stis_ex/stis_unshifted/coadd/hst_14423_stis_agkp81d266_g430l_od1al1_cspec.fits
No need to create abutted product as < 2 single grating products
Processing product (14423, 'l2')
Targets in visit (14423, 'l2'): ['AGK+81D266']
Processing target AGK+81D266 in visit (14423, 'l2')
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_unshifted/od1al2030_sx1.fits', './stis_ex/stis_unshifted/od1al2040_sx1.fits']
Processing file ./stis_ex/stis_unshifted/od1al2030_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1al2040_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./stis_ex/stis_unshifted/coadd/hst_14423_stis_agkp81d266_g430l_od1al2_cspec.fits
No need to create abutted product as < 2 single grating products
Processing product (14423, 'l4')
Targets in visit (14423, 'l4'): ['AGK+81D266']
Processing target AGK+81D266 in visit (14423, 'l4')
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_unshifted/od1al4030_sx1.fits', './stis_ex/stis_unshifted/od1al4040_sx1.fits']
Processing file ./stis_ex/stis_unshifted/od1al4030_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1al4040_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./stis_ex/stis_unshifted/coadd/hst_14423_stis_agkp81d266_g430l_od1al4_cspec.fits
No need to create abutted product as < 2 single grating products
Processing product (14423, 'm1')
Targets in visit (14423, 'm1'): ['AGK+81D266']
Processing target AGK+81D266 in visit (14423, 'm1')
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_unshifted/od1am10b0_sx1.fits', './stis_ex/stis_unshifted/od1am10e0_sx1.fits']
Processing file ./stis_ex/stis_unshifted/od1am10b0_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1am10e0_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./stis_ex/stis_unshifted/coadd/hst_14423_stis_agkp81d266_g430l_od1am1_cspec.fits
No need to create abutted product as < 2 single grating products
Looping over proposals
Processing product 14423
Targets in proposal 14423: ['AGK+81D266']
Processing target AGK+81D266 in proposal 14423
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_unshifted/od1al1030_sx1.fits', './stis_ex/stis_unshifted/od1al1040_sx1.fits', './stis_ex/stis_unshifted/od1al2030_sx1.fits', './stis_ex/stis_unshifted/od1al2040_sx1.fits', './stis_ex/stis_unshifted/od1al4030_sx1.fits', './stis_ex/stis_unshifted/od1al4040_sx1.fits', './stis_ex/stis_unshifted/od1am10b0_sx1.fits', './stis_ex/stis_unshifted/od1am10e0_sx1.fits']
Processing file ./stis_ex/stis_unshifted/od1al1030_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1al1040_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1al2030_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1al2040_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1al4030_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1al4040_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1am10b0_sx1.fits
Processing file ./stis_ex/stis_unshifted/od1am10e0_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./stis_ex/stis_unshifted/coadd/hst_14423_stis_agkp81d266_g430l_od1a_cspec.fits
Making a product from these gratings
STIS/G430L 2895.9-5704.4 (Actual: 2969.5-5702.7)
Transition wavelengths tweaked
Starting at the short wavelength end with grating STIS/G430L
Truncating current grating at 5702.705595657229
./stis_ex/stis_unshifted/coadd/hst_14423_stis_agkp81d266_g430l_od1a_cspec.fits already exists and overwrite=False, skipping write
   Wrote ./stis_ex/stis_unshifted/coadd/hst_14423_stis_agkp81d266_g430l_od1a_cspec.fits

We will plot the coadd over our current SX1 files; the aperture used is also listed in the legend. Observations that were taken at the E1 position have the value 52X2E1 for the PROPAPER header keyword (and are dotted on the plot), whereas observations taken at the nominal position have the value 52X2. Notice the area around 4860Å in the second plot shows a visible shift between datasets taken at the nominal and E1 positions.

coadd_stis = "hst_14423_stis_agkp81d266_g430l_od1a_cspec.fits"

# A list of the SX1 files for our data
sx1s = list(stis_unshifted.glob("*sx1*"))

# Creating a figure with two subplots
fig, ax = plt.subplots(2, 1, figsize=(14, 12))

for curr_plot in ax:
    # Plotting each SX1 file
    for file in sx1s:
        with fits.open(file) as hdul:
            wl = hdul[1].data["WAVELENGTH"].ravel()
            flux = hdul[1].data["FLUX"].ravel()

            aperture = hdul[0].header['PROPAPER']

            # Differentiating between nominal and E1 position via linestyle
            if aperture == "52X2":
                linestyle = "solid"
                label = f"{hdul[0].header['ROOTNAME']} - nom."
            else:
                linestyle = "dotted"
                label = f"{hdul[0].header['ROOTNAME']} - E1"

            # Plotting the actual data
            curr_plot.plot(wl, flux,
                           label=label,
                           alpha=0.75,
                           lw=2,
                           linestyle=linestyle)

    # Plotting the coadd in black
    with fits.open(stis_unshifted_coadd / coadd_stis) as hdul:
        wl = hdul[1].data["WAVELENGTH"].ravel()
        flux = hdul[1].data["FLUX"].ravel()

        curr_plot.plot(wl, flux,
                       label="Coadd",
                       alpha=0.75,
                       color="black",
                       lw=2)

# Adding labels, formatting, xlim
plt.suptitle("SX1 Files against Coadd - AGK+81D266")
plt.xlabel(r'Wavelength [$\AA$]')
ax[0].set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')
ax[1].set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')

ax[1].set_xlim(4825, 4900)
ax[1].set_ylim(0.4e-13, 1.5e-13)

ax[0].legend()

plt.tight_layout()

plt.show()
../../../_images/3634bad98cef2a22c21c8c409b1c4fb4b0c97a12e8d7c36a8b0fbdb7f5870a2a.png

Since we see a consistent shift in the data between the observations that used the E1 aperture and the nominal, we need to determine the actual shift in pixels and re-run CalSTIS on our data. We will not be calculating the radial velocity and comparing it to the literature value to reduce notebook length, and because the shift is known to be relative to the nominal position.

2.3 Performing Cross-Correlation on STIS data and Calculating Lag#

There are multiple ways to determine the best observation to set as the reference, and that is up to the user to do so. Since we are shifting all the E1 observations to the nominal positions, we will use the brightest nominal observation as our reference. We are using the brightest because we are making the assumption that it is the observation most centered in the aperture, but you will need to use other methods when determining the file to reference to. Let’s determine the brightest nominal file below:

# A variable for the brightest filename, arbitrarily
ref_file = sx1s[0]

for file in sx1s:
    # Getting flux data for current interation's file + current brightest file
    with fits.open(file) as hdul:
        curr_flux = hdul[1].data["FLUX"].ravel()
        aperture = hdul[0].header["PROPAPER"]

    with fits.open(ref_file) as ref_hdul:
        ref_flux = ref_hdul[1].data["FLUX"].ravel()

    # If current file's mean flux > ref file, replace ref file
    if ((np.mean(curr_flux) > np.mean(ref_flux)) & (aperture == "52X2")):
        ref_file = file

    else:
        continue

# Printing out our file
print(f"The brightest file is {ref_file.name}.")
The brightest file is od1al2030_sx1.fits.

We’ve now determined that od1al2030_sx1.fits is the brightest spectra of our data. We will go through each SX1 file taken at the E1 position in our data and cross-correlate it to our od1al2030_sx1.fits file. We will calculate the shifts for a single file first (to better illustrate each step), then define a function to perform these same steps for the rest of the files.

We will be cross-correlating similarly to how we did our COS example in the previous section, but this section will mainly follow the steps in the official STIS Cross-Correlation Notebook.

We will need to calculate the mean plate scale, i.e. the dispersion per pixel, for our reference dataset. This will be used to determine the shift in pixels later on in the tutorial.

# Getting a list of files taken at E1 position
e1_pos = [file for file in sx1s if fits.getval(file, "PROPAPER") != "52X2"]

# Example file
stis_file = e1_pos[0]

# Getting the data for the reference file
with fits.open(ref_file) as hdul:
    ref_wl = hdul[1].data["WAVELENGTH"].ravel()
    ref_flux = hdul[1].data["FLUX"].ravel()

with fits.open(stis_file) as hdul:
    ex_wl = hdul[1].data["WAVELENGTH"].ravel()
    ex_flux = hdul[1].data["FLUX"].ravel()

# Interpolating the example spectra
ex_flux = np.interp(ref_wl, ex_wl, ex_flux)

# Getting the dispersion per pixel
mean_plate_scale = np.mean(ref_wl[1:] - ref_wl[:-1])
print(f"The dispersion per pixel is {np.round(mean_plate_scale, 2)} Å/pixel")
The dispersion per pixel is 2.75 Å/pixel

Now we will use our cross-correlation function defined in the COS section to determine the lag and cross-correlation coefficient. We can determine the shift by getting the lag value with the highest corresponding cross-correlation coefficient. Our lags are discrete pixel integer values, so we will need to fit a quadratic curve using fitting and Polynomial1D from the astropy.modeling module. The lag at the maxima of our fit is the pixel shift that we will use when re-calibrating with CalSTIS.

Note: you will need to experiment with different fits when determining your lag; there is no single function that will work in all scenarios

# Calculating the lag and cc coeff using the earlier defined function
lag, cc = cross_correlate(ref_flux, ex_flux)

# Fitting a quadratic to the peak to find pixel shift
fitter = fitting.LinearLSQFitter()

# Getting the 8 points near the peak
width = 8

low, hi = np.argmax(cc) - width//2, np.argmax(cc) + width//2 + 1
fit = fitter(Polynomial1D(degree=2), x=lag[low:hi], y=cc[low:hi])

x_c = np.arange(np.min(lag), np.max(lag), 0.01)

# Determining the shift, in pixels
shift1 = -fit.parameters[1] / (2. * fit.parameters[2])

print(f"The shift, in pixels, is {np.round(shift1, 2)} pixels")
print(f"The shift, in angstroms, is {np.round(shift1*mean_plate_scale, 2)}Å")

plt.plot(
    lag,
    cc,
    lw=2,
    color="black"
)

plt.plot(
    x_c,
    fit(x_c),
    lw=2,
    label="Fitted Quadratic",
    alpha=0.6
)

plt.axvline(
    shift1,
    color="red",
    label="Maxima of fit"
)

# Adding title
plt.title("Lag (px) vs Cross Correlation Coeff, with fitted curve and ZOOMED",
          weight="bold")

plt.xlabel("Lag (px)")
plt.ylabel("Cross Correlation Coeff.")

plt.ylim(0.9, 1.05)
plt.xlim(shift1 - 25, shift1 + 25)

plt.legend()

plt.tight_layout()

plt.show()
The shift, in pixels, is 0.86 pixels
The shift, in angstroms, is 2.35Å
../../../_images/c9ba07662ce521d97703ae64570d42e2a8e2430d1150917f0784a78239222e22.png

2.4 Applying Shifts to Raw STIS data and Re-creating Coadd#

Now that we’ve calculated the shift, we need to alter the header keywords of our data and then re-calibrate the spectrum using CalSTIS. We will extract the SHIFTA1 and SHIFTA2 keywords from the corresponding FLT file, add our calculated shift value to the value of this keyword, then set the WAVECORR calibration switch in the RAW file to OMIT and re-run CalSTIS.

# Path to the FLT for our example file
flt_file = stis_data / f"{fits.getval(stis_file, 'ROOTNAME')}_flt.fits"

# Extracting the shift from the FLT file
SHIFTA1 = fits.getval(flt_file, "SHIFTA1", ext=1)
SHIFTA2 = fits.getval(flt_file, "SHIFTA2", ext=1)

# Update SHIFTA1 (spectral direction) to take into account the calculated shift
SHIFTA1 += shift1

# Path to the raw file
raw_file = stis_data / f"{fits.getval(stis_file, 'ROOTNAME')}_raw.fits"

# Updating the header to reflect updated shift + FLT SHIFTA2 value
fits.setval(raw_file, keyword="SHIFTA1", value=SHIFTA1, ext=1)
fits.setval(raw_file, keyword="SHIFTA2", value=SHIFTA2, ext=1)

# Set WAVECORR to OMIT since we're applying the shift
fits.setval(raw_file, "WAVECORR", value="OMIT", ext=0)

Now we can run CalSTIS:

try:
    stistools.calstis.calstis(str(raw_file),
                              outroot=str(stis_shifted))
    
except RuntimeError as e:
    print('An error occured', e)
*** CALSTIS-0 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:11 UTC

Input    stis_ex/stis_data/od1al2040_raw.fits
Outroot  stis_ex/stis_shifted

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:11 UTC
Input    stis_ex/stis_data/od1al2040_raw.fits
Output   stis_ex/stis_shifted_blv_tmp.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:11 UTC
Epcfile  od1al2yrj_epc.fits
Warning  EPCTAB `od1al2yrj_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  PERFORM
DQITAB   oref$h1v11475o_bpx.fits
DQITAB   PEDIGREE=GROUND
DQITAB   DESCRIP =Prel. Ground Calib
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1442.79.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASFILE oref$05314032o_bia.fits
BIASFILE PEDIGREE=INFLIGHT 27/03/2016 04/04/2016
BIASFILE DESCRIP =Weekly gain=1 bias for STIS CCD data taken after Mar 27 2016-------
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT

PHOTCORR OMIT
Imset 1  End 16:57:11 UTC

Imset 2  Begin 16:57:11 UTC
Epcfile  od1al2ysj_epc.fits
Warning  EPCTAB `od1al2ysj_epc.fits' not found.

DQICORR  PERFORM
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1444.06.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT
Imset 2  End 16:57:11 UTC

End      31-Dec-2024 16:57:11 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-2 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:11 UTC
Input    stis_ex/stis_shifted_blv_tmp.fits
Output   stis_ex/stis_shifted_crj_tmp.fits

CRCORR   PERFORM
Total number of input image sets = 2
CRREJTAB oref$j3m1403io_crr.fits
CRCORR   COMPLETE

End      31-Dec-2024 16:57:11 UTC

*** CALSTIS-2 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:11 UTC
Input    stis_ex/stis_shifted_crj_tmp.fits
Output   stis_ex/stis_shifted_crj.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:11 UTC
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$0531403co_drk.fits
DARKFILE PEDIGREE=INFLIGHT 27/03/2016 04/04/2016
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Mar 27 2016-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:11 UTC

End      31-Dec-2024 16:57:11 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:11 UTC
Input    stis_ex/stis_shifted_blv_tmp.fits
Output   stis_ex/stis_shifted_flt.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:11 UTC
Epcfile  od1al2yrj_epc.fits
Warning  EPCTAB `od1al2yrj_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$0531403co_drk.fits
DARKFILE PEDIGREE=INFLIGHT 27/03/2016 04/04/2016
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Mar 27 2016-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:11 UTC

Imset 2  Begin 16:57:11 UTC
Epcfile  od1al2ysj_epc.fits
Warning  EPCTAB `od1al2ysj_epc.fits' not found.

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKCORR COMPLETE

FLATCORR PERFORM
FLATCORR COMPLETE

SHADCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 2  End 16:57:11 UTC

End      31-Dec-2024 16:57:11 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-7 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:11 UTC
Input    stis_ex/stis_shifted_crj.fits
Output   stis_ex/stis_shifted_sx2.fits
OBSMODE  ACCUM
APERTURE 52X2E1
OPT_ELEM G430L
DETECTOR CCD
Imset 1  Begin 16:57:11 UTC
Warning  Wavecal processing has not been performed.

HELCORR  PERFORM
HELCORR  COMPLETE

Order 1  Begin 16:57:11 UTC

X2DCORR  PERFORM
DISPCORR PERFORM
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Offset relative to row 900
SDCTAB   oref$16j16006o_sdc.fits
SDCTAB   PEDIGREE=INFLIGHT 27/05/1997 13/06/2017
SDCTAB   DESCRIP =Co-aligned fiducial bars via an update to the CDELT2 plate scales.-
SDCTAB   DESCRIP =CDELT2 updated with inflight data, others Lindler/prelaunch
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
INANGTAB oref$h5s11397o_iac.fits
INANGTAB PEDIGREE=GROUND
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
INANGTAB DESCRIP =Model/C. Bowers
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time
SPTRCTAB DESCRIP =Lindler/Bohlin/Dressel/Holfeltz postlaunch calibration

FLUXCORR PERFORM
PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 14/04/1998
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
PHOTTAB  DESCRIP =Updated Sensitivities 2022
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/5/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
PCTAB    DESCRIP =12 STIS observations averaged
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR COMPLETE
X2DCORR  COMPLETE
DISPCORR COMPLETE
Order 1  End 16:57:11 UTC
Imset 1  End 16:57:11 UTC

End      31-Dec-2024 16:57:11 UTC

*** CALSTIS-7 complete ***

*** CALSTIS-6 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:11 UTC

INFO     'E1' has been appended to aperture
Input    stis_ex/stis_shifted_crj.fits
Output   stis_ex/stis_shifted_sx1.fits
Rootname od1al2040
OBSMODE  ACCUM
APERTURE 52X2E1
OPT_ELEM G430L
DETECTOR CCD

XTRACTAB oref$n7p1031qo_1dx.fits
XTRACTAB PEDIGREE=INFLIGHT 18/05/97
XTRACTAB DESCRIP =Analysis from prop. 7094
XTRACTAB DESCRIP =Analysis from prop. 7094
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 02/09/1997 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time

Imset 1  Begin 16:57:11 UTC
         Input read into memory.
Order 1  Begin 16:57:11 UTC
X1DCORR  PERFORM
BACKCORR PERFORM
******** Calling Slfit ***********BACKCORR COMPLETE
X1DCORR  COMPLETE
         Spectrum extracted at y position = 892.934

DISPCORR PERFORM
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Offset relative to row 900
INANGTAB oref$h5s11397o_iac.fits
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
DISPCORR COMPLETE

HELCORR  PERFORM
HELCORR  COMPLETE

PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 16/03/2021
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
GACTAB   oref$p9r19203o_gac.fits
GACTAB   PEDIGREE=INFLIGHT 03/04/2002 03/08/2004
GACTAB   DESCRIP =X1D flux corr for grating/aper combos
GACTAB   DESCRIP =Grating-Aperture Throughput Correction
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/05/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR PERFORM
CTECORR  PERFORM
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij
         GACTAB correction applied for G430L 52X2E1 4300
CTECORR  COMPLETE
FLUXCORR COMPLETE
SGEOCORR OMIT

         Row 1 written to disk.
Order 1  End 16:57:12 UTC

         trace was rotated by = 0.0508783 degree.
Imset 1  End 16:57:12 UTC

Warning  Keyword `XTRACALG' is being added to header.
End      31-Dec-2024 16:57:12 UTC

*** CALSTIS-6 complete ***

End      31-Dec-2024 16:57:12 UTC

*** CALSTIS-0 complete ***

We will now define a function to calculate and perform shifts on the rest of the E1 position datasets. We have three remaining files to shift, so we will define a function to calculate the fit, plot, and run CalSTIS.

Note that you will need to experiment with different fits/functions for your dataset.

def shift_stis(ref_file, stis_file, width, plot, run_calstis=False):
    '''
    Determing the shift, in pixels, between the file and the reference.
    Update the RAW file with the new shift and run CalSTIS.
    ----------
    Input:
    pathlib.Path or str ref_file : Path to the reference file
    pathlib.Path or str stis_file : Path to the file that needs to be shifted
    int width : Number points to fit at the peak of the function, must be > 2
    bool plot : Do you want to plot the cc function and the fit?
    bool run_calstis : True if you want to run CalSTIS on the shifted dataset
    '''
    # Getting the data for the reference file
    with fits.open(ref_file) as hdul:
        ref_wl = hdul[1].data["WAVELENGTH"].ravel()
        ref_flux = hdul[1].data["FLUX"].ravel()

    with fits.open(stis_file) as hdul:
        ex_wl = hdul[1].data["WAVELENGTH"].ravel()
        ex_flux = hdul[1].data["FLUX"].ravel()

    # Interpolating the example spectra
    ex_flux = np.interp(ref_wl, ex_wl, ex_flux)

    # Getting the dispersion per pixel
    mean_plate_scale = np.mean(ref_wl[1:] - ref_wl[:-1])

    print(f"Dispersion per pixel is {np.round(mean_plate_scale, 2)} Å/pixel")

    # Calculating the lag and cc coeff using the earlier defined function
    lag, cc = cross_correlate(ref_flux, ex_flux)

    # Fitting a quadratic to the peak to find pixel shift
    fitter = fitting.LinearLSQFitter()

    low, hi = np.argmax(cc) - width//2, np.argmax(cc) + width//2 + 1
    fit = fitter(Polynomial1D(degree=2), x=lag[low:hi], y=cc[low:hi])

    x_c = np.arange(np.min(lag), np.max(lag), 0.01)

    # Determining the shift, in pixels
    shift1 = -fit.parameters[1] / (2. * fit.parameters[2])

    print(f"The shift, in pixels, is {np.round(shift1, 2)} pixels")
    print(f"The shift, in Å, is {np.round(shift1*mean_plate_scale, 2)}Å")

    if plot:
        plt.plot(
            lag,
            cc,
            lw=2,
            color="black",
            alpha=0.8
        )

        plt.plot(
            x_c,
            fit(x_c),
            lw=2,
            label="Fitted Quadratic",
            alpha=0.6
        )

        plt.axvline(
            shift1,
            color="red",
            label="Maxima of fit"
        )

        # Adding title
        plt.title("Lag (px) vs Cross Correlation Coeff, with fitted curve",
                  weight="bold")

        plt.xlabel("Lag (px)")
        plt.ylabel("Cross Correlation Coeff.")

        plt.ylim(0.9, 1.05)
        plt.xlim(shift1 - 25, shift1 + 25)

        plt.legend()

        plt.tight_layout()

        plt.show()

    if run_calstis:
        # Path to the FLT for our example file
        flt_file = f"{stis_data}/{fits.getval(stis_file, 'ROOTNAME')}_flt.fits"

        # Extracting the shift from the FLT file
        SHIFTA1 = fits.getval(flt_file, "SHIFTA1", ext=1)
        SHIFTA2 = fits.getval(flt_file, "SHIFTA2", ext=1)

        # Update SHIFTA1 (spectral direction) to include the calculated shift
        SHIFTA1 += shift1

        # Path to the raw file
        raw_file = f"{stis_data}/{fits.getval(stis_file, 'ROOTNAME')}_raw.fits"

        # Updating the header to reflect updated shift + FLT SHIFTA2 value
        fits.setval(raw_file, keyword="SHIFTA1", value=SHIFTA1, ext=1)
        fits.setval(raw_file, keyword="SHIFTA2", value=SHIFTA2, ext=1)

        # Set WAVECORR to OMIT since we're applying the shift
        fits.setval(raw_file, "WAVECORR", value="OMIT", ext=0)

        stistools.calstis.calstis(raw_file,
                                  verbose=False,
                                  outroot=f"{str(stis_shifted)}/")

Let’s shift od1al4040_sx1.fits:

width = 7
try:
    shift_stis(ref_file, e1_pos[1], width, plot=False, run_calstis=True)
except RuntimeError as e:
    print('An error occured', e)
Dispersion per pixel is 2.75 Å/pixel
The shift, in pixels, is 0.49 pixels
The shift, in Å, is 1.34Å

*** CALSTIS-0 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:12 UTC

Input    stis_ex/stis_data/od1am10e0_raw.fits
Outroot  stis_ex/stis_shifted/od1am10e0_raw.fits

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:12 UTC
Input    stis_ex/stis_data/od1am10e0_raw.fits
Output   stis_ex/stis_shifted/od1am10e0_blv_tmp.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:12 UTC
Epcfile  od1am1hnj_epc.fits
Warning  EPCTAB `od1am1hnj_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  PERFORM
DQITAB   oref$h1v11475o_bpx.fits
DQITAB   PEDIGREE=GROUND
DQITAB   DESCRIP =Prel. Ground Calib
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1434.75.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASFILE oref$0531402qo_bia.fits
BIASFILE PEDIGREE=INFLIGHT 22/02/2016 01/03/2016
BIASFILE DESCRIP =Weekly gain=1 bias for STIS CCD data taken after Feb 22 2016-------
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT

PHOTCORR OMIT
Imset 1  End 16:57:12 UTC

Imset 2  Begin 16:57:12 UTC
Epcfile  od1am1hoj_epc.fits
Warning  EPCTAB `od1am1hoj_epc.fits' not found.

DQICORR  PERFORM
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1434.94.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT
Imset 2  End 16:57:12 UTC

End      31-Dec-2024 16:57:12 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-2 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:12 UTC
Input    stis_ex/stis_shifted/od1am10e0_blv_tmp.fits
Output   stis_ex/stis_shifted/od1am10e0_crj_tmp.fits

CRCORR   PERFORM
Total number of input image sets = 2
CRREJTAB oref$j3m1403io_crr.fits
CRCORR   COMPLETE

End      31-Dec-2024 16:57:12 UTC

*** CALSTIS-2 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:12 UTC
Input    stis_ex/stis_shifted/od1am10e0_crj_tmp.fits
Output   stis_ex/stis_shifted/od1am10e0_crj.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:12 UTC

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$05314034o_drk.fits
DARKFILE PEDIGREE=INFLIGHT 22/02/2016 01/03/2016
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Feb 22 2016-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:12 UTC

End      31-Dec-2024 16:57:12 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:12 UTC
Input    stis_ex/stis_shifted/od1am10e0_blv_tmp.fits
Output   stis_ex/stis_shifted/od1am10e0_flt.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:12 UTC
Epcfile  od1am1hnj_epc.fits
Warning  EPCTAB `od1am1hnj_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$05314034o_drk.fits
DARKFILE PEDIGREE=INFLIGHT 22/02/2016 01/03/2016
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Feb 22 2016-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:12 UTC

Imset 2  Begin 16:57:12 UTC
Epcfile  od1am1hoj_epc.fits
Warning  EPCTAB `od1am1hoj_epc.fits' not found.

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKCORR COMPLETE

FLATCORR PERFORM
FLATCORR COMPLETE

SHADCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 2  End 16:57:12 UTC

End      31-Dec-2024 16:57:12 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-7 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:12 UTC
Input    stis_ex/stis_shifted/od1am10e0_crj.fits
Output   stis_ex/stis_shifted/od1am10e0_sx2.fits
OBSMODE  ACCUM
APERTURE 52X2E1
OPT_ELEM G430L
DETECTOR CCD
Imset 1  Begin 16:57:12 UTC
Warning  Wavecal processing has not been performed.

HELCORR  PERFORM
HELCORR  COMPLETE
Order 1  Begin 16:57:12 UTC

X2DCORR  PERFORM
DISPCORR PERFORM
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Offset relative to row 900
SDCTAB   oref$16j16006o_sdc.fits
SDCTAB   PEDIGREE=INFLIGHT 27/05/1997 13/06/2017
SDCTAB   DESCRIP =Co-aligned fiducial bars via an update to the CDELT2 plate scales.-
SDCTAB   DESCRIP =CDELT2 updated with inflight data, others Lindler/prelaunch
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
INANGTAB oref$h5s11397o_iac.fits
INANGTAB PEDIGREE=GROUND
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
INANGTAB DESCRIP =Model/C. Bowers
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time
SPTRCTAB DESCRIP =Lindler/Bohlin/Dressel/Holfeltz postlaunch calibration

FLUXCORR PERFORM
PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 14/04/1998
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
PHOTTAB  DESCRIP =Updated Sensitivities 2022
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/5/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
PCTAB    DESCRIP =12 STIS observations averaged
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR COMPLETE
X2DCORR  COMPLETE
DISPCORR COMPLETE
Order 1  End 16:57:12 UTC
Imset 1  End 16:57:12 UTC

End      31-Dec-2024 16:57:12 UTC

*** CALSTIS-7 complete ***

*** CALSTIS-6 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:12 UTC

INFO     'E1' has been appended to aperture
Input    stis_ex/stis_shifted/od1am10e0_crj.fits
Output   stis_ex/stis_shifted/od1am10e0_sx1.fits
Rootname od1am10e0
OBSMODE  ACCUM
APERTURE 52X2E1
OPT_ELEM G430L
DETECTOR CCD

XTRACTAB oref$n7p1031qo_1dx.fits
XTRACTAB PEDIGREE=INFLIGHT 18/05/97
XTRACTAB DESCRIP =Analysis from prop. 7094
XTRACTAB DESCRIP =Analysis from prop. 7094
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 02/09/1997 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time

Imset 1  Begin 16:57:13 UTC
         Input read into memory.
Order 1  Begin 16:57:13 UTC
X1DCORR  PERFORM
BACKCORR PERFORM
******** Calling Slfit ***********BACKCORR COMPLETE
X1DCORR  COMPLETE
         Spectrum extracted at y position = 892.867

DISPCORR PERFORM
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Offset relative to row 900
INANGTAB oref$h5s11397o_iac.fits
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
DISPCORR COMPLETE

HELCORR  PERFORM
HELCORR  COMPLETE

PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 16/03/2021
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
GACTAB   oref$p9r19203o_gac.fits
GACTAB   PEDIGREE=INFLIGHT 03/04/2002 03/08/2004
GACTAB   DESCRIP =X1D flux corr for grating/aper combos
GACTAB   DESCRIP =Grating-Aperture Throughput Correction
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/05/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR PERFORM
CTECORR  PERFORM
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij
         GACTAB correction applied for G430L 52X2E1 4300
CTECORR  COMPLETE
FLUXCORR COMPLETE
SGEOCORR OMIT

         Row 1 written to disk.
Order 1  End 16:57:13 UTC

         trace was rotated by = 0.050452 degree.
Imset 1  End 16:57:13 UTC

Warning  Keyword `XTRACALG' is being added to header.
End      31-Dec-2024 16:57:13 UTC

*** CALSTIS-6 complete ***

End      31-Dec-2024 16:57:13 UTC

*** CALSTIS-0 complete ***

Now od1am10e0_sx1.fits:

width = 9
try:
    shift_stis(ref_file, e1_pos[2], width, plot=False, run_calstis=True)
except RuntimeError as e:
    print('An error occured', e)
Dispersion per pixel is 2.75 Å/pixel
The shift, in pixels, is 1.17 pixels
The shift, in Å, is 3.21Å
*** CALSTIS-0 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:13 UTC

Input    stis_ex/stis_data/od1al1040_raw.fits
Outroot  stis_ex/stis_shifted/od1al1040_raw.fits

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:13 UTC
Input    stis_ex/stis_data/od1al1040_raw.fits
Output   stis_ex/stis_shifted/od1al1040_blv_tmp.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:13 UTC
Epcfile  od1al1b1j_epc.fits
Warning  EPCTAB `od1al1b1j_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  PERFORM
DQITAB   oref$h1v11475o_bpx.fits
DQITAB   PEDIGREE=GROUND
DQITAB   DESCRIP =Prel. Ground Calib
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1450.05.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASFILE oref$02a1919to_bia.fits
BIASFILE PEDIGREE=INFLIGHT 08/11/2015 16/11/2015
BIASFILE DESCRIP =Weekly gain=1 bias for STIS CCD data taken after Nov 08 2015-------
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT

PHOTCORR OMIT
Imset 1  End 16:57:13 UTC

Imset 2  Begin 16:57:13 UTC
Epcfile  od1al1b2j_epc.fits
Warning  EPCTAB `od1al1b2j_epc.fits' not found.

DQICORR  PERFORM
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1451.58.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT
Imset 2  End 16:57:13 UTC

End      31-Dec-2024 16:57:13 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-2 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:13 UTC
Input    stis_ex/stis_shifted/od1al1040_blv_tmp.fits
Output   stis_ex/stis_shifted/od1al1040_crj_tmp.fits

CRCORR   PERFORM
Total number of input image sets = 2
CRREJTAB oref$j3m1403io_crr.fits
CRCORR   COMPLETE

End      31-Dec-2024 16:57:13 UTC

*** CALSTIS-2 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:13 UTC
Input    stis_ex/stis_shifted/od1al1040_crj_tmp.fits
Output   stis_ex/stis_shifted/od1al1040_crj.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:13 UTC
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$02a1920ao_drk.fits
DARKFILE PEDIGREE=INFLIGHT 07/11/2015 16/11/2015
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Nov 07 2015-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:13 UTC

End      31-Dec-2024 16:57:13 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:13 UTC
Input    stis_ex/stis_shifted/od1al1040_blv_tmp.fits
Output   stis_ex/stis_shifted/od1al1040_flt.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:13 UTC
Epcfile  od1al1b1j_epc.fits
Warning  EPCTAB `od1al1b1j_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$02a1920ao_drk.fits
DARKFILE PEDIGREE=INFLIGHT 07/11/2015 16/11/2015
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Nov 07 2015-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:13 UTC

Imset 2  Begin 16:57:13 UTC
Epcfile  od1al1b2j_epc.fits
Warning  EPCTAB `od1al1b2j_epc.fits' not found.

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKCORR COMPLETE

FLATCORR PERFORM
FLATCORR COMPLETE

SHADCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 2  End 16:57:13 UTC

End      31-Dec-2024 16:57:13 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-7 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:13 UTC
Input    stis_ex/stis_shifted/od1al1040_crj.fits
Output   stis_ex/stis_shifted/od1al1040_sx2.fits
OBSMODE  ACCUM
APERTURE 52X2E1
OPT_ELEM G430L
DETECTOR CCD
Imset 1  Begin 16:57:13 UTC
Warning  Wavecal processing has not been performed.

HELCORR  PERFORM
HELCORR  COMPLETE

Order 1  Begin 16:57:13 UTC
X2DCORR  PERFORM
DISPCORR PERFORM
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Offset relative to row 900
SDCTAB   oref$16j16006o_sdc.fits
SDCTAB   PEDIGREE=INFLIGHT 27/05/1997 13/06/2017
SDCTAB   DESCRIP =Co-aligned fiducial bars via an update to the CDELT2 plate scales.-
SDCTAB   DESCRIP =CDELT2 updated with inflight data, others Lindler/prelaunch
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
INANGTAB oref$h5s11397o_iac.fits
INANGTAB PEDIGREE=GROUND
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
INANGTAB DESCRIP =Model/C. Bowers
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time
SPTRCTAB DESCRIP =Lindler/Bohlin/Dressel/Holfeltz postlaunch calibration

FLUXCORR PERFORM
PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 14/04/1998
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
PHOTTAB  DESCRIP =Updated Sensitivities 2022
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/5/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
PCTAB    DESCRIP =12 STIS observations averaged
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR COMPLETE
X2DCORR  COMPLETE
DISPCORR COMPLETE
Order 1  End 16:57:13 UTC
Imset 1  End 16:57:13 UTC

End      31-Dec-2024 16:57:13 UTC

*** CALSTIS-7 complete ***

*** CALSTIS-6 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:13 UTC

INFO     'E1' has been appended to aperture
Input    stis_ex/stis_shifted/od1al1040_crj.fits
Output   stis_ex/stis_shifted/od1al1040_sx1.fits
Rootname od1al1040
OBSMODE  ACCUM
APERTURE 52X2E1
OPT_ELEM G430L
DETECTOR CCD

XTRACTAB oref$n7p1031qo_1dx.fits
XTRACTAB PEDIGREE=INFLIGHT 18/05/97
XTRACTAB DESCRIP =Analysis from prop. 7094
XTRACTAB DESCRIP =Analysis from prop. 7094
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 02/09/1997 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time

Imset 1  Begin 16:57:14 UTC
         Input read into memory.
Order 1  Begin 16:57:14 UTC
X1DCORR  PERFORM
BACKCORR PERFORM
******** Calling Slfit ***********BACKCORR COMPLETE
X1DCORR  COMPLETE
         Spectrum extracted at y position = 892.684

DISPCORR PERFORM
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Offset relative to row 900
INANGTAB oref$h5s11397o_iac.fits
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
DISPCORR COMPLETE

HELCORR  PERFORM
HELCORR  COMPLETE

PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 16/03/2021
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
GACTAB   oref$p9r19203o_gac.fits
GACTAB   PEDIGREE=INFLIGHT 03/04/2002 03/08/2004
GACTAB   DESCRIP =X1D flux corr for grating/aper combos
GACTAB   DESCRIP =Grating-Aperture Throughput Correction
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/05/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR PERFORM
CTECORR  PERFORM
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij
         GACTAB correction applied for G430L 52X2E1 4300
CTECORR  COMPLETE
FLUXCORR COMPLETE
SGEOCORR OMIT

         Row 1 written to disk.
Order 1  End 16:57:14 UTC

         trace was rotated by = 0.0493412 degree.
Imset 1  End 16:57:14 UTC

Warning  Keyword `XTRACALG' is being added to header.
End      31-Dec-2024 16:57:14 UTC

*** CALSTIS-6 complete ***

End      31-Dec-2024 16:57:14 UTC

*** CALSTIS-0 complete ***

And finally, od1al1040_sx1.fits:

width = 7
try:
    shift_stis(ref_file, e1_pos[3], width, plot=False, run_calstis=True)
except RuntimeError as e:
    print('An error occured', e)
Dispersion per pixel is 2.75 Å/pixel
The shift, in pixels, is 0.76 pixels
The shift, in Å, is 2.1Å
*** CALSTIS-0 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:14 UTC

Input    stis_ex/stis_data/od1al4040_raw.fits
Outroot  stis_ex/stis_shifted/od1al4040_raw.fits

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:14 UTC
Input    stis_ex/stis_data/od1al4040_raw.fits
Output   stis_ex/stis_shifted/od1al4040_blv_tmp.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:14 UTC
Epcfile  od1al4axj_epc.fits
Warning  EPCTAB `od1al4axj_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  PERFORM
DQITAB   oref$h1v11475o_bpx.fits
DQITAB   PEDIGREE=GROUND
DQITAB   DESCRIP =Prel. Ground Calib
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1451.76.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASFILE oref$09k14502o_bia.fits
BIASFILE PEDIGREE=INFLIGHT 18/08/2016 25/08/2016
BIASFILE DESCRIP =Weekly gain=1 bias for STIS CCD data taken after Aug 18 2016-------
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT

PHOTCORR OMIT
Imset 1  End 16:57:14 UTC

Imset 2  Begin 16:57:14 UTC
Epcfile  od1al4ayj_epc.fits
Warning  EPCTAB `od1al4ayj_epc.fits' not found.

DQICORR  PERFORM
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1454.25.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT
Imset 2  End 16:57:14 UTC

End      31-Dec-2024 16:57:14 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-2 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:14 UTC
Input    stis_ex/stis_shifted/od1al4040_blv_tmp.fits
Output   stis_ex/stis_shifted/od1al4040_crj_tmp.fits

CRCORR   PERFORM
Total number of input image sets = 2
CRREJTAB oref$j3m1403io_crr.fits
CRCORR   COMPLETE

End      31-Dec-2024 16:57:14 UTC

*** CALSTIS-2 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:14 UTC
Input    stis_ex/stis_shifted/od1al4040_crj_tmp.fits
Output   stis_ex/stis_shifted/od1al4040_crj.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:14 UTC
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$09k14506o_drk.fits
DARKFILE PEDIGREE=INFLIGHT 18/08/2016 25/08/2016
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Aug 18 2016-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:14 UTC

End      31-Dec-2024 16:57:14 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:14 UTC
Input    stis_ex/stis_shifted/od1al4040_blv_tmp.fits
Output   stis_ex/stis_shifted/od1al4040_flt.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:14 UTC
Epcfile  od1al4axj_epc.fits
Warning  EPCTAB `od1al4axj_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$09k14506o_drk.fits
DARKFILE PEDIGREE=INFLIGHT 18/08/2016 25/08/2016
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Aug 18 2016-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:14 UTC

Imset 2  Begin 16:57:14 UTC
Epcfile  od1al4ayj_epc.fits
Warning  EPCTAB `od1al4ayj_epc.fits' not found.

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKCORR COMPLETE

FLATCORR PERFORM
FLATCORR COMPLETE

SHADCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 2  End 16:57:14 UTC

End      31-Dec-2024 16:57:14 UTC

*** CALSTIS-1 complete ***
*** CALSTIS-7 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:14 UTC
Input    stis_ex/stis_shifted/od1al4040_crj.fits
Output   stis_ex/stis_shifted/od1al4040_sx2.fits
OBSMODE  ACCUM
APERTURE 52X2E1
OPT_ELEM G430L
DETECTOR CCD
Imset 1  Begin 16:57:14 UTC
Warning  Wavecal processing has not been performed.

HELCORR  PERFORM
HELCORR  COMPLETE

Order 1  Begin 16:57:14 UTC

X2DCORR  PERFORM
DISPCORR PERFORM
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Offset relative to row 900
SDCTAB   oref$16j16006o_sdc.fits
SDCTAB   PEDIGREE=INFLIGHT 27/05/1997 13/06/2017
SDCTAB   DESCRIP =Co-aligned fiducial bars via an update to the CDELT2 plate scales.-
SDCTAB   DESCRIP =CDELT2 updated with inflight data, others Lindler/prelaunch
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
INANGTAB oref$h5s11397o_iac.fits
INANGTAB PEDIGREE=GROUND
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
INANGTAB DESCRIP =Model/C. Bowers
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time
SPTRCTAB DESCRIP =Lindler/Bohlin/Dressel/Holfeltz postlaunch calibration

FLUXCORR PERFORM
PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 14/04/1998
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
PHOTTAB  DESCRIP =Updated Sensitivities 2022
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/5/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
PCTAB    DESCRIP =12 STIS observations averaged
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR COMPLETE
X2DCORR  COMPLETE
DISPCORR COMPLETE
Order 1  End 16:57:15 UTC
Imset 1  End 16:57:15 UTC

End      31-Dec-2024 16:57:15 UTC

*** CALSTIS-7 complete ***

*** CALSTIS-6 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:15 UTC

INFO     'E1' has been appended to aperture
Input    stis_ex/stis_shifted/od1al4040_crj.fits
Output   stis_ex/stis_shifted/od1al4040_sx1.fits
Rootname od1al4040
OBSMODE  ACCUM
APERTURE 52X2E1
OPT_ELEM G430L
DETECTOR CCD

XTRACTAB oref$n7p1031qo_1dx.fits
XTRACTAB PEDIGREE=INFLIGHT 18/05/97
XTRACTAB DESCRIP =Analysis from prop. 7094
XTRACTAB DESCRIP =Analysis from prop. 7094
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 02/09/1997 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time

Imset 1  Begin 16:57:15 UTC
         Input read into memory.
Order 1  Begin 16:57:15 UTC
X1DCORR  PERFORM
BACKCORR PERFORM
******** Calling Slfit ***********BACKCORR COMPLETE
X1DCORR  COMPLETE
         Spectrum extracted at y position = 892.751

DISPCORR PERFORM
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Offset relative to row 900
INANGTAB oref$h5s11397o_iac.fits
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
DISPCORR COMPLETE

HELCORR  PERFORM
HELCORR  COMPLETE

PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 16/03/2021
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
GACTAB   oref$p9r19203o_gac.fits
GACTAB   PEDIGREE=INFLIGHT 03/04/2002 03/08/2004
GACTAB   DESCRIP =X1D flux corr for grating/aper combos
GACTAB   DESCRIP =Grating-Aperture Throughput Correction
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/05/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR PERFORM
CTECORR  PERFORM
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij
         GACTAB correction applied for G430L 52X2E1 4300
CTECORR  COMPLETE
FLUXCORR COMPLETE
SGEOCORR OMIT

         Row 1 written to disk.
Order 1  End 16:57:15 UTC

         trace was rotated by = 0.0524527 degree.
Imset 1  End 16:57:15 UTC

Warning  Keyword `XTRACALG' is being added to header.
End      31-Dec-2024 16:57:15 UTC

*** CALSTIS-6 complete ***

End      31-Dec-2024 16:57:15 UTC

*** CALSTIS-0 complete ***

A file taken in the nominal position, od1am10b0 is also shifted, so we will fix that too:

width = 15
filepath = stis_unshifted / "od1am10b0_sx1.fits"

try:
    shift_stis(ref_file, filepath, width, plot=False, run_calstis=True)
except RuntimeError as e:
    print('An error occured', e)
Dispersion per pixel is 2.75 Å/pixel
The shift, in pixels, is -0.49 pixels
The shift, in Å, is -1.35Å
*** CALSTIS-0 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:15 UTC

Input    stis_ex/stis_data/od1am10b0_raw.fits
Outroot  stis_ex/stis_shifted/od1am10b0_raw.fits

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:15 UTC
Input    stis_ex/stis_data/od1am10b0_raw.fits
Output   stis_ex/stis_shifted/od1am10b0_blv_tmp.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:15 UTC
Epcfile  od1am1hgj_epc.fits
Warning  EPCTAB `od1am1hgj_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  PERFORM
DQITAB   oref$h1v11475o_bpx.fits
DQITAB   PEDIGREE=GROUND
DQITAB   DESCRIP =Prel. Ground Calib
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1434.32.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASFILE oref$0531402qo_bia.fits
BIASFILE PEDIGREE=INFLIGHT 22/02/2016 01/03/2016
BIASFILE DESCRIP =Weekly gain=1 bias for STIS CCD data taken after Feb 22 2016-------
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT

PHOTCORR OMIT
Imset 1  End 16:57:15 UTC

Imset 2  Begin 16:57:15 UTC
Epcfile  od1am1hhj_epc.fits
Warning  EPCTAB `od1am1hhj_epc.fits' not found.

DQICORR  PERFORM
DQICORR  COMPLETE

ATODCORR OMIT

BLEVCORR PERFORM
         Bias level from overscan has been subtracted; \
         mean of bias levels subtracted was 1435.35.
BLEVCORR COMPLETE
         Uncertainty array initialized, readnoise=6.24, gain=1

BIASCORR PERFORM
BIASCORR COMPLETE

DARKCORR OMIT

FLATCORR OMIT

SHADCORR OMIT
Imset 2  End 16:57:15 UTC

End      31-Dec-2024 16:57:15 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-2 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:15 UTC
Input    stis_ex/stis_shifted/od1am10b0_blv_tmp.fits
Output   stis_ex/stis_shifted/od1am10b0_crj_tmp.fits

CRCORR   PERFORM
Total number of input image sets = 2
CRREJTAB oref$j3m1403io_crr.fits
CRCORR   COMPLETE

End      31-Dec-2024 16:57:15 UTC

*** CALSTIS-2 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:15 UTC
Input    stis_ex/stis_shifted/od1am10b0_crj_tmp.fits
Output   stis_ex/stis_shifted/od1am10b0_crj.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:15 UTC
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$05314034o_drk.fits
DARKFILE PEDIGREE=INFLIGHT 22/02/2016 01/03/2016
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Feb 22 2016-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:15 UTC

End      31-Dec-2024 16:57:15 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-1 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:15 UTC
Input    stis_ex/stis_shifted/od1am10b0_blv_tmp.fits
Output   stis_ex/stis_shifted/od1am10b0_flt.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

Imset 1  Begin 16:57:15 UTC
Epcfile  od1am1hgj_epc.fits
Warning  EPCTAB `od1am1hgj_epc.fits' not found.

CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKFILE oref$05314034o_drk.fits
DARKFILE PEDIGREE=INFLIGHT 22/02/2016 01/03/2016
DARKFILE DESCRIP =Weekly gain=1 dark for STIS CCD data taken after Feb 22 2016-------
DARKCORR COMPLETE

FLATCORR PERFORM
PFLTFILE oref$x6417094o_pfl.fits
PFLTFILE PEDIGREE=INFLIGHT 24/10/2011 24/06/2012
PFLTFILE DESCRIP =REVISED ON-ORBIT STIS SPECTROSCOPIC CCD P-FLAT FOR L-MODES---------
LFLTFILE oref$pcc2026jo_lfl.fits
LFLTFILE PEDIGREE=INFLIGHT 27/05/1997 03/08/2004
LFLTFILE DESCRIP =CCD G430L Low-Order Flat
FLATCORR COMPLETE

SHADCORR OMIT

PHOTCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 1  End 16:57:15 UTC

Imset 2  Begin 16:57:15 UTC
Epcfile  od1am1hhj_epc.fits
Warning  EPCTAB `od1am1hhj_epc.fits' not found.

DQICORR  OMIT

ATODCORR OMIT

BLEVCORR OMIT

BIASCORR OMIT

DARKCORR PERFORM
DARKCORR COMPLETE

FLATCORR PERFORM
FLATCORR COMPLETE

SHADCORR OMIT

STATFLAG PERFORM
STATFLAG COMPLETE
Imset 2  End 16:57:15 UTC

End      31-Dec-2024 16:57:15 UTC

*** CALSTIS-1 complete ***

*** CALSTIS-7 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:15 UTC
Input    stis_ex/stis_shifted/od1am10b0_crj.fits
Output   stis_ex/stis_shifted/od1am10b0_sx2.fits
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD
Imset 1  Begin 16:57:15 UTC
Warning  Wavecal processing has not been performed.

HELCORR  PERFORM
HELCORR  COMPLETE

Order 1  Begin 16:57:15 UTC

X2DCORR  PERFORM
DISPCORR PERFORM
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Microscope Meas./Hartig Post-launch Offsets
SDCTAB   oref$16j16006o_sdc.fits
SDCTAB   PEDIGREE=INFLIGHT 27/05/1997 13/06/2017
SDCTAB   DESCRIP =Co-aligned fiducial bars via an update to the CDELT2 plate scales.-
SDCTAB   DESCRIP =CDELT2 updated with inflight data, others Lindler/prelaunch
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
INANGTAB oref$h5s11397o_iac.fits
INANGTAB PEDIGREE=GROUND
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
INANGTAB DESCRIP =Model/C. Bowers
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time
SPTRCTAB DESCRIP =Lindler/Bohlin/Dressel/Holfeltz postlaunch calibration

FLUXCORR PERFORM
PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 14/04/1998
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
PHOTTAB  DESCRIP =Updated Sensitivities 2022
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/5/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
PCTAB    DESCRIP =12 STIS observations averaged
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR COMPLETE
X2DCORR  COMPLETE
DISPCORR COMPLETE
Order 1  End 16:57:16 UTC
Imset 1  End 16:57:16 UTC

End      31-Dec-2024 16:57:16 UTC

*** CALSTIS-7 complete ***

*** CALSTIS-6 -- Version 3.4.2 (19-Jan-2018) ***
Begin    31-Dec-2024 16:57:16 UTC

Input    stis_ex/stis_shifted/od1am10b0_crj.fits
Output   stis_ex/stis_shifted/od1am10b0_sx1.fits
Rootname od1am10b0
OBSMODE  ACCUM
APERTURE 52X2
OPT_ELEM G430L
DETECTOR CCD

XTRACTAB oref$n7p1031qo_1dx.fits
XTRACTAB PEDIGREE=INFLIGHT 18/05/97
XTRACTAB DESCRIP =Analysis from prop. 7094
XTRACTAB DESCRIP =Analysis from prop. 7094
SPTRCTAB oref$qa31608go_1dt.fits
SPTRCTAB PEDIGREE=INFLIGHT 02/09/1997 13/02/1998
SPTRCTAB DESCRIP =New traces to account for angle change with time

Imset 1  Begin 16:57:16 UTC
         Input read into memory.
Order 1  Begin 16:57:16 UTC
X1DCORR  PERFORM
BACKCORR PERFORM
******** Calling Slfit ***********BACKCORR COMPLETE
X1DCORR  COMPLETE
         Spectrum extracted at y position = 509.434

DISPCORR PERFORM
DISPTAB  oref$l2j0137to_dsp.fits
DISPTAB  PEDIGREE=INFLIGHT 27/02/1997 24/11/1999
DISPTAB  DESCRIP =Lindler, May 2000
DISPTAB  DESCRIP =Lindler Postlaunch, May 2000
APDESTAB oref$16j16005o_apd.fits
APDESTAB PEDIGREE=INFLIGHT 01/03/1997 13/06/2017
APDESTAB DESCRIP =Aligned long-slit bar positions for single-bar cases.--------------
APDESTAB DESCRIP =Microscope Meas./Hartig Post-launch Offsets
INANGTAB oref$h5s11397o_iac.fits
INANGTAB DESCRIP =Model/C. Bowers May 6, 1997
DISPCORR COMPLETE

HELCORR  PERFORM
HELCORR  COMPLETE

PHOTTAB  oref$74e15479o_pht.fits
PHOTTAB  PEDIGREE=INFLIGHT 27/02/1997 16/03/2021
PHOTTAB  DESCRIP =Updated sensitivity curves for G750L
APERTAB  oref$y2r1559to_apt.fits
APERTAB  PEDIGREE=MODEL
APERTAB  DESCRIP =Added/updated values for 31X0.05NDA,31X0.05NDB,31X0.05NDC apertures
APERTAB  DESCRIP =Bohlin/Hartig TIM Models Nov. 1998
PCTAB    oref$q541740no_pct.fits
PCTAB    PEDIGREE=INFLIGHT 18/05/1997 19/12/1998
PCTAB    DESCRIP =Sensitivity for diff. extractions heights
TDSTAB   oref$8712049eo_tds.fits
TDSTAB   PEDIGREE=INFLIGHT 01/04/1997 06/03/2024
TDSTAB   DESCRIP =Updated time sensitivities for MIRVIS, G230LB, and G230MB
FLUXCORR PERFORM
CTECORR  PERFORM
CCDTAB   oref$16j1600do_ccd.fits
CCDTAB   PEDIGREE=INFLIGHT 01/05/2009 01/05/2009
CCDTAB   DESCRIP =Updated amp=D gain=4 atodgain and corresponding readnoise values---
CCDTAB   DESCRIP =Proposal 8057, by I. Dashevsky & P. Goudfrooij
CTECORR  COMPLETE
FLUXCORR COMPLETE
SGEOCORR OMIT

         Row 1 written to disk.
Order 1  End 16:57:16 UTC

         trace was rotated by = 0.0504519 degree.
Imset 1  End 16:57:16 UTC

Warning  Keyword `XTRACALG' is being added to header.
End      31-Dec-2024 16:57:16 UTC

*** CALSTIS-6 complete ***

End      31-Dec-2024 16:57:16 UTC

*** CALSTIS-0 complete ***

2.5 Comparing Non-Adjusted and Adjusted STIS Coadds#

Now that we’ve applied the shifts to our data, we will re-run the coadd code. To get a proper comparison, we will need to copy over the files taken at the nominal position to the stis_shifted directory since the coadd code needs all X1D/SX1 files in the same directory.

for file in sx1s:
    if file.name == "od1am10b0_sx1.fits":
        continue

    if fits.getval(file, "PROPAPER") == "52X2":
        new_path = stis_shifted / os.path.basename(file)
        shutil.copy(file, new_path)

And now we run the coadd script:

!swrapper -i ./stis_ex/stis_shifted -o ./stis_ex/stis_shifted/coadd
HASP version 1.0
Ullyses version 4.1.0
Creating list of unique modes from these files:
./stis_ex/stis_shifted/od1al1030_sx1.fits AGK+81D266 STIS CCD G430L 52X2 14423 (14423, 'l1')
./stis_ex/stis_shifted/od1al1040_sx1.fits AGK+81D266 STIS CCD G430L 52X2E1 14423 (14423, 'l1')
./stis_ex/stis_shifted/od1al2030_sx1.fits AGK+81D266 STIS CCD G430L 52X2 14423 (14423, 'l2')
./stis_ex/stis_shifted/od1al4030_sx1.fits AGK+81D266 STIS CCD G430L 52X2 14423 (14423, 'l4')
./stis_ex/stis_shifted/od1al4040_sx1.fits AGK+81D266 STIS CCD G430L 52X2E1 14423 (14423, 'l4')
./stis_ex/stis_shifted/od1am10b0_sx1.fits AGK+81D266 STIS CCD G430L 52X2 14423 (14423, 'm1')
./stis_ex/stis_shifted/od1am10e0_sx1.fits AGK+81D266 STIS CCD G430L 52X2E1 14423 (14423, 'm1')
Looping over visits
Processing product (14423, 'l1')
Targets in visit (14423, 'l1'): ['AGK+81D266']
Processing target AGK+81D266 in visit (14423, 'l1')
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_shifted/od1al1030_sx1.fits', './stis_ex/stis_shifted/od1al1040_sx1.fits']
Processing file ./stis_ex/stis_shifted/od1al1030_sx1.fits
Processing file ./stis_ex/stis_shifted/od1al1040_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
WARNING: VerifyWarning: Card is too long, comment will be truncated. [astropy.io.fits.card]
   Wrote ./stis_ex/stis_shifted/coadd/hst_14423_stis_agkp81d266_g430l_od1al1_cspec.fits
No need to create abutted product as < 2 single grating products
Processing product (14423, 'l2')
Targets in visit (14423, 'l2'): ['AGK+81D266']
Processing target AGK+81D266 in visit (14423, 'l2')
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_shifted/od1al2030_sx1.fits']
Processing file ./stis_ex/stis_shifted/od1al2030_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./stis_ex/stis_shifted/coadd/hst_14423_stis_agkp81d266_g430l_od1al2_cspec.fits
No need to create abutted product as < 2 single grating products
Processing product (14423, 'l4')
Targets in visit (14423, 'l4'): ['AGK+81D266']
Processing target AGK+81D266 in visit (14423, 'l4')
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_shifted/od1al4030_sx1.fits', './stis_ex/stis_shifted/od1al4040_sx1.fits']
Processing file ./stis_ex/stis_shifted/od1al4030_sx1.fits
Processing file ./stis_ex/stis_shifted/od1al4040_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./stis_ex/stis_shifted/coadd/hst_14423_stis_agkp81d266_g430l_od1al4_cspec.fits
No need to create abutted product as < 2 single grating products
Processing product (14423, 'm1')
Targets in visit (14423, 'm1'): ['AGK+81D266']
Processing target AGK+81D266 in visit (14423, 'm1')
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_shifted/od1am10b0_sx1.fits', './stis_ex/stis_shifted/od1am10e0_sx1.fits']
Processing file ./stis_ex/stis_shifted/od1am10b0_sx1.fits
Processing file ./stis_ex/stis_shifted/od1am10e0_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./stis_ex/stis_shifted/coadd/hst_14423_stis_agkp81d266_g430l_od1am1_cspec.fits
No need to create abutted product as < 2 single grating products
Looping over proposals
Processing product 14423
Targets in proposal 14423: ['AGK+81D266']
Processing target AGK+81D266 in proposal 14423
Processing grating STIS/G430L
Importing files ['./stis_ex/stis_shifted/od1al1030_sx1.fits', './stis_ex/stis_shifted/od1al1040_sx1.fits', './stis_ex/stis_shifted/od1al2030_sx1.fits', './stis_ex/stis_shifted/od1al4030_sx1.fits', './stis_ex/stis_shifted/od1al4040_sx1.fits', './stis_ex/stis_shifted/od1am10b0_sx1.fits', './stis_ex/stis_shifted/od1am10e0_sx1.fits']
Processing file ./stis_ex/stis_shifted/od1al1030_sx1.fits
Processing file ./stis_ex/stis_shifted/od1al1040_sx1.fits
Processing file ./stis_ex/stis_shifted/od1al2030_sx1.fits
Processing file ./stis_ex/stis_shifted/od1al4030_sx1.fits
Processing file ./stis_ex/stis_shifted/od1al4040_sx1.fits
Processing file ./stis_ex/stis_shifted/od1am10b0_sx1.fits
Processing file ./stis_ex/stis_shifted/od1am10e0_sx1.fits
Using a maximum SNR of 20.0 in flux-based filtering
   Wrote ./stis_ex/stis_shifted/coadd/hst_14423_stis_agkp81d266_g430l_od1a_cspec.fits
Making a product from these gratings
STIS/G430L 2895.9-5704.4 (Actual: 2967.5-5700.7)
Transition wavelengths tweaked
Starting at the short wavelength end with grating STIS/G430L
Truncating current grating at 5700.705595657229
./stis_ex/stis_shifted/coadd/hst_14423_stis_agkp81d266_g430l_od1a_cspec.fits already exists and overwrite=False, skipping write
   Wrote ./stis_ex/stis_shifted/coadd/hst_14423_stis_agkp81d266_g430l_od1a_cspec.fits

And we can now compare our pre-shifted and shifted data and their coadds.

coadd = "hst_14423_stis_agkp81d266_g430l_od1a_cspec.fits"

fig, ax = plt.subplots(2, 2, figsize=(14, 10))

types = [stis_unshifted, stis_shifted]

for i, is_shifted in enumerate(types):
    for file in is_shifted.glob("*sx1*"):
        with fits.open(file) as hdul:
            wl = hdul[1].data["WAVELENGTH"].ravel()
            flux = hdul[1].data["FLUX"].ravel()

            aperture = hdul[0].header['PROPAPER']

            # Differentiating between nominal and E1 position via linestyle
            if aperture == "52X2":
                linestyle = "solid"
                label = f"{hdul[0].header['ROOTNAME']} - nom."
            else:
                linestyle = "dotted"
                label = f"{hdul[0].header['ROOTNAME']} - E1"

        ax[0][i].plot(
            wl,
            flux,
            lw=2,
            alpha=0.6,
            label=label,
            linestyle=linestyle
        )

        ax[1][i].plot(
            wl,
            flux,
            lw=2,
            alpha=0.6,
            label=label,
            linestyle=linestyle
        )

    # Plotting the coadd
    with fits.open(f"{is_shifted}/coadd/{coadd}") as hdul:
        wl = hdul[1].data["WAVELENGTH"].ravel()
        flux = hdul[1].data["FLUX"].ravel()

    ax[0][i].plot(
        wl,
        flux,
        label="Coadd",
        color="black",
        alpha=0.7
    )

    ax[1][i].plot(
        wl,
        flux,
        label="Coadd",
        color="black",
        alpha=0.7
    )

    # All plots will have same labels
    for subplot in ax[i].ravel():
        subplot.set_ylabel(r'Flux [$erg\ s^{-1}\ cm^{-2}\ \AA^{-1}$]')
        subplot.set_xlabel(r'Wavelength [$\AA$]')

    shifted = ['Unshifted', 'Shifted'][i]

    ax[0][i].set_title(f"Flux vs Wavelength, {shifted}",
                       fontweight="bold")
    ax[1][i].set_title(f"Flux vs Wavelength 4840-4900Å, {shifted}",
                       fontweight="bold")

    ax[1][i].set_xlim(4840, 4900)
    ax[1][i].set_ylim(0.4e-13, 1.5e-13)

    ax[0][i].legend()

plt.tight_layout()
plt.show()
../../../_images/19138a82bae59773b53aaa334f938761c4e22e86615631f2d78da9110c271b0d.png

We can see the offsets between the datasets taken at the nominal position and the E1 position are reduced after we’ve applied our shifts and run CalSTIS. While we did a very rough estimate of the shift, users will want to verify that they have the correct wavelength solution through their own methods (e.g. checking expected wavelengths to observed wavelengths, comparing radial velocities, etc.).

Congrats on completing the notebook!#

There are more tutorial notebooks for custom coaddition cases in this repo, check them out!#

About this Notebook#

Author: Sierra Gomez (sigomez@stsci.edu)

Updated on: August 29, 2024

This tutorial was generated to be in compliance with the STScI style guides and would like to cite the Jupyter guide in particular.

Citations#

If you use astropy, astroquery, or matplotlib, numpy for published research, please cite the authors. Follow these links for more information about citations: