.. _tutorials_waveformplayback: **************************** Play back archived waveforms **************************** Aims: * Use previously recorded waveform files to re-run the analysis of an old event using SeisComP. This is known as a *waveform playback*. * Insert results into your current SeisComP database for later processing. * Review the results from playbacks. Pre-requisites for this tutorial: * Have SeisComP installed and configured * Have access to :term:`miniSEED` waveforms Afterwards/Results/Outcomes: * The results from the playback are in your SeisComP system, e.g. :term:`picks `, :term:`origins `, :term:`amplitudes `, :term:`events ` Time range estimate: * 60 minutes Related tutorial(s): * Tutorial on :ref:`getting help ` ---------- Playbacks are an important way of testing module and whole-system configurations, operator trainings, system demonstrations and validations and tuning of the SeisComP modules used for detecting and locating events, e.g. involving * :ref:`seedlink` * :ref:`slarchive` * :ref:`scautopick` * :ref:`scautoloc` * :ref:`scamp` * :ref:`scmag` * :ref:`scevent` * others. Playbacks rely on miniSEED data which are obtained from the :term:`SDS` archive or other sources. The miniSEED data records in the data files must be sorted by end time! There are two types of playbacks: * :ref:`Real-time playbacks `. * :ref:`Non-real-time playbacks `. Data preparation ================ First extract the data. Make sure the miniSEED records are sorted by end time. The data extraction depends on the data source. Examples: * **SDS archive:** Extract the data from your own SDS archive using :ref:`scart` and save it in a new miniSEED file :file:`[your miniSEED file]`, sorted by end time of the records. Examples: .. code-block:: sh scart -dsE -l [list file] $SEISCOMP_ROOT/var/lib/archive > [your miniSEED file] * **FDSNWS:** Get the miniSEED data from an external FDSNWS server. The obtained data are initially sorted by station and must therefore be sorted by end time using :ref:`scmssort`. Use the resulting file :file:`[your miniSEED file]` for your playback. Example for one hour of data from the GE network from `FDSNWS at GEOFON `_: .. code-block:: sh wget -O data.mseed "http://geofon.gfz-potsdam.de/fdsnws/dataselect/1/query?net=GE&cha=BH*&starttime=2021-04-01T06:00:00Z&endtime=2021-04-01T07:00:00Z" scmssort -u -E data.mseed > [your miniSEED file] * **CAPS server:** Extract the data from gempa's CAPS server :cite:p:`caps` using :cite:t:`capstool`: .. code-block:: sh capstool -H [host]:[port] [request file] > data.mseed or :ref:`scart` with the *caps* :term:`recordstream`: .. code-block:: sh scart -I caps://[host]:[port] -l [list file] --stdout > data.mseed Eventually, sort the downloaded data by end time with :ref:`scmssort` creating a new file, :file:`[your miniSEED file]`: .. code-block:: sh scmssort -u -E data.mseed > [your miniSEED file] Use the resulting file :file:`[your miniSEED file]` for your playback. Playbacks ========= .. _tutorials_rtplayback: Real-time playbacks ------------------- In a real-time playback data are injected into the seedlink buffer from a file using the command-line tool :ref:`msrtsimul`. Therefore, seedlink requires a configuration. #. Prepare :ref:`seedlink` to except data from msrtsimul: * In the :ref:`module configuration ` of seedlink set .. code-block:: sh msrtsimul = true * Save the configuration, update the configuration and restart seedlink: .. code-block:: sh seiscomp update-config seiscomp restart seedlink Open :scrttv: to verify the success of this re-configuration. No new data must arrive. #. Restart all automatic data processing modules you wish to involve. Additionally start :ref:`slarchive` to archive the miniSEED data in the SDS archive for post-processing. .. code-block:: sh seiscomp restart scmaster scautopick scautoloc scamp scmag scevent slarchive #. Start all desired :term:`GUI` modules to observe the data acquisition and processing and the event results, e.g.: .. code-block:: sh scrttv & scmv & scesv & scolv #. Start the playback using msrtsimul: .. code-block:: sh msrtsimul -v [your miniSEED file] This will play back the data as if they where perfectly recorded and received now. To preserve the time of the records use :program:`msrtsimul` with the historic mode: .. code-block:: sh msrtsimul -v -m historic [your miniSEED file] .. note:: Using :program:`msrtsimul` with the historic mode requires to reset the seedlink buffer and the buffer of other processing modules by removing the buffer files and restarting the modules. This mode may therefore be exclusively used by experienced users. Revert the seedlink configuration after the playback to return to the original real-time data acquisition. .. warning:: Be careful with executing real-time playbacks on production SeisComP systems: * You potentially disrupt the real-time data acquisition * You potentially add data at wrong times to seedlink and your SDS waveform archive * You modify the history of the created events * You potentially add events at wrong origin times to your database. Better use separate test systems for real-time playbacks. .. _tutorials_nonrtplayback: Non-real-time playbacks ----------------------- In non-real-time playbacks, also referred to as offline playbacks, data are processed by each module as fast as possible. The results can be communicated by * Messages: message-based playback * XML files in :term:`SCML` format: XML playback. They require the processing modules to provide the *- -ep* option. .. warning:: In non-real-time playbacks scheduling and the creation history are not representative of real-time situations. Reviewing results ================= Use :ref:`scolv` or other :term:`GUIs ` to review the results: * Event parameters are in the default database. Configure :ref:`concepts_RecordStream` if the waveforms are in the seedlink or in the :term:`SDS` archive: .. code-block:: sh scolv -d mysql://sysop:sysop@localhost/seiscomp * Event parameters are in the default database but the waveforms are read from the miniSEED file: .. code-block:: sh scolv -d mysql://sysop:sysop@localhost/seiscomp -I file://[your file] .. note:: Reading from the original file will only work if the actual times of the data are preserved during the playback. This is **not** the case when starting :program:`msrtsimul` without the historic mode. * Event parameters are available in one XML file and the waveforms are read from the miniSEED file: .. code-block:: sh scolv --offline -d mysql://sysop:sysop@localhost/seiscomp -I file://[your miniSEED file] To open the XML file click on the *File* menu of scolv. When results are available in several XML files, the files can be merged beforehand using :ref:`scxmlmerge`. .. note:: Adjust the arguments to match your configuration. Use your own values for arguments enclosed by brackets, e.g. [your file]