-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMain_Multi.py
executable file
·151 lines (122 loc) · 3.81 KB
/
Main_Multi.py
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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
Created on Thu May 21 16:22:01 2020
@author: el
"""
from Forward import Forward
from param_acquisition import ParamGPRMAX, ParamMVG, Geometry
import itertools
import numpy as np
import dask
import os
#from joblib import Parallel, delayed
os.chdir('/home/el/Codes/Porchet-GPR')
#%% Geometrie
#def des paramètres géométriques
geometry=Geometry()
#Domaine de calcul (en cm)
#Tolerance
geometry.tol=10**(-7)
# largeur
geometry.xmin=0
geometry.xmax=40
# hauteur (elevation)
geometry.emin=0
geometry.emax = 80
# profondeur du trou en cm
geometry.dtrou = 30
# elevation du fond du trou
geometry.etrou = geometry.emax - geometry.dtrou
# rayon du trou en cm
geometry.r=2
# hauteur d'eau imposée au fond du trou en cm
geometry.h_eau=5.0
# pas de la maille en cm
#geometry.dx = 0.1
geometry.dx = 1
# profondeur sous le trou (cm) jusqu'où on souhaite un maillage affiné.
geometry.zaff= 20
#largeur horizontal de la zone affinée (cm)
geometry.waff=20
# elevation de l'affinage
geometry.eaff=geometry.etrou-geometry.zaff
# contrainte d'angle min pour mesh
geometry.quality=33
# maximum triangle size (m*²)
geometry.area=5
# tupple for mesh generation
geometry.smooth=[1,5]
#%% def de paramètres SWMS
#Temps d'infiltration où à lieu le calcul de chaque trace (minutes)
#temps=[1.00, 2.00]
temps=[0.17, 0.33, 0.50, 0.67, 0.83, 1.00, 2.00, 3.00, 4.00, 5.00, 6.00]
# Temps max de calcul SWMS2D au delà duquel on arrète le calcul (secondes)
tmax_SWMS2D = 60
#tmax_SWMS2D = 10
nT=len(temps)
#%% Definition des param gprMax
paramGPRMAX=ParamGPRMAX()
# Domaine de calcul (cm)
paramGPRMAX.xmin = geometry.xmin
paramGPRMAX.xmax = geometry.xmax
paramGPRMAX.zmin = geometry.emin
paramGPRMAX.zmax = geometry.emax
# Taille des mailles (cm)
paramGPRMAX.dx = 1.0
# Electrical conductivity of the medium
paramGPRMAX.sigma=0.0000
# Relative dielectric permittivity of water
paramGPRMAX.eps_w=80.1
# Relative dielectric permittivity of PVC
paramGPRMAX.eps_pvc=3
# Relative dielectric permittivity of pure silice
paramGPRMAX.eps_s=2.5
# Ricker signal central frequency (Hz)
paramGPRMAX.wave_freq = 1000e6
# Frequence max du signal EM (Hz)
paramGPRMAX.freq_max = 2.8 * paramGPRMAX.wave_freq
# Distance between hole middle and source (m)
paramGPRMAX.d_emet = 0.18
# Distance between hole middle and receiving antenna (m)
paramGPRMAX.d_recept = 0.22
# param qui raffine le pas spatial (par défaut 10 d'après doc gprmax)
paramGPRMAX.spatial_step = 5
# Trace time window (ns)
paramGPRMAX.time = 30e-9
#time_step_stability_factor (pas utilisé pour le moment...)
paramGPRMAX.fac_dt = 0.2
#%% Pqrqm mvg
# Teneur en eau résiduelle
tr = [0.02]
# Teneur en eau à saturation
ts = np.arange(0.28, 0.38, 0.02, 'float')
# Teneur en eau initiale
ti = np.arange(0.06, 0.14, 0.02, 'float')
# Perméabilité à saturation
Ks = np.arange(0.075, 0.325, 0.025, 'float')
# param fitting retention n
n = np.arange(2, 8, 0.5, 'float')
# param fitting retention alpha
alpha = np.arange(0.02, 0.05, 0.005, 'float')
print(len(list(itertools.product(tr, ts, ti, Ks, n, alpha))))
# Teneur en eau résiduelle
#%% Lancement du calcul
tasks = []
for p in itertools.product(tr, ts, ti, Ks, n, alpha):
# Définition des paramètres MVG
paramMVG = ParamMVG(tr=p[0], ts=p[1],ti=p[2], Ks=p[3], n=p[4], alpha=p[5])
paramMVG.porosity = paramMVG.ts
[twt,vol]=Forward(geometry,paramMVG,paramGPRMAX,temps,tmax_SWMS2D)
#%% test
# import time
# def connerie(ola):
# print(str(ola))
# time.sleep(ola)
# tasks = []
# for p in range(3000):#itertools.product(tr, ts, ti, Ks, n, alpha):
# # Définition des paramètres MVG
# #paramMVG = ParamMVG(tr=p[0], ts=p[1],ti=p[2], Ks=p[3], n=p[4], alpha=p[5])
# #paramMVG.porosity = paramMVG.ts
# tasks.append(dask.delayed(connerie)(p))
# dask.compute(tasks, scheduler='multiprocessing')