Skip to content

Teseo2: Turn the Eldest Seismograms into the Electronic Original Ones

Notifications You must be signed in to change notification settings

matteoquintiliani/teseo2

 
 

Repository files navigation

Teseo2: Turn the Eldest Seismograms into the Electronic Original Ones

Teseo2 is a software tool for quick and accurate digitization/vectorization of seismogram traces from raster files.

It has been developed in the framework of the Sismos project [Michelini and the Sismos Team, 2005] at Istituto Nazionale di Geofisica e Vulcanologia (Italy). This name was inspired by the myth of Theseus and it is also an acronym for

Turn the Eldest Seismograms into the Electronic Original Ones.

Teseo2 is a plug-in for GIMP - GNU Image Manipulation Program - that extends its functionalities for seismological studies. The GIMP is a multiplatform photo manipulation tool freely distributed. It works on many operating systems, in many languages.

Teseo2 allows primarily for:

  • additional operations on the vectorized trace (i.e. resampling and alignment)
  • supervised vectorization algorithms (colour weighted mean)
  • analysis after trace vectorization, such as curvature correction and time realignment
  • trace import/export in several formats (such as SAC, SVG, DXF, ASCII, Timemarks distances).

In order to keep track of the stages and parameters of a seismogram vectorization, Teseo2 is able to write this information into the image saved into GIMP's native XCF file type.

Teseo2 is developed following the "Open-Source" philosophy and it is freely distributed under GPL license. It is cross-platform and the sources, the binaries for Linux, Windows and Mac OS X, are periodically updated on the Sismos web site.

Documentation links

Using Teseo by Docker (recommended)

We recommend to run Teseo by Docker in a Unix-like environment (Linux or Mac OS X).

Installation and use Teseo by Docker

Requirements

  • Docker (Linux, Mac OS X, Windows)
  • X11 server
    • Mac OS X: Xquartz - https://www.xquartz.org/
    • Important note for XQuartz: in XQuartz Preferences, within "Security" tab, you have to check the option "Allow connections from network clients".
  • git
    • Mac OS X: Xcode - xcode-select --install
  • make
    • Mac OS X: Xcode - xcode-select --install

Optional packages

  • ssh client
    • ssh client is only required for running Teseo Docker Image by make -f Makefile.Docker run_ssh_xhost (see below the option based on ssh and xhost).

Download teseo2 repository

git clone https://github.com/INGV/teseo2.git
cd teseo2

Build Docker Image

Edit the file Makefile.Docker.env and set properly the following custom variables:

######################################
# Custom variables
######################################

#Dockerfile
DOCKERBASEIMAGE=alpine
DOCKERFILE=Dockerfile.$(DOCKERBASEIMAGE)

# Custom SSH port used to access to docker container
SSH_CONTAINER_PORT = 10022

# User ID and Group ID for teseo user and group.
# WARNING: On Linux, if you run docker image by different UID or GID
# you could not able to write in docker mount data directory.
# If you want always add new teseo user and group set ENV_UID and ENV_GID to zero.
ENV_UID=`id -u`
ENV_GID=`id -g`
# ENV_UID=0
# ENV_GID=0

# Default docker mount data directory
BASEMOUNTDIR = `pwd`/DockerMount

# X11 Server Hostname or IP
# Try to catch docker host IP when running run_xhost
MYIP = `ifconfig | grep -w inet | egrep -v -w "127.0.0.1" | awk '{print $$2}' | head -n 1`
# You can manually set
# MYIP = X11_server_hostname_or_IP

# Set path where searching xhost command
XHOST_PATH = /usr/X11R6/bin:/usr/bin/X11:/opt/X11/bin

Then run:

make -f Makefile.Docker build

Run Docker Image

Teseo Docker Image is based on X11 environment. You need to set up an X11 server on your computer.

You can run Teseo Docker Image by one of the following option:

1) Based on X11 local socket.

WARNING: It works only on Linux. It does not work on Mac OS X!

make -f Makefile.Docker run_xlocal
2) Based on xhost.

WARNING: Not when the machine is offline.

It is not possible running in this mode when you are offline (that is when your Docker host does not have any visible IP from docker container).

When you run this mode, you have to disable the access control to your X11 server, clients can connect from any host. Run xhost + or make -f Makefile.Docker xhost_disable_control.

Run:

# OPTIONAL:
#    xhost +
#    make -f Makefile.Docker xhost_disable_control

make -f Makefile.Docker run_xhost
3) Based on ssh and xhost.

NOTE: This is the general solution.

This solution should work on all cases:

  • it is more general than previous based on xhost
  • it is safer because enable access control only to the localhost machine. Run xhost +localhost or make -f Makefile.Docker xhost_add_localhost
  • and you can run also when your machine is offline.

Before you start, you have to run the docker container as an SSH server service by:

# OPTIONAL:
#    xhost +localhost
#    make -f Makefile.Docker xhost_add_localhost

make -f Makefile.Docker start

Then run:

make -f Makefile.Docker run_ssh_xhost

Note: when you finished to use the docker container remember to stop it by:

make -f Makefile.Docker stop

Update Docker Image

To update your Teseo Docker Image pull the changes from git repository and rebuild by make.

cd teseo2
git pull

Rebuild

make -f Makefile.Docker build

General Build from scratch

Requirements

  • gimp-2.2.9 up to gimp-2.10.x

The configure scripts might fail asking you the dependency libraries you have to install or to specify into PKG_CONFIG_PATH.

Quick installation

$ tar xzvf teseo*.tar.gz
$ cd teseo2/
$ cd gtk-addons
$ ./configure && make && sudo make install
$ cd ../newuoa
$ ./configure F77=<fortran-path> && make && sudo make install
$ cd ../teseo-2
$ ./configure && make && sudo make install

Details in file ./teseo-2/INSTALL

Authors

Stefano Pintore and Matteo Quintiliani.

Contributors

Diego Franceschi, Antoine Schlupp, Daniel Amorese.

References

Michelini, A. and the Sismos Team (2005). Collection, digitization and distribution of historical seismological data at INGV. EOS, 86(28).

Pintore S., Quintiliani M., Franceschi D. (2005) Teseo: a vectoriser of historical seismograms. Computers & Geosciences, Volume 31, Issue 10, 2005, Pages 1277-1285, ISSN 0098-3004, http://dx.doi.org/10.1016/j.cageo.2005.04.001

Schlupp, Antoine & Cisternas, Armando. (2007). Source history of the 1905 great Mongolian earthquakes (Tsetserleg, Bolnay). Geophysical Journal International. 169. 1115 - 1131. 10.1111/j.1365-246X.2007.03323.x.

Cadek, O. (1987). Studying earthquake ground motion in prague from wiechert seismograph records. Gerl. Beitr. Geoph., 96:438-447.

About

Teseo2: Turn the Eldest Seismograms into the Electronic Original Ones

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 38.3%
  • Shell 32.9%
  • C++ 14.6%
  • HTML 9.4%
  • Fortran 2.5%
  • Makefile 1.8%
  • Other 0.5%