File: baselines.py

package info (click to toggle)
doris 5.0.3~beta%2Bdfsg-19
  • links: PTS, VCS
  • area: contrib
  • in suites: forky, sid
  • size: 6,944 kB
  • sloc: cpp: 43,560; python: 8,213; csh: 3,636; sh: 2,527; ansic: 649; makefile: 337; xml: 208
file content (99 lines) | stat: -rwxr-xr-x 3,319 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
import os
import numpy as np
import warnings
from shutil import copyfile
from doris.doris_stack.main_code.resdata import ResData
import datetime
import subprocess


def baselines(dir_in,inputfile,start_date='2014-01-01',end_date='2018-01-01',doris=''):
    # This function calculates the baselines and plots a baseline plot.

    # Define doris path
    if not doris:
        doris = doris_path

    if not os.path.exists(dir_in):
        warnings.warn('The input directory does not exist!')
        return

    os.chdir(dir_in)
    process_folder = os.path.join(dir_in, 'baseline_process')
    if not os.path.exists(process_folder):
        os.mkdir(process_folder)
    os.chdir(process_folder)

    try:
        first = np.datetime64(start_date)
        last = np.datetime64(end_date)
    except:
        warnings.warn('Input dates could not be converted, use "yyyy-mm-dd"')
        return

    # Search for folders and take only the first burst.
    folders = next(os.walk(dir_in))[1]
    folders = sorted(folders)

    # Initialize... (Search for folders / resfiles / dates)
    n = 0
    res = []; date = []
    for fold in folders:
        # Select only the folders which has a name like yyyymmdd and are within
        if len(fold) == 8:
            # define date of folder
            date_prod = np.datetime64((fold[:4] + '-' + fold[4:6] + '-' + fold[6:]))

            if date_prod >= first and date_prod <= last:
                # Select the first swath
                date_fold = os.path.join(dir_in,fold)
                swath_fold = os.path.join(date_fold,next(os.walk(date_fold))[1][0])
                # Select the first burst
                prod_files = next(os.walk(swath_fold))[2]
                for file in prod_files:
                    if file.endswith('1.res'):
                        res.extend([os.path.join(swath_fold,file)])
                        date.extend([date_prod])
                        n = n + 1
                        break

    # Now create a set of baselines

    baselines = np.zeros([len(res),len(res)])
    resfiles = dict()

    # First create the ifgs.res files and store the data in a res data class.
    master = res[0]
    copyfile(master,os.path.join(process_folder,'master.res'))

    for resultfile, dat in zip(res, date):
        copyfile(resultfile,os.path.join(process_folder,'slave.res'))
        subprocess.call([doris + ' ' + inputfile], shell=True)

        dat = dat.astype(datetime.datetime).strftime('%Y-%m-%d')
        resfiles[dat] = ResData(type='interferogram',filename='ifgs.res')
        resfiles[dat].read()
        os.remove(os.path.join(process_folder,'ifgs.res'))

    # Then gather the baselines
    for dat, j in zip(date, range(len(date))):
        dat = dat.astype(datetime.datetime).strftime('%Y-%m-%d')
        baselines[j,0] = resfiles[dat].processes['coarse_orbits']['Bperp'][1]



    # Create figure of baselines.
    days = (date[0] - date).astype(float)
    plt.figure(111)
    plt.plot(baselines[:,0], days, marker='o')

    # Annotate
    for dat, x, y in zip(date, baselines[:,0], days):
        dat = dat.astype(datetime.datetime).strftime('%Y-%m-%d')
        plt.annotate(
            dat,
            xy = (x, y), xytext = (0, 0),
            textcoords = 'offset points', size = 8)

    plt.savefig('baseline_plot.pdf')