Solar Orbiter Inventory Plots

Remote Sensing Instruments | In situ instruments | All instruments for all SCI levels (L1, L2, L3)| Python code to find latest data per instrument

Remote Sensing Instruments

(maintained by E. Buchlin, IAS, Paris)

Inventory Plots for all instruments and Science Levels

These are indicative plots for the contents of the SOAR as of 31 March 2025. These plots were created by this Jupyter Notebook: InventoryPlots.ipynb

These are meant for information only and in future, the inventory plots will be provided with the web interface SOAR.

In situ: EPD, MAG, RPW, SWA

Remote sensing: EUI, Metis, PHI, SoloHI, SPICE, STIX


EPD





Back to list of instruments

EUI




 

Back to list of instruments

MAG


 

Back to list of instruments

Metis



Back to list of instruments

PHI



 

Back to list of instruments

RPW




Back to list of instruments

SoloHI


 

Back to list of instruments

SPICE


Back to list of instruments

STIX


Back to list of instruments

SWA




Back to list of instruments

 

Latest data available

This python code will access the TAP database and return the latest data's date available for each instrument and level:

 

import pyvo as vo # Data Access (pyvo.dal)
from datetime import datetime, timedelta
import pandas as pd

instru_list = ['EPD', 'EUI', 'MAG', 'METIS', 'PHI', 'RPW', 'SOLOHI', 'SPICE', 'STIX', 'SWA']
level_list = ['L1', 'L2', 'L3']
ARCHIVE = 'https://soar.esac.esa.int/soar-sl-tap/tap'

def TAPquery(ARCHIVE, query):
    '''
    Given the ARCHIVE (e.g., https://soar.esac.esa.int/soar-sl-tap/tap) and the
    ADQL query, fetch the results and return as a DataFrame.
    '''
    try:
        ESDC = vo.dal.TAPService(ARCHIVE)
        results = ESDC.search(query)
        astropy_table = results.to_table()
        return astropy_table.to_pandas()  # convert to DataFrame
    except Exception as e:
        print(f"Error executing query: {e}")
        return None

for instr in instru_list:
    print(instr)
    for level in level_list:
        ADQL = (
            f"SELECT level, MAX(begin_time) "
            f"FROM v_sc_data_item "
            f"WHERE instrument='{instr}' AND level='{level}' "
            f"GROUP BY level"
            )

        result_table = TAPquery(ARCHIVE, ADQL)

        if result_table is not None and len(result_table) > 0:
            latest_time = result_table['MAX'].iloc[0]
            print(f"{level}: {latest_time}")
        else:
            print(f"{level}: ---")