Skip to content

Data component

mfangaritav edited this page Jan 5, 2024 · 32 revisions

Declaring an object

The first step to run an inversion with VMOD is to declare a Data object. The user should load the locations of data points (add_xs and add_ys) and the components for the data type.

GNSS

For example the class that represents the GNSS data type (Gnss) has methods to add the east (add_uxs), north (add_uys), and vertical (add_uzs) components. Here we show an example on how to declare a GNSS object:

from vmod.data import Gnss

#Create Gnss object
obs=Gnss()

#Add the names of the stations
obs.add_names(names)

#Add the x and y coordinates of the stations
obs.add_xs(xs)
obs.add_ys(ys)

#Add deformation dataset in east (uxs), north (uys) and vertical (uzs)
obs.add_ux(uxs)
obs.add_uy(uys)
obs.add_uz(uzs)

#Add uncertainties in east (euxs), north (euys) and vertical (euzs)
obs.add_errx(euxs)
obs.add_erry(euys)
obs.add_errz(euzs)

Alternatively, the user can declare the Gnss object and arrange the GNSS data in a csv file and import the information into the object.

from vmod.data import Gnss

#Create Gnss object
obs=Gnss()

#Import csv into the observation object
obs.importcsv('examples/gps/unimak_gnss_NOAM.txt')

InSAR

The InSAR datasets can be import it into Insar objects. It is necessary to load the Line-Of-Sight observations (add_los), the azimuth and incidence angles (add_vecs).

from vmod.data import Insar

#Create Insar object
obs=Insar()

#Add the x and y coordinates of the stations
obs.add_xs(xs)
obs.add_ys(ys)

#Add azimuth and incidence angles.
obs.add_vecs(azs,lks)

#Add deformation dataset
obs.add_los(los)

VMOD has auxiliary libraries to downsample the InSAR datasets using a quadtree algorithm. The function get_quadtree expects a matrix with the LOS observations (los), the azimuth angle(s) (az), the incidence angle(s) (inc), an array that contains the extent of the image (extent), a variance threshold (th) and the name of the file (name) with the quadtree output.

from vmod import util

util.quadtree_var(los,az,inc,extent,th,name)

Create a new data type

Users wishing to include a new datatype should clone the source repository and create a new file in the data folder. This file should contain a new class that inherit from the 'Data' class and that has the functions to initialize the attributes, adding the components belonging to the datatype and a function to derive the components from 3d displacements. For example, in the Insar class we defined the following functions:

class Insar(Data):
    def __init__():
        ...
    def add_los(self, los):
        ...
    def from_model3d(self, func):
        ...