mirror of https://gitlab.com/pamhyr/pamhyr2
Compare commits
42 Commits
e86b84b0b9
...
da78d0cdb1
| Author | SHA1 | Date |
|---|---|---|
|
|
da78d0cdb1 | |
|
|
850db144ac | |
|
|
0f6709075f | |
|
|
0a0eeb3c3f | |
|
|
539b63f765 | |
|
|
19fedc2278 | |
|
|
f54dc07432 | |
|
|
3bbc55b4be | |
|
|
c0d4aced5e | |
|
|
421e6797f6 | |
|
|
0886956ec8 | |
|
|
9670bde56f | |
|
|
3277cf551b | |
|
|
ad5cc831a3 | |
|
|
1f35020e3f | |
|
|
7ef41ad886 | |
|
|
ada396f26d | |
|
|
674247db09 | |
|
|
5fecd29666 | |
|
|
71e1324a0f | |
|
|
07cae542b0 | |
|
|
b693f67b99 | |
|
|
18a3d51d75 | |
|
|
118a39bd5c | |
|
|
2009e8223b | |
|
|
bdaa38ea5c | |
|
|
713732b1dd | |
|
|
f053539cdd | |
|
|
fc6916bb3e | |
|
|
97c26cb4fb | |
|
|
10c98bb96e | |
|
|
7c2d9891d0 | |
|
|
3c3ac1f1df | |
|
|
80af278a0f | |
|
|
f254eaee25 | |
|
|
5adb0bdee5 | |
|
|
64c99d46d4 | |
|
|
0f0defb36f | |
|
|
1e1ee67d4b | |
|
|
5bc514c565 | |
|
|
1da3461dfe | |
|
|
dd5eecb1e2 |
|
|
@ -186,7 +186,7 @@ unittest:
|
||||||
- pip3 install -r ./full-requirements.txt
|
- pip3 install -r ./full-requirements.txt
|
||||||
- pip3 install -U -r ./full-requirements.txt
|
- pip3 install -U -r ./full-requirements.txt
|
||||||
- cd src
|
- cd src
|
||||||
- python3 -m unittest discover -t .
|
- python3.12 -m unittest discover -t .
|
||||||
|
|
||||||
test-pep8:
|
test-pep8:
|
||||||
stage: test
|
stage: test
|
||||||
|
|
|
||||||
16
README.md
16
README.md
|
|
@ -3,7 +3,7 @@
|
||||||
Pamhyr is a free and open source graphical user interface for 1D hydro-sedimentary
|
Pamhyr is a free and open source graphical user interface for 1D hydro-sedimentary
|
||||||
modelling of rivers.
|
modelling of rivers.
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
|
|
@ -21,9 +21,9 @@ modelling of rivers.
|
||||||
+ Create and edit study alternative scenario tree
|
+ Create and edit study alternative scenario tree
|
||||||
|
|
||||||
Let see the
|
Let see the
|
||||||
[documentation](https://gitlab.irstea.fr/theophile.terraz/pamhyr/-/wikis/home)
|
[documentation](https://gitlab.com/pamhyr/pamhyr2/-/wikis/home)
|
||||||
([:fr:](https://gitlab.irstea.fr/theophile.terraz/pamhyr/-/wikis/home-fr),
|
([:fr:](https://gitlab.com/pamhyr/pamhyr2/-/wikis/home-fr),
|
||||||
[:gb:](https://gitlab.irstea.fr/theophile.terraz/pamhyr/-/wikis/home-en))
|
[:gb:](https://gitlab.com/pamhyr/pamhyr2/-/wikis/home-en))
|
||||||
for more details.
|
for more details.
|
||||||
|
|
||||||
## Install
|
## Install
|
||||||
|
|
@ -31,11 +31,11 @@ for more details.
|
||||||
### GNU/Linux
|
### GNU/Linux
|
||||||
|
|
||||||
See documentation:
|
See documentation:
|
||||||
- [French :fr:](https://gitlab.irstea.fr/theophile.terraz/pamhyr/-/wikis/home/fr/Install%20on%20GNULinux)
|
- [French :fr:](https://gitlab.com/pamhyr/pamhyr2/-/wikis/home/fr/Install%20on%20GNULinux)
|
||||||
- [English :gb:](https://gitlab.irstea.fr/theophile.terraz/pamhyr/-/wikis/home/en/Install%20on%20GNULinux)
|
- [English :gb:](https://gitlab.com/pamhyr/pamhyr2/-/wikis/home/en/Install%20on%20GNULinux)
|
||||||
|
|
||||||
### Windows
|
### Windows
|
||||||
|
|
||||||
See documentation:
|
See documentation:
|
||||||
- [French :fr:](https://gitlab.irstea.fr/theophile.terraz/pamhyr/-/wikis/home/fr/Install%20on%20Windows)
|
- [French :fr:](https://gitlab.com/pamhyr/pamhyr2/-/wikis/home/fr/Install%20on%20Windows)
|
||||||
- [English :gb:](https://gitlab.irstea.fr/theophile.terraz/pamhyr/-/wikis/home/en/Install%20on%20Windows)
|
- [English :gb:](https://gitlab.com/pamhyr/pamhyr2/-/wikis/home/en/Install%20on%20Windows)
|
||||||
|
|
|
||||||
Binary file not shown.
|
|
@ -14,3 +14,4 @@ platformdirs>=4.2.0
|
||||||
pyshp>=2.3.1
|
pyshp>=2.3.1
|
||||||
rasterio==1.3.11
|
rasterio==1.3.11
|
||||||
#fortranformat==2.0.3
|
#fortranformat==2.0.3
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -66,7 +66,6 @@ class InternalMeshing(AMeshingTool):
|
||||||
return new_profiles
|
return new_profiles
|
||||||
|
|
||||||
def st_to_m(self, profiles, guide_list):
|
def st_to_m(self, profiles, guide_list):
|
||||||
|
|
||||||
guide_list = ["un"] + guide_list + ["np"]
|
guide_list = ["un"] + guide_list + ["np"]
|
||||||
max_values = [0] * (len(guide_list) - 1)
|
max_values = [0] * (len(guide_list) - 1)
|
||||||
max_values_index = [0] * (len(guide_list) - 1)
|
max_values_index = [0] * (len(guide_list) - 1)
|
||||||
|
|
@ -85,11 +84,13 @@ class InternalMeshing(AMeshingTool):
|
||||||
profiles[isect+1],
|
profiles[isect+1],
|
||||||
guide_list[i],
|
guide_list[i],
|
||||||
guide_list[i+1])
|
guide_list[i+1])
|
||||||
|
|
||||||
for isect in reversed(range(0, max_values_index[i])):
|
for isect in reversed(range(0, max_values_index[i])):
|
||||||
self.compl_sect(profiles[isect+1],
|
self.compl_sect(profiles[isect+1],
|
||||||
profiles[isect],
|
profiles[isect],
|
||||||
guide_list[i],
|
guide_list[i],
|
||||||
guide_list[i+1])
|
guide_list[i+1])
|
||||||
|
|
||||||
return profiles
|
return profiles
|
||||||
|
|
||||||
def interpolate_transversal_step(self,
|
def interpolate_transversal_step(self,
|
||||||
|
|
@ -129,6 +130,7 @@ class InternalMeshing(AMeshingTool):
|
||||||
p.name = f'interpol{p.rk}'
|
p.name = f'interpol{p.rk}'
|
||||||
new_profiles2.append(p)
|
new_profiles2.append(p)
|
||||||
new_profiles.append(new_profiles2)
|
new_profiles.append(new_profiles2)
|
||||||
|
|
||||||
return new_profiles
|
return new_profiles
|
||||||
|
|
||||||
def compl_sect(self, sect1, sect2, tag1, tag2):
|
def compl_sect(self, sect1, sect2, tag1, tag2):
|
||||||
|
|
@ -243,8 +245,9 @@ class InternalMeshing(AMeshingTool):
|
||||||
sect2.point(start2+len2).name = ''
|
sect2.point(start2+len2).name = ''
|
||||||
if tag1 != "un":
|
if tag1 != "un":
|
||||||
sect2.point(start2).name = tag1
|
sect2.point(start2).name = tag1
|
||||||
if tag1 != "np":
|
if tag2 != "np":
|
||||||
sect2.point(start2+len2).name = tag2
|
sect2.point(start2+len2).name = tag2
|
||||||
|
|
||||||
sect2.modified()
|
sect2.modified()
|
||||||
|
|
||||||
def update_rk(self, reach, begin_rk, end_rk,
|
def update_rk(self, reach, begin_rk, end_rk,
|
||||||
|
|
|
||||||
|
|
@ -34,15 +34,13 @@ class DIFAdisTSSpec(SQLSubModel):
|
||||||
|
|
||||||
def __init__(self, id: int = -1, method: str = "",
|
def __init__(self, id: int = -1, method: str = "",
|
||||||
status=None, owner_scenario=-1):
|
status=None, owner_scenario=-1):
|
||||||
super(DIFAdisTSSpec, self).__init__()
|
super(DIFAdisTSSpec, self).__init__(
|
||||||
|
id=id, status=status,
|
||||||
|
owner_scenario=owner_scenario
|
||||||
|
)
|
||||||
|
|
||||||
self._status = status
|
self._status = status
|
||||||
|
|
||||||
if id == -1:
|
|
||||||
self._id = DIFAdisTSSpec._id_cnt
|
|
||||||
else:
|
|
||||||
self._id = id
|
|
||||||
|
|
||||||
self._method = method
|
self._method = method
|
||||||
self._reach = None
|
self._reach = None
|
||||||
self._start_rk = None
|
self._start_rk = None
|
||||||
|
|
@ -52,8 +50,6 @@ class DIFAdisTSSpec(SQLSubModel):
|
||||||
self._c = None
|
self._c = None
|
||||||
self._enabled = True
|
self._enabled = True
|
||||||
|
|
||||||
DIFAdisTSSpec._id_cnt = max(DIFAdisTSSpec._id_cnt + 1, self._id)
|
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def _db_create(cls, execute, ext=""):
|
def _db_create(cls, execute, ext=""):
|
||||||
execute(f"""
|
execute(f"""
|
||||||
|
|
|
||||||
|
|
@ -1098,6 +1098,7 @@ class ProfileXYZ(Profile, SQLSubModel):
|
||||||
rk=self.rk,
|
rk=self.rk,
|
||||||
reach=self.reach,
|
reach=self.reach,
|
||||||
status=self._status)
|
status=self._status)
|
||||||
|
|
||||||
for i, k in enumerate(self.points):
|
for i, k in enumerate(self.points):
|
||||||
p.insert_point(i, k.copy())
|
p.insert_point(i, k.copy())
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -312,7 +312,7 @@ class Reservoir(SQLSubModel):
|
||||||
new_reservoir._node = next(
|
new_reservoir._node = next(
|
||||||
filter(
|
filter(
|
||||||
lambda n: n.id == node_id, data["nodes"]
|
lambda n: n.id == node_id, data["nodes"]
|
||||||
)
|
), None
|
||||||
)
|
)
|
||||||
|
|
||||||
data["reservoir"] = new_reservoir
|
data["reservoir"] = new_reservoir
|
||||||
|
|
|
||||||
|
|
@ -164,13 +164,194 @@ class AdisTS(CommandLineSolver):
|
||||||
return lst
|
return lst
|
||||||
|
|
||||||
def input_param(self):
|
def input_param(self):
|
||||||
name = self._study.name
|
name = self._study.name.replace(" ", "_")
|
||||||
return f"{name}.REP"
|
return f"{name}.REP"
|
||||||
|
|
||||||
def log_file(self):
|
def log_file(self):
|
||||||
name = self._study.name
|
name = self._study.name.replace(" ", "_")
|
||||||
return f"{name}.TRA"
|
return f"{name}.TRA"
|
||||||
|
|
||||||
|
def _export_ST(self, study, repertory, qlog, name="0"):
|
||||||
|
files = []
|
||||||
|
|
||||||
|
if qlog is not None:
|
||||||
|
qlog.put("Export ST file")
|
||||||
|
|
||||||
|
os.makedirs(os.path.join(repertory, "net"), exist_ok=True)
|
||||||
|
|
||||||
|
# Write header
|
||||||
|
edges = study.river.enable_edges()
|
||||||
|
for edge in edges:
|
||||||
|
name = f"Reach_{edge.id + 1:>3}".replace(" ", "0")
|
||||||
|
|
||||||
|
with adists_file_open(
|
||||||
|
os.path.join(repertory, "net", f"{name}.ST"),
|
||||||
|
"w+"
|
||||||
|
) as f:
|
||||||
|
files.append(str(os.path.join("net", f"{name}.ST")))
|
||||||
|
|
||||||
|
cnt_num = 1
|
||||||
|
for profile in edge.reach.profiles:
|
||||||
|
self._export_ST_profile_header(
|
||||||
|
f, files, profile, cnt_num
|
||||||
|
)
|
||||||
|
cnt_num += 1
|
||||||
|
|
||||||
|
# Points
|
||||||
|
for point in profile.points:
|
||||||
|
self._export_ST_point_line(
|
||||||
|
f, files, point
|
||||||
|
)
|
||||||
|
|
||||||
|
# Profile last line
|
||||||
|
f.write(f" 999.9990 999.9990 999.9990\n")
|
||||||
|
|
||||||
|
def _export_ST_profile_header(self, wfile, files,
|
||||||
|
profile, cnt):
|
||||||
|
num = f"{cnt:>6}"
|
||||||
|
c1 = f"{profile.code1:>6}"
|
||||||
|
c2 = f"{profile.code2:>6}"
|
||||||
|
t = f"{len(profile.points):>6}"
|
||||||
|
rk = f"{profile.rk:>12f}"[0:12]
|
||||||
|
pname = profile.name
|
||||||
|
if profile.name == "":
|
||||||
|
# Generate name from profile id prefixed with
|
||||||
|
# 'p' (and replace space char with '0' char)
|
||||||
|
pname = f"p{profile.id:>3}".replace(" ", "0")
|
||||||
|
name = f"{pname:<19}"
|
||||||
|
|
||||||
|
# Generate sediment additional data if available
|
||||||
|
sediment = ""
|
||||||
|
if profile.sl is not None:
|
||||||
|
if not any(filter(lambda f: ".GRA" in f, files)):
|
||||||
|
files.append(self._gra_file)
|
||||||
|
|
||||||
|
# Number of layers
|
||||||
|
nl = len(profile.sl)
|
||||||
|
sediment = f" {nl:>3}"
|
||||||
|
|
||||||
|
# Layers data
|
||||||
|
for layer in profile.sl.layers:
|
||||||
|
sediment += (
|
||||||
|
f" {layer.height:>10} {layer.d50:>10} " +
|
||||||
|
f"{layer.sigma:>10} " +
|
||||||
|
f"{layer.critical_constraint:>10}"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Profile header line
|
||||||
|
wfile.write(f"{num}{c1}{c2}{t} {rk} {pname} {sediment}\n")
|
||||||
|
|
||||||
|
def _export_ST_point_line(self, wfile, files, point):
|
||||||
|
x = f"{point.x:<12.4f}"[0:12]
|
||||||
|
y = f"{point.y:<12.4f}"[0:12]
|
||||||
|
z = f"{point.z:<12.4f}"[0:12]
|
||||||
|
n = f"{point.name:<3}"
|
||||||
|
|
||||||
|
# Generate sediment additional data if available
|
||||||
|
sediment = ""
|
||||||
|
prev = point.z
|
||||||
|
if point.sl is not None:
|
||||||
|
# Number of layers
|
||||||
|
nl = len(point.sl)
|
||||||
|
sediment = f"{nl:>3}"
|
||||||
|
|
||||||
|
# Layers data
|
||||||
|
for layer in point.sl.layers:
|
||||||
|
prev = round(prev - layer.height, 5)
|
||||||
|
sediment += (
|
||||||
|
f" {prev:>10} {layer.d50:>10} " +
|
||||||
|
f"{layer.sigma:>10} " +
|
||||||
|
f"{layer.critical_constraint:>10}"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Point line
|
||||||
|
wfile.write(f"{x} {y} {z} {n} {sediment}\n")
|
||||||
|
|
||||||
|
def _export_NET(self, study, repertory, qlog=None, name="0"):
|
||||||
|
|
||||||
|
if qlog is not None:
|
||||||
|
qlog.put("Export NET file")
|
||||||
|
|
||||||
|
with adists_file_open(
|
||||||
|
os.path.join(repertory, f"{name}.NET"), "w+") as f:
|
||||||
|
edges = study.river.enable_edges()
|
||||||
|
|
||||||
|
for e in edges:
|
||||||
|
name = f"Reach_{e.id + 1:>3}".replace(" ", "0")
|
||||||
|
id = name
|
||||||
|
|
||||||
|
n1 = f"{e.node1.id:3}".replace(" ", "x")
|
||||||
|
n2 = f"{e.node2.id:3}".replace(" ", "x")
|
||||||
|
file = os.path.join("net", name + ".ST")
|
||||||
|
|
||||||
|
f.write(f"{id} {n1} {n2} {file}\n")
|
||||||
|
|
||||||
|
def _export_fake_INI(self, study, repertory, qlog=None, name="0"):
|
||||||
|
if qlog is not None:
|
||||||
|
qlog.put("Export fake INI file")
|
||||||
|
|
||||||
|
with adists_file_open(
|
||||||
|
os.path.join(
|
||||||
|
repertory, "Mage_fin.ini"
|
||||||
|
), "w+"
|
||||||
|
) as f:
|
||||||
|
edges = study.river.enable_edges()
|
||||||
|
for i, edge in enumerate(edges):
|
||||||
|
lst = list(filter(
|
||||||
|
lambda f: f.is_full_defined(),
|
||||||
|
edge.frictions.frictions
|
||||||
|
))
|
||||||
|
rk_min = 9999999.9
|
||||||
|
rk_max = -9999999.9
|
||||||
|
coeff_min = -1.0
|
||||||
|
coeff_max = -1.0
|
||||||
|
for s in lst: # TODO optimise ?
|
||||||
|
if s.begin_rk > rk_max:
|
||||||
|
rk_max = s.begin_rk
|
||||||
|
coeff_max = s.begin_strickler
|
||||||
|
if s.begin_rk < rk_min:
|
||||||
|
rk_min = s.begin_rk
|
||||||
|
coeff_min = s.begin_strickler
|
||||||
|
if s.end_rk > rk_max:
|
||||||
|
rk_max = s.end_rk
|
||||||
|
coeff_max = s.end_strickler
|
||||||
|
if s.end_rk < rk_min:
|
||||||
|
rk_min = s.end_rk
|
||||||
|
coeff_min = s.end_strickler
|
||||||
|
|
||||||
|
print("min max", rk_min, rk_max)
|
||||||
|
|
||||||
|
def get_stricklers_from_rk(rk, lst):
|
||||||
|
print("rk", rk)
|
||||||
|
|
||||||
|
coeff = None
|
||||||
|
if rk > rk_max:
|
||||||
|
coeff = coeff_max
|
||||||
|
elif rk < rk_min:
|
||||||
|
coeff = coeff_min
|
||||||
|
else:
|
||||||
|
for s in lst:
|
||||||
|
if (rk >= s.begin_rk and rk <= s.end_rk or
|
||||||
|
rk <= s.begin_rk and rk >= s.end_rk):
|
||||||
|
coeff = s.begin_strickler # TODO: inerpolate
|
||||||
|
break
|
||||||
|
|
||||||
|
# TODO interpolation if rk is not in frictons
|
||||||
|
|
||||||
|
if coeff is None:
|
||||||
|
logger.error(
|
||||||
|
"Study frictions are not fully defined"
|
||||||
|
)
|
||||||
|
return None
|
||||||
|
|
||||||
|
return coeff.minor, coeff.medium
|
||||||
|
|
||||||
|
for j, profile in enumerate(edge.reach.profiles):
|
||||||
|
coef_min, coef_moy = get_stricklers_from_rk(profile.rk,
|
||||||
|
lst)
|
||||||
|
f.write(
|
||||||
|
f" {i+1:3}{j+1:4}{' '*116}{coef_min:9}{coef_moy:9}\n")
|
||||||
|
|
||||||
def _export_REP_additional_lines(self, study, rep_file):
|
def _export_REP_additional_lines(self, study, rep_file):
|
||||||
lines = filter(
|
lines = filter(
|
||||||
lambda line: line.is_enabled(),
|
lambda line: line.is_enabled(),
|
||||||
|
|
@ -192,7 +373,7 @@ class AdisTS(CommandLineSolver):
|
||||||
), "w+"
|
), "w+"
|
||||||
) as f:
|
) as f:
|
||||||
path = os.path.join("..", mage_rep, name)
|
path = os.path.join("..", mage_rep, name)
|
||||||
f.write(f"NET {path}.NET\n")
|
f.write(f"NET {name}.NET\n")
|
||||||
f.write(f"REP {path}.REP\n")
|
f.write(f"REP {path}.REP\n")
|
||||||
|
|
||||||
for file in files:
|
for file in files:
|
||||||
|
|
@ -201,13 +382,25 @@ class AdisTS(CommandLineSolver):
|
||||||
|
|
||||||
self._export_REP_additional_lines(study, f)
|
self._export_REP_additional_lines(study, f)
|
||||||
|
|
||||||
path_mage_net = os.path.join(os.path.abspath(
|
self._export_ST(study, repertory, qlog, name=name)
|
||||||
os.path.join(repertory, os.pardir)
|
self._export_NET(study, repertory, qlog, name=name)
|
||||||
), os.path.join(mage_rep, "net"))
|
|
||||||
path_adists_net = os.path.join(repertory, "net")
|
|
||||||
|
|
||||||
if os.path.exists(path_mage_net):
|
# fake mage_fin.ini:
|
||||||
shutil.copytree(path_mage_net, path_adists_net, dirs_exist_ok=True)
|
|
||||||
|
path_mage = os.path.join(os.path.abspath(
|
||||||
|
os.path.join(repertory, os.pardir)), mage_rep)
|
||||||
|
self._export_fake_INI(study, path_mage,
|
||||||
|
qlog, name=name)
|
||||||
|
|
||||||
|
# path_mage_net = os.path.join(os.path.abspath(
|
||||||
|
# os.path.join(repertory, os.pardir)
|
||||||
|
# ), os.path.join(mage_rep, "net"))
|
||||||
|
# path_adists_net = os.path.join(repertory, "net")
|
||||||
|
|
||||||
|
# if os.path.exists(path_mage_net):
|
||||||
|
# shutil.copytree(path_mage_net,
|
||||||
|
# path_adists_net,
|
||||||
|
# dirs_exist_ok=True)
|
||||||
|
|
||||||
@timer
|
@timer
|
||||||
def export(self, study, repertory, qlog=None):
|
def export(self, study, repertory, qlog=None):
|
||||||
|
|
|
||||||
|
|
@ -58,12 +58,12 @@ class Rubar3(CommandLineSolver):
|
||||||
("rubarbe_iovis", "n"),
|
("rubarbe_iovis", "n"),
|
||||||
("rubarbe_rep", "n"),
|
("rubarbe_rep", "n"),
|
||||||
("rubarbe_tinit", "000:00:00:00"),
|
("rubarbe_tinit", "000:00:00:00"),
|
||||||
("rubarbe_tmax", "999:99:99:00"),
|
("rubarbe_tmax", "000:01:00:00"), # 1 day
|
||||||
("rubarbe_tiopdt", "000:00:00:00"),
|
("rubarbe_tiopdt", "000:00:00:00"),
|
||||||
("rubarbe_dt", "5.0"),
|
("rubarbe_dt", "5.0"),
|
||||||
("rubarbe_ts", "999:99:99:00"),
|
("rubarbe_ts", "999:99:99:00"),
|
||||||
("rubarbe_dtsauv", "00:00:00:05"),
|
("rubarbe_dtsauv", "00:00:05:00"),
|
||||||
("rubarbe_psave", "00:00:00:05"),
|
("rubarbe_psave", "00:00:05:00"),
|
||||||
("rubarbe_fdeb1", "1"),
|
("rubarbe_fdeb1", "1"),
|
||||||
("rubarbe_fdeb2", "10"),
|
("rubarbe_fdeb2", "10"),
|
||||||
("rubarbe_fdeb3", "100"),
|
("rubarbe_fdeb3", "100"),
|
||||||
|
|
@ -610,6 +610,28 @@ class Rubar3(CommandLineSolver):
|
||||||
)
|
)
|
||||||
|
|
||||||
ts = set()
|
ts = set()
|
||||||
|
timestamp = next(filter(
|
||||||
|
lambda p: p.name == 'rubarbe_tinit',
|
||||||
|
study.river.get_params(self._type).parameters
|
||||||
|
)).value
|
||||||
|
if timestamp.count(':') == 3:
|
||||||
|
timestamp = old_pamhyr_date_to_timestamp(timestamp)
|
||||||
|
ts.add(timestamp)
|
||||||
|
|
||||||
|
# add initial condition
|
||||||
|
for r, edge in enumerate(study.river.enable_edges()):
|
||||||
|
reach = edge.reach
|
||||||
|
ics = study.river.initial_conditions.get(edge)
|
||||||
|
q = ics.get_discharge()
|
||||||
|
z = ics.get_elevation()
|
||||||
|
k = 0
|
||||||
|
for i, j in zip(z, q):
|
||||||
|
v = reach.profiles[k].speed(i, j)
|
||||||
|
set_and_compute_limites(reachs[r][0], k, i, j, v)
|
||||||
|
k += 1
|
||||||
|
|
||||||
|
# start read
|
||||||
|
|
||||||
end = False
|
end = False
|
||||||
while True:
|
while True:
|
||||||
line = f.readline()
|
line = f.readline()
|
||||||
|
|
@ -649,6 +671,97 @@ class Rubar3(CommandLineSolver):
|
||||||
h, s, q, z = read_data_line(f)
|
h, s, q, z = read_data_line(f)
|
||||||
set_and_compute_limites(reach, ind, z+h, q, s)
|
set_and_compute_limites(reach, ind, z+h, q, s)
|
||||||
|
|
||||||
|
@timer
|
||||||
|
def write_bin(self, study, fname, results, qlog=None, name="0"):
|
||||||
|
logger.info(f"write_bin: Start writing '{fname}' ...")
|
||||||
|
|
||||||
|
with open(fname, "wb") as f:
|
||||||
|
def newline(j): return np.asarray([j], dtype=np.int32).tofile(f)
|
||||||
|
def endline(j): return np.asarray([j], dtype=np.int32).tofile(f)
|
||||||
|
|
||||||
|
def write_int(i):
|
||||||
|
newline(len(i)*4)
|
||||||
|
np.array(i, dtype=np.int32).tofile(f)
|
||||||
|
endline(len(i)*4)
|
||||||
|
|
||||||
|
def write_float(i):
|
||||||
|
newline(len(i)*4)
|
||||||
|
np.array(i, dtype=np.float32).tofile(f)
|
||||||
|
endline(len(i)*4)
|
||||||
|
|
||||||
|
def write_float64(i):
|
||||||
|
newline(len(i)*8)
|
||||||
|
np.array(i, dtype=np.float64).tofile(f)
|
||||||
|
endline(len(i)*8)
|
||||||
|
|
||||||
|
def write_float64(i):
|
||||||
|
newline(len(i)*8)
|
||||||
|
np.array(i, dtype=np.float64).tofile(f)
|
||||||
|
endline(len(i)*8)
|
||||||
|
|
||||||
|
def write_data(npts, t, a, val):
|
||||||
|
newline(npts*4 + 13)
|
||||||
|
np.array(npts, dtype=np.int32).tofile(f)
|
||||||
|
np.array(t, dtype=np.float64).tofile(f)
|
||||||
|
np.array(bytearray(a.encode()), dtype=np.byte).tofile(f)
|
||||||
|
np.array(val, dtype=np.float32).tofile(f)
|
||||||
|
endline(npts*4 + 13)
|
||||||
|
|
||||||
|
ts_list = sorted(results.get("timestamps"))
|
||||||
|
profiles = []
|
||||||
|
for r in results.river.reachs:
|
||||||
|
profiles += r.profiles
|
||||||
|
|
||||||
|
# Meta data (1st line)
|
||||||
|
nb_reach = len(results.river)
|
||||||
|
nb_profile = len(profiles)
|
||||||
|
write_int([nb_reach, nb_profile, "82"])
|
||||||
|
|
||||||
|
# Reach information (2nd line)
|
||||||
|
is1 = []
|
||||||
|
is2 = []
|
||||||
|
ltmp = []
|
||||||
|
i = 1
|
||||||
|
for r in results.river.reachs:
|
||||||
|
j = i+len(r)-1
|
||||||
|
ltmp += [i, j]
|
||||||
|
is1.append(i)
|
||||||
|
is2.append(j)
|
||||||
|
i += i+len(r)
|
||||||
|
write_int(ltmp)
|
||||||
|
|
||||||
|
# X (3rd line)
|
||||||
|
rk = []
|
||||||
|
for r in results.river.reachs:
|
||||||
|
rk += r.geometry.get_rk()
|
||||||
|
write_float(rk)
|
||||||
|
|
||||||
|
# Z and Y (4th line)
|
||||||
|
# ltmp = []
|
||||||
|
# for r in results.river.reachs:
|
||||||
|
# for p in r.prifiles:
|
||||||
|
# ltpm.append(p.rk)
|
||||||
|
write_float(3*nb_profile*[0.0])
|
||||||
|
|
||||||
|
# Data
|
||||||
|
|
||||||
|
for timestamp in ts_list:
|
||||||
|
q = list(
|
||||||
|
map(
|
||||||
|
lambda p: p.get_ts_key(timestamp, "Q"),
|
||||||
|
profiles
|
||||||
|
)
|
||||||
|
)
|
||||||
|
write_data(nb_profile, timestamp, "Q", q)
|
||||||
|
z = list(
|
||||||
|
map(
|
||||||
|
lambda p: p.get_ts_key(timestamp, "Z"),
|
||||||
|
profiles
|
||||||
|
)
|
||||||
|
)
|
||||||
|
write_data(nb_profile, timestamp, "Z", z)
|
||||||
|
logger.info(f"write_bin: ... end with {len(ts_list)} timestamps")
|
||||||
|
|
||||||
@timer
|
@timer
|
||||||
def results(self, study, repertory, qlog=None, name=None):
|
def results(self, study, repertory, qlog=None, name=None):
|
||||||
results = Results(
|
results = Results(
|
||||||
|
|
|
||||||
|
|
@ -302,7 +302,6 @@ class GeometryWindow(PamhyrWindow):
|
||||||
self.tableView.model().blockSignals(False)
|
self.tableView.model().blockSignals(False)
|
||||||
|
|
||||||
def edit_meshing(self):
|
def edit_meshing(self):
|
||||||
|
|
||||||
rows = list(
|
rows = list(
|
||||||
set(
|
set(
|
||||||
(i.row() for i in self.tableView.selectedIndexes())
|
(i.row() for i in self.tableView.selectedIndexes())
|
||||||
|
|
@ -326,6 +325,25 @@ class GeometryWindow(PamhyrWindow):
|
||||||
logger_exception(e)
|
logger_exception(e)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
ind = []
|
||||||
|
for i in range(self._reach.number_profiles):
|
||||||
|
if self._reach.profile(i).rk in selected_rk:
|
||||||
|
ind.append(i)
|
||||||
|
self.tableView.setFocus()
|
||||||
|
selection = self.tableView.selectionModel()
|
||||||
|
index = QItemSelection()
|
||||||
|
if len(ind) > 0:
|
||||||
|
for i in ind:
|
||||||
|
index.append(QItemSelectionRange(
|
||||||
|
self.tableView.model().index(i, 0))
|
||||||
|
)
|
||||||
|
selection.select(
|
||||||
|
index,
|
||||||
|
QItemSelectionModel.Rows |
|
||||||
|
QItemSelectionModel.ClearAndSelect |
|
||||||
|
QItemSelectionModel.Select
|
||||||
|
)
|
||||||
|
|
||||||
def _edit_meshing(self, data):
|
def _edit_meshing(self, data):
|
||||||
try:
|
try:
|
||||||
mesher = InternalMeshing()
|
mesher = InternalMeshing()
|
||||||
|
|
@ -371,9 +389,6 @@ class GeometryWindow(PamhyrWindow):
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger_exception(e)
|
logger_exception(e)
|
||||||
raise ExternFileMissingError(
|
raise ExternFileMissingError(
|
||||||
module="mage",
|
|
||||||
filename="MailleurTT",
|
|
||||||
path=MeshingWithMageMailleurTT._path(),
|
|
||||||
src_except=e
|
src_except=e
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -53,7 +53,8 @@ class LCTranslate(MainTranslate):
|
||||||
self._dict["y"] = _translate("Geometry", "Y (m)")
|
self._dict["y"] = _translate("Geometry", "Y (m)")
|
||||||
self._dict["z"] = _translate("Geometry", "Z (m)")
|
self._dict["z"] = _translate("Geometry", "Z (m)")
|
||||||
self._dict["file_lat"] = _translate(
|
self._dict["file_lat"] = _translate(
|
||||||
"LateralContribution", "Shapefile (*.LAT *.lat)")
|
"LateralContribution",
|
||||||
|
"Mage lateral contributions file (*.LAT *.lat)")
|
||||||
self._dict["file_all"] = _translate(
|
self._dict["file_all"] = _translate(
|
||||||
"LateralContribution", "All files (*)")
|
"LateralContribution", "All files (*)")
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2006,6 +2006,13 @@ class ApplicationWindow(QMainWindow, ListedSubWindow, WindowToolKit):
|
||||||
if res.river.reach(r).has_bedload():
|
if res.river.reach(r).has_bedload():
|
||||||
res.river.reach(r).bufferize(ts, "zfd")
|
res.river.reach(r).bufferize(ts, "zfd")
|
||||||
|
|
||||||
|
for res in (result3, result4, result5):
|
||||||
|
for r in range(int(res.get("nb_reach"))):
|
||||||
|
for key in ["Z", "Q", "V"]:
|
||||||
|
res.river.reach(r).bufferize(ts, key)
|
||||||
|
if res.river.reach(r).has_bedload():
|
||||||
|
res.river.reach(r).bufferize(ts, "zfd")
|
||||||
|
|
||||||
return [result4, result5, result3]
|
return [result4, result5, result3]
|
||||||
|
|
||||||
def open_results_adists(self):
|
def open_results_adists(self):
|
||||||
|
|
|
||||||
|
|
@ -19,7 +19,7 @@
|
||||||
from View.Tools.PamhyrWindow import PamhyrDialog
|
from View.Tools.PamhyrWindow import PamhyrDialog
|
||||||
|
|
||||||
from PyQt5.QtWidgets import (
|
from PyQt5.QtWidgets import (
|
||||||
QRadioButton, QCheckBox, QVBoxLayout, QLabel,
|
QRadioButton, QCheckBox, QVBoxLayout, QLabel, QFrame
|
||||||
)
|
)
|
||||||
|
|
||||||
from View.Results.translate import ResultsTranslate
|
from View.Results.translate import ResultsTranslate
|
||||||
|
|
@ -43,6 +43,7 @@ class CustomExportDialog(PamhyrDialog):
|
||||||
|
|
||||||
self.setup_radio_buttons_x()
|
self.setup_radio_buttons_x()
|
||||||
self.setup_radio_buttons_res()
|
self.setup_radio_buttons_res()
|
||||||
|
self.setup_label()
|
||||||
self.setup_envelop_box()
|
self.setup_envelop_box()
|
||||||
self.setup_check_boxes()
|
self.setup_check_boxes()
|
||||||
|
|
||||||
|
|
@ -87,6 +88,22 @@ class CustomExportDialog(PamhyrDialog):
|
||||||
|
|
||||||
layout.addStretch()
|
layout.addStretch()
|
||||||
|
|
||||||
|
def setup_label(self):
|
||||||
|
self._label = self.find(QLabel, "label_4")
|
||||||
|
self._label.setFrameStyle(QFrame.StyledPanel)
|
||||||
|
self._label.setStyleSheet('background-color: white')
|
||||||
|
self.set_label()
|
||||||
|
for r in self._radio:
|
||||||
|
r[1].clicked.connect(self.set_label)
|
||||||
|
|
||||||
|
def set_label(self):
|
||||||
|
if self._radio[0][1].isChecked():
|
||||||
|
self._label.setText(self._parent.text_bief() + "\n" +
|
||||||
|
self._parent.text_time())
|
||||||
|
else:
|
||||||
|
self._label.setText(self._parent.text_bief() + "\n" +
|
||||||
|
self._parent.text_profile())
|
||||||
|
|
||||||
def setup_envelop_box(self):
|
def setup_envelop_box(self):
|
||||||
layout = self.find(QVBoxLayout, "verticalLayout_x")
|
layout = self.find(QVBoxLayout, "verticalLayout_x")
|
||||||
self._envelop = QCheckBox(
|
self._envelop = QCheckBox(
|
||||||
|
|
|
||||||
|
|
@ -19,7 +19,7 @@
|
||||||
from View.Tools.PamhyrWindow import PamhyrDialog
|
from View.Tools.PamhyrWindow import PamhyrDialog
|
||||||
|
|
||||||
from PyQt5.QtWidgets import (
|
from PyQt5.QtWidgets import (
|
||||||
QRadioButton, QCheckBox, QVBoxLayout,
|
QRadioButton, QCheckBox, QVBoxLayout, QLabel, QFrame
|
||||||
)
|
)
|
||||||
|
|
||||||
from View.Results.translate import ResultsTranslate
|
from View.Results.translate import ResultsTranslate
|
||||||
|
|
@ -50,6 +50,7 @@ class CustomExportAdisDialog(PamhyrDialog):
|
||||||
|
|
||||||
self.setup_radio_buttons_x()
|
self.setup_radio_buttons_x()
|
||||||
self.setup_radio_buttons_pol()
|
self.setup_radio_buttons_pol()
|
||||||
|
self.setup_label()
|
||||||
self.setup_check_boxes()
|
self.setup_check_boxes()
|
||||||
|
|
||||||
self.value = None
|
self.value = None
|
||||||
|
|
@ -84,6 +85,22 @@ class CustomExportAdisDialog(PamhyrDialog):
|
||||||
self._radio2[0][1].setChecked(True)
|
self._radio2[0][1].setChecked(True)
|
||||||
layout.addStretch()
|
layout.addStretch()
|
||||||
|
|
||||||
|
def setup_label(self):
|
||||||
|
self._label = self.find(QLabel, "label_4")
|
||||||
|
self._label.setFrameStyle(QFrame.StyledPanel)
|
||||||
|
self._label.setStyleSheet('background-color: white')
|
||||||
|
self.set_label()
|
||||||
|
for r in self._radio:
|
||||||
|
r[1].clicked.connect(self.set_label)
|
||||||
|
|
||||||
|
def set_label(self):
|
||||||
|
if self._radio[0][1].isChecked():
|
||||||
|
self._label.setText(self._parent.text_bief() + "\n" +
|
||||||
|
self._parent.text_time())
|
||||||
|
else:
|
||||||
|
self._label.setText(self._parent.text_bief() + "\n" +
|
||||||
|
self._parent.text_profile())
|
||||||
|
|
||||||
def setup_check_boxes(self):
|
def setup_check_boxes(self):
|
||||||
self._check = []
|
self._check = []
|
||||||
layout = self.find(QVBoxLayout, "verticalLayout_y")
|
layout = self.find(QVBoxLayout, "verticalLayout_y")
|
||||||
|
|
|
||||||
|
|
@ -19,7 +19,7 @@
|
||||||
from View.Tools.PamhyrWindow import PamhyrDialog
|
from View.Tools.PamhyrWindow import PamhyrDialog
|
||||||
|
|
||||||
from PyQt5.QtWidgets import (
|
from PyQt5.QtWidgets import (
|
||||||
QRadioButton, QCheckBox, QVBoxLayout,
|
QRadioButton, QCheckBox, QVBoxLayout, QLabel, QFrame
|
||||||
)
|
)
|
||||||
|
|
||||||
from View.Results.CustomPlot.Translate import CustomPlotTranslate
|
from View.Results.CustomPlot.Translate import CustomPlotTranslate
|
||||||
|
|
@ -38,10 +38,12 @@ class CustomPlotValuesSelectionDialog(PamhyrDialog):
|
||||||
parent=parent
|
parent=parent
|
||||||
)
|
)
|
||||||
|
|
||||||
|
self._parent = parent
|
||||||
self._available_values_x = self._trad.get_dict("values_x")
|
self._available_values_x = self._trad.get_dict("values_x")
|
||||||
self._available_values_y = self._trad.get_dict("values_y")
|
self._available_values_y = self._trad.get_dict("values_y")
|
||||||
|
|
||||||
self.setup_radio_buttons()
|
self.setup_radio_buttons()
|
||||||
|
self.setup_label()
|
||||||
self.setup_envelop_box()
|
self.setup_envelop_box()
|
||||||
self.setup_check_boxs()
|
self.setup_check_boxs()
|
||||||
|
|
||||||
|
|
@ -62,6 +64,22 @@ class CustomPlotValuesSelectionDialog(PamhyrDialog):
|
||||||
self._radio[0][1].setChecked(True)
|
self._radio[0][1].setChecked(True)
|
||||||
layout.addStretch()
|
layout.addStretch()
|
||||||
|
|
||||||
|
def setup_label(self):
|
||||||
|
self._label = self.find(QLabel, "label_3")
|
||||||
|
self._label.setFrameStyle(QFrame.StyledPanel)
|
||||||
|
self._label.setStyleSheet('background-color: white')
|
||||||
|
self.set_label()
|
||||||
|
for r in self._radio:
|
||||||
|
r[1].clicked.connect(self.set_label)
|
||||||
|
|
||||||
|
def set_label(self):
|
||||||
|
if self._radio[0][1].isChecked():
|
||||||
|
self._label.setText(self._parent.text_bief() + "\n" +
|
||||||
|
self._parent.text_time())
|
||||||
|
else:
|
||||||
|
self._label.setText(self._parent.text_bief() + "\n" +
|
||||||
|
self._parent.text_profile())
|
||||||
|
|
||||||
def setup_envelop_box(self):
|
def setup_envelop_box(self):
|
||||||
self._envelop = []
|
self._envelop = []
|
||||||
layout = self.find(QVBoxLayout, "verticalLayout_x")
|
layout = self.find(QVBoxLayout, "verticalLayout_x")
|
||||||
|
|
|
||||||
|
|
@ -204,7 +204,8 @@ class CustomPlot(PamhyrPlot):
|
||||||
|
|
||||||
e = list(
|
e = list(
|
||||||
map(
|
map(
|
||||||
lambda p: max(self.get_ts_zmin(p, res_id)),
|
lambda p: max(self.get_ts_zmin(
|
||||||
|
p, self._current_res_id)),
|
||||||
range(len(reach))
|
range(len(reach))
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
@ -217,7 +218,8 @@ class CustomPlot(PamhyrPlot):
|
||||||
|
|
||||||
e = list(
|
e = list(
|
||||||
map(
|
map(
|
||||||
lambda p: min(self.get_ts_zmin(p, res_id)),
|
lambda p: min(self.get_ts_zmin(
|
||||||
|
p, self._current_res_id)),
|
||||||
range(len(reach))
|
range(len(reach))
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
|
||||||
|
|
@ -314,16 +314,12 @@ class ResultsWindow(PamhyrWindow):
|
||||||
super(ResultsWindow, self).closeEvent(event)
|
super(ResultsWindow, self).closeEvent(event)
|
||||||
|
|
||||||
def _compute_status_label(self):
|
def _compute_status_label(self):
|
||||||
# Timestamp
|
|
||||||
ts = self._timestamps[self._slider_time.value()]
|
|
||||||
|
|
||||||
t0 = datetime.fromtimestamp(0)
|
return (self.text_bief() + " | " +
|
||||||
fts = str(
|
self.text_profile() + " | " +
|
||||||
datetime.fromtimestamp(ts) - t0
|
self.text_time())
|
||||||
)
|
|
||||||
fts.replace("days", _translate("Results", "days"))\
|
|
||||||
.replace("day", _translate("Results", "day"))
|
|
||||||
|
|
||||||
|
def text_bief(self):
|
||||||
# Reach
|
# Reach
|
||||||
table = self.find(QTableView, f"tableView_reach")
|
table = self.find(QTableView, f"tableView_reach")
|
||||||
indexes = table.selectedIndexes()
|
indexes = table.selectedIndexes()
|
||||||
|
|
@ -331,7 +327,16 @@ class ResultsWindow(PamhyrWindow):
|
||||||
reach = self._study.river.enable_edges()[0]
|
reach = self._study.river.enable_edges()[0]
|
||||||
else:
|
else:
|
||||||
reach = self._study.river.enable_edges()[indexes[0].row()]
|
reach = self._study.river.enable_edges()[indexes[0].row()]
|
||||||
|
return f"{self._trad['reach']}: {reach.name}"
|
||||||
|
|
||||||
|
def text_profile(self):
|
||||||
|
# Reach
|
||||||
|
table = self.find(QTableView, f"tableView_reach")
|
||||||
|
indexes = table.selectedIndexes()
|
||||||
|
if len(indexes) == 0:
|
||||||
|
reach = self._study.river.enable_edges()[0]
|
||||||
|
else:
|
||||||
|
reach = self._study.river.enable_edges()[indexes[0].row()]
|
||||||
# Profile
|
# Profile
|
||||||
table = self.find(QTableView, f"tableView_profile")
|
table = self.find(QTableView, f"tableView_profile")
|
||||||
indexes = table.selectedIndexes()
|
indexes = table.selectedIndexes()
|
||||||
|
|
@ -341,10 +346,22 @@ class ResultsWindow(PamhyrWindow):
|
||||||
profile = reach.reach.profile(indexes[0].row())
|
profile = reach.reach.profile(indexes[0].row())
|
||||||
|
|
||||||
pname = profile.name if profile.name != "" else profile.rk
|
pname = profile.name if profile.name != "" else profile.rk
|
||||||
|
return f"{self._trad['cross_section']}: {pname}"
|
||||||
|
|
||||||
return (f"{self._trad['reach']}: {reach.name} | " +
|
def text_time(self):
|
||||||
f"{self._trad['cross_section']}: {pname} | " +
|
# Timestamp
|
||||||
f"{self._trad['unit_time_s']} : {fts} ({ts} sec)")
|
ts = self._timestamps[self._slider_time.value()]
|
||||||
|
|
||||||
|
t0 = datetime.fromtimestamp(0)
|
||||||
|
fts = str(
|
||||||
|
datetime.fromtimestamp(ts) - t0
|
||||||
|
)
|
||||||
|
fts = str(
|
||||||
|
datetime.fromtimestamp(ts) - t0
|
||||||
|
)
|
||||||
|
fts.replace("days", _translate("Results", "days"))\
|
||||||
|
.replace("day", _translate("Results", "day"))
|
||||||
|
return f"{self._trad['time']} : {fts} ({ts} sec)"
|
||||||
|
|
||||||
def setup_statusbar(self):
|
def setup_statusbar(self):
|
||||||
txt = self._compute_status_label()
|
txt = self._compute_status_label()
|
||||||
|
|
@ -779,20 +796,29 @@ class ResultsWindow(PamhyrWindow):
|
||||||
first_line.append(f"Profile: {pname}")
|
first_line.append(f"Profile: {pname}")
|
||||||
val_dict = self._export_time(profile_id, y, solver_id)
|
val_dict = self._export_time(profile_id, y, solver_id)
|
||||||
|
|
||||||
with open(filename, 'w', newline='') as csvfile:
|
try:
|
||||||
writer = csv.writer(csvfile, delimiter=',',
|
with open(filename, 'w', newline='') as csvfile:
|
||||||
quotechar='|', quoting=csv.QUOTE_MINIMAL)
|
writer = csv.writer(csvfile, delimiter=',',
|
||||||
dict_x = self._trad.get_dict("values_x")
|
quotechar='|', quoting=csv.QUOTE_MINIMAL)
|
||||||
header = []
|
dict_x = self._trad.get_dict("values_x")
|
||||||
writer.writerow(first_line)
|
header = []
|
||||||
for text in val_dict.keys():
|
writer.writerow(first_line)
|
||||||
header.append(text)
|
for text in val_dict.keys():
|
||||||
writer.writerow(header)
|
header.append(text)
|
||||||
for row in range(len(val_dict[dict_x[x]])):
|
writer.writerow(header)
|
||||||
line = []
|
for row in range(len(val_dict[dict_x[x]])):
|
||||||
for var in val_dict.keys():
|
line = []
|
||||||
line.append(val_dict[var][row])
|
for var in val_dict.keys():
|
||||||
writer.writerow(line)
|
line.append(val_dict[var][row])
|
||||||
|
writer.writerow(line)
|
||||||
|
self._timer.stop()
|
||||||
|
except Exception as e:
|
||||||
|
self.message_box(
|
||||||
|
window_title=self._trad["Warning"],
|
||||||
|
text=self._trad["mb_write_error"],
|
||||||
|
informative_text=self._trad["mb_close_file"]
|
||||||
|
)
|
||||||
|
logger_exception(e)
|
||||||
|
|
||||||
def export_all(self, reach, directory, timestamps):
|
def export_all(self, reach, directory, timestamps):
|
||||||
name = reach.name
|
name = reach.name
|
||||||
|
|
@ -805,17 +831,25 @@ class ResultsWindow(PamhyrWindow):
|
||||||
f"reach_{name}.csv"
|
f"reach_{name}.csv"
|
||||||
)
|
)
|
||||||
|
|
||||||
with open(file_name, 'w', newline='') as csvfile:
|
try:
|
||||||
writer = csv.writer(csvfile, delimiter=',',
|
with open(file_name, 'w', newline='') as csvfile:
|
||||||
quotechar='|', quoting=csv.QUOTE_MINIMAL)
|
writer = csv.writer(csvfile, delimiter=',',
|
||||||
ts = timestamps[0]
|
quotechar='|', quoting=csv.QUOTE_MINIMAL)
|
||||||
writer.writerow(self._table["raw_data"]._headers)
|
ts = timestamps[0]
|
||||||
for row in range(self._table["raw_data"].rowCount()):
|
writer.writerow(self._table["raw_data"]._headers)
|
||||||
line = []
|
for row in range(self._table["raw_data"].rowCount()):
|
||||||
for column in range(self._table["raw_data"].columnCount()):
|
line = []
|
||||||
index = self._table["raw_data"].index(row, column)
|
for column in range(self._table["raw_data"].columnCount()):
|
||||||
line.append(self._table["raw_data"].data(index))
|
index = self._table["raw_data"].index(row, column)
|
||||||
writer.writerow(line)
|
line.append(self._table["raw_data"].data(index))
|
||||||
|
writer.writerow(line)
|
||||||
|
except Exception as e:
|
||||||
|
self.message_box(
|
||||||
|
window_title=self._trad["Warning"],
|
||||||
|
text=self._trad["mb_write_errore"],
|
||||||
|
informative_text=self._trad["mb_close_file"]
|
||||||
|
)
|
||||||
|
logger_exception(e)
|
||||||
|
|
||||||
def export_current(self):
|
def export_current(self):
|
||||||
self.file_dialog(
|
self.file_dialog(
|
||||||
|
|
|
||||||
|
|
@ -345,24 +345,29 @@ class ResultsWindowAdisTS(PamhyrWindow):
|
||||||
super(ResultsWindowAdisTS, self).closeEvent(event)
|
super(ResultsWindowAdisTS, self).closeEvent(event)
|
||||||
|
|
||||||
def _compute_status_label(self):
|
def _compute_status_label(self):
|
||||||
# Timestamp
|
return (self.text_bief() + " | " +
|
||||||
ts = self._timestamps[self._slider_time.value()]
|
self.text_profile() + " | " +
|
||||||
|
self.text_pollutant() + " | " +
|
||||||
t0 = datetime.fromtimestamp(0)
|
self.text_time())
|
||||||
fts = str(
|
|
||||||
datetime.fromtimestamp(ts) - t0
|
|
||||||
)
|
|
||||||
fts.replace("days", _translate("Results", "days"))\
|
|
||||||
.replace("day", _translate("Results", "day"))
|
|
||||||
|
|
||||||
|
def text_bief(self):
|
||||||
# Reach
|
# Reach
|
||||||
table = self.find(QTableView, f"tableView_reach")
|
table = self.find(QTableView, f"tableView_reach")
|
||||||
indexes = table.selectedIndexes()
|
indexes = table.selectedIndexes()
|
||||||
if len(indexes) == 0:
|
if len(indexes) == 0:
|
||||||
reach = self._study.river.edges()[0]
|
reach = self._study.river.enable_edges()[0]
|
||||||
else:
|
else:
|
||||||
reach = self._study.river.edges()[indexes[0].row()]
|
reach = self._study.river.enable_edges()[indexes[0].row()]
|
||||||
|
return f"{self._trad['reach']}: {reach.name}"
|
||||||
|
|
||||||
|
def text_profile(self):
|
||||||
|
# Reach
|
||||||
|
table = self.find(QTableView, f"tableView_reach")
|
||||||
|
indexes = table.selectedIndexes()
|
||||||
|
if len(indexes) == 0:
|
||||||
|
reach = self._study.river.enable_edges()[0]
|
||||||
|
else:
|
||||||
|
reach = self._study.river.enable_edges()[indexes[0].row()]
|
||||||
# Profile
|
# Profile
|
||||||
table = self.find(QTableView, f"tableView_profile")
|
table = self.find(QTableView, f"tableView_profile")
|
||||||
indexes = table.selectedIndexes()
|
indexes = table.selectedIndexes()
|
||||||
|
|
@ -372,7 +377,24 @@ class ResultsWindowAdisTS(PamhyrWindow):
|
||||||
profile = reach.reach.profile(indexes[0].row())
|
profile = reach.reach.profile(indexes[0].row())
|
||||||
|
|
||||||
pname = profile.name if profile.name != "" else profile.rk
|
pname = profile.name if profile.name != "" else profile.rk
|
||||||
|
return f"{self._trad['cross_section']}: {pname}"
|
||||||
|
|
||||||
|
def text_time(self):
|
||||||
|
# Timestamp
|
||||||
|
ts = self._timestamps[self._slider_time.value()]
|
||||||
|
|
||||||
|
t0 = datetime.fromtimestamp(0)
|
||||||
|
fts = str(
|
||||||
|
datetime.fromtimestamp(ts) - t0
|
||||||
|
)
|
||||||
|
fts = str(
|
||||||
|
datetime.fromtimestamp(ts) - t0
|
||||||
|
)
|
||||||
|
fts.replace("days", _translate("Results", "days"))\
|
||||||
|
.replace("day", _translate("Results", "day"))
|
||||||
|
return f"{self._trad['time']} : {fts} ({ts} sec)"
|
||||||
|
|
||||||
|
def text_pollutant(self):
|
||||||
# Pollutant
|
# Pollutant
|
||||||
table = self.find(QTableView, f"tableView_pollutants")
|
table = self.find(QTableView, f"tableView_pollutants")
|
||||||
indexes = table.selectedIndexes()
|
indexes = table.selectedIndexes()
|
||||||
|
|
@ -381,10 +403,7 @@ class ResultsWindowAdisTS(PamhyrWindow):
|
||||||
self._results.pollutants_list[i.row()+1] for i in indexes
|
self._results.pollutants_list[i.row()+1] for i in indexes
|
||||||
]
|
]
|
||||||
|
|
||||||
return (f"{self._trad['reach']}: {reach.name} | " +
|
return (f"Pollutant: {', '.join(self.pollutant_label)}")
|
||||||
f"{self._trad['cross_section']}: {pname} | " +
|
|
||||||
f"Pollutant: {', '.join(self.pollutant_label)} | " +
|
|
||||||
f"{self._trad['unit_time_s']} : {fts} ({ts} sec)")
|
|
||||||
|
|
||||||
def setup_statusbar(self):
|
def setup_statusbar(self):
|
||||||
txt = self._compute_status_label()
|
txt = self._compute_status_label()
|
||||||
|
|
|
||||||
|
|
@ -56,6 +56,13 @@ class ResultsTranslate(MainTranslate):
|
||||||
self._dict["ImageCoordinates"] = _translate(
|
self._dict["ImageCoordinates"] = _translate(
|
||||||
"Results", "Image coordinates"
|
"Results", "Image coordinates"
|
||||||
)
|
)
|
||||||
|
self._dict["mb_write_error"] = _translate(
|
||||||
|
"Results", "An error occured when writing to file"
|
||||||
|
)
|
||||||
|
self._dict["mb_close_file"] = _translate(
|
||||||
|
"Results",
|
||||||
|
"If the file is in use, close it and try again"
|
||||||
|
)
|
||||||
|
|
||||||
self._sub_dict["table_headers_reach"] = {
|
self._sub_dict["table_headers_reach"] = {
|
||||||
"name": _translate("Results", "Reach name"),
|
"name": _translate("Results", "Reach name"),
|
||||||
|
|
|
||||||
|
|
@ -94,7 +94,8 @@ class SelectSolverWindowAdisTS(PamhyrDialog):
|
||||||
)
|
)
|
||||||
|
|
||||||
solvers_mage = list(filter(
|
solvers_mage = list(filter(
|
||||||
lambda x: "mage" in x._type.lower(), self._config.solvers
|
lambda x: "mage" or "rubar" in x._type.lower(),
|
||||||
|
self._config.solvers
|
||||||
))
|
))
|
||||||
solvers_mage_names = list(map(lambda x: x._name, solvers_mage))
|
solvers_mage_names = list(map(lambda x: x._name, solvers_mage))
|
||||||
|
|
||||||
|
|
@ -184,6 +185,9 @@ class SolverLogWindowAdisTS(PamhyrWindow):
|
||||||
parent=parent
|
parent=parent
|
||||||
)
|
)
|
||||||
|
|
||||||
|
self._workdir = ""
|
||||||
|
self._workdir_mage = ""
|
||||||
|
|
||||||
self.setup_action()
|
self.setup_action()
|
||||||
self.setup_alarm()
|
self.setup_alarm()
|
||||||
self.setup_connections()
|
self.setup_connections()
|
||||||
|
|
@ -226,17 +230,47 @@ class SolverLogWindowAdisTS(PamhyrWindow):
|
||||||
self._alarm.timeout.connect(self.update)
|
self._alarm.timeout.connect(self.update)
|
||||||
|
|
||||||
def setup_workdir(self):
|
def setup_workdir(self):
|
||||||
self._workdir = ""
|
scenario = self._study.status.scenario
|
||||||
|
srep = scenario.workdir()
|
||||||
|
|
||||||
if self._study.filename == "":
|
if self._study.filename == "":
|
||||||
self._workdir = tempfile.TemporaryDirectory()
|
self._workdir = os.path.join(
|
||||||
|
tempfile.TemporaryDirectory(),
|
||||||
|
srep
|
||||||
|
)
|
||||||
else:
|
else:
|
||||||
self._workdir = os.path.join(
|
self._workdir = os.path.join(
|
||||||
os.path.dirname(self._study.filename),
|
os.path.dirname(self._study.filename),
|
||||||
"_PAMHYR_",
|
"_PAMHYR_",
|
||||||
self._study.name.replace(" ", "_"),
|
self._study.name.replace(" ", "_"),
|
||||||
self._solver.name.replace(" ", "_"),
|
self._solver.name.replace(" ", "_"),
|
||||||
|
srep
|
||||||
)
|
)
|
||||||
os.makedirs(self._workdir, exist_ok=True)
|
|
||||||
|
logger.info(f"Create workdir: '{self._workdir}'")
|
||||||
|
os.makedirs(self._workdir, exist_ok=True)
|
||||||
|
|
||||||
|
self.setup_mage_workdir()
|
||||||
|
|
||||||
|
def setup_mage_workdir(self):
|
||||||
|
scenario = self._study.status.scenario
|
||||||
|
srep = scenario.workdir()
|
||||||
|
|
||||||
|
if self._study.filename == "":
|
||||||
|
self._workdir_mage = os.path.join(
|
||||||
|
tempfile.TemporaryDirectory(),
|
||||||
|
srep
|
||||||
|
)
|
||||||
|
else:
|
||||||
|
self._workdir_mage = os.path.join(
|
||||||
|
os.path.dirname(self._study.filename),
|
||||||
|
"_PAMHYR_",
|
||||||
|
self._study.name.replace(" ", "_"),
|
||||||
|
self._mage_rep.replace(" ", "_"),
|
||||||
|
srep
|
||||||
|
)
|
||||||
|
|
||||||
|
logger.info(f"Create workdir: '{self._workdir_mage}'")
|
||||||
|
|
||||||
def setup_process(self):
|
def setup_process(self):
|
||||||
self._alarm.start(100)
|
self._alarm.start(100)
|
||||||
|
|
@ -252,7 +286,8 @@ class SolverLogWindowAdisTS(PamhyrWindow):
|
||||||
def export(self):
|
def export(self):
|
||||||
self._log(f" *** Export study {self._solver.name}", color="blue")
|
self._log(f" *** Export study {self._solver.name}", color="blue")
|
||||||
ok = self._solver.export(
|
ok = self._solver.export(
|
||||||
self._study, self._workdir, self._mage_rep, qlog=self._output
|
self._study, self._workdir, self._workdir_mage,
|
||||||
|
qlog=self._output
|
||||||
)
|
)
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
|
|
@ -366,7 +401,8 @@ class SolverLogWindowAdisTS(PamhyrWindow):
|
||||||
self._log(f" *** Export study {self._solver.name}", color="blue")
|
self._log(f" *** Export study {self._solver.name}", color="blue")
|
||||||
|
|
||||||
ok = self._solver.export(
|
ok = self._solver.export(
|
||||||
self._study, self._workdir, self._mage_rep, qlog=self._output
|
self._study, self._workdir, self._workdir_mage,
|
||||||
|
qlog=self._output
|
||||||
)
|
)
|
||||||
|
|
||||||
if not ok:
|
if not ok:
|
||||||
|
|
@ -442,12 +478,7 @@ class SolverLogWindowAdisTS(PamhyrWindow):
|
||||||
mage_solver = next(filter(
|
mage_solver = next(filter(
|
||||||
lambda x: x._name == self._mage_rep, self._config.solvers
|
lambda x: x._name == self._mage_rep, self._config.solvers
|
||||||
))
|
))
|
||||||
workdir_mage = os.path.join(
|
workdir_mage = self._workdir_mage
|
||||||
os.path.dirname(self._study.filename),
|
|
||||||
"_PAMHYR_",
|
|
||||||
self._study.name.replace(" ", "_"),
|
|
||||||
mage_solver.name.replace(" ", "_"),
|
|
||||||
)
|
|
||||||
|
|
||||||
def reading_fn():
|
def reading_fn():
|
||||||
self._results_mage = mage_solver.results(
|
self._results_mage = mage_solver.results(
|
||||||
|
|
|
||||||
|
|
@ -91,6 +91,7 @@ class WaitingDialog(PamhyrDialog):
|
||||||
parent=parent
|
parent=parent
|
||||||
)
|
)
|
||||||
self._to_close = False
|
self._to_close = False
|
||||||
|
self.setFixedSize(self.width(), self.height())
|
||||||
|
|
||||||
self._payload_fn = payload_fn
|
self._payload_fn = payload_fn
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -7,23 +7,13 @@
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>194</width>
|
<width>194</width>
|
||||||
<height>70</height>
|
<height>126</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
<string>Dialog</string>
|
<string>Dialog</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QGridLayout" name="gridLayout">
|
<layout class="QGridLayout" name="gridLayout">
|
||||||
<item row="4" column="0">
|
|
||||||
<widget class="QDialogButtonBox" name="buttonBox">
|
|
||||||
<property name="orientation">
|
|
||||||
<enum>Qt::Horizontal</enum>
|
|
||||||
</property>
|
|
||||||
<property name="standardButtons">
|
|
||||||
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="3" column="0">
|
<item row="3" column="0">
|
||||||
<widget class="QSplitter" name="splitter">
|
<widget class="QSplitter" name="splitter">
|
||||||
<property name="orientation">
|
<property name="orientation">
|
||||||
|
|
@ -64,6 +54,23 @@
|
||||||
</widget>
|
</widget>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item row="5" column="0">
|
||||||
|
<widget class="QDialogButtonBox" name="buttonBox">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="standardButtons">
|
||||||
|
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="4" column="0">
|
||||||
|
<widget class="QLabel" name="label_4">
|
||||||
|
<property name="text">
|
||||||
|
<string>TextLabel</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
<resources/>
|
<resources/>
|
||||||
|
|
|
||||||
|
|
@ -7,14 +7,24 @@
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>414</width>
|
<width>414</width>
|
||||||
<height>70</height>
|
<height>132</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
<string>Dialog</string>
|
<string>Dialog</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QGridLayout" name="gridLayout">
|
<layout class="QGridLayout" name="gridLayout">
|
||||||
<item row="0" column="0">
|
<item row="3" column="0">
|
||||||
|
<widget class="QDialogButtonBox" name="buttonBox">
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
<property name="standardButtons">
|
||||||
|
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="1" column="0">
|
||||||
<widget class="QSplitter" name="splitter">
|
<widget class="QSplitter" name="splitter">
|
||||||
<property name="orientation">
|
<property name="orientation">
|
||||||
<enum>Qt::Horizontal</enum>
|
<enum>Qt::Horizontal</enum>
|
||||||
|
|
@ -43,13 +53,10 @@
|
||||||
</widget>
|
</widget>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0">
|
<item row="2" column="0">
|
||||||
<widget class="QDialogButtonBox" name="buttonBox">
|
<widget class="QLabel" name="label_3">
|
||||||
<property name="orientation">
|
<property name="text">
|
||||||
<enum>Qt::Horizontal</enum>
|
<string>TextLabel</string>
|
||||||
</property>
|
|
||||||
<property name="standardButtons">
|
|
||||||
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
|
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,7 @@
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="label">
|
<widget class="QLabel" name="label">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Upstream height (m)</string>
|
<string>Upstream elevation (m)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
|
@ -70,7 +70,7 @@
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="label_2">
|
<widget class="QLabel" name="label_2">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Downstream height (m)</string>
|
<string>Downstream elevation (m)</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
|
|
||||||
|
|
@ -101,6 +101,7 @@ class Config(SQL):
|
||||||
# Add default solver
|
# Add default solver
|
||||||
posix = os.name == 'posix'
|
posix = os.name == 'posix'
|
||||||
ext = "" if posix else ".exe"
|
ext = "" if posix else ".exe"
|
||||||
|
path = os.path.join("@install_dir", "mage8", f"mage{ext}")
|
||||||
|
|
||||||
self.execute(f"""
|
self.execute(f"""
|
||||||
INSERT INTO solver VALUES (
|
INSERT INTO solver VALUES (
|
||||||
|
|
@ -111,7 +112,7 @@ class Config(SQL):
|
||||||
'', '', '',
|
'', '', '',
|
||||||
|
|
||||||
'',
|
'',
|
||||||
'@install_dir/mage/mage{ext} @args @input',
|
'{path} @args @input',
|
||||||
''
|
''
|
||||||
)
|
)
|
||||||
""")
|
""")
|
||||||
|
|
@ -135,16 +136,19 @@ class Config(SQL):
|
||||||
if int(release) < 5:
|
if int(release) < 5:
|
||||||
posix = os.name == 'posix'
|
posix = os.name == 'posix'
|
||||||
ext = "" if posix else ".exe"
|
ext = "" if posix else ".exe"
|
||||||
|
path = os.path.join("@install_dir", "mage8", f"mage{ext}")
|
||||||
|
|
||||||
self.execute(
|
self.execute(
|
||||||
"UPDATE solver SET cmd_solver=" +
|
"UPDATE solver SET cmd_solver=" +
|
||||||
f"'@install_dir/mage8/mage{ext} @args @input' "
|
f"'{path} @args @input' "
|
||||||
"WHERE name='default-mage'"
|
"WHERE name='default-mage'"
|
||||||
)
|
)
|
||||||
|
|
||||||
if int(release) < 6:
|
if int(release) < 6:
|
||||||
posix = os.name == 'posix'
|
posix = os.name == 'posix'
|
||||||
ext = "" if posix else ".exe"
|
ext = "" if posix else ".exe"
|
||||||
|
path = os.path.join("@install_dir",
|
||||||
|
"adists", f"adists{ext}")
|
||||||
|
|
||||||
self.execute(f"""
|
self.execute(f"""
|
||||||
INSERT INTO solver VALUES (
|
INSERT INTO solver VALUES (
|
||||||
|
|
@ -155,19 +159,21 @@ class Config(SQL):
|
||||||
'', '', '',
|
'', '', '',
|
||||||
|
|
||||||
'',
|
'',
|
||||||
'@install_dir/adists/adists{ext} @args @input',
|
'{path} @args @input',
|
||||||
''
|
''
|
||||||
)
|
)
|
||||||
""")
|
""")
|
||||||
self.execute(
|
self.execute(
|
||||||
"UPDATE solver SET cmd_solver=" +
|
"UPDATE solver SET cmd_solver=" +
|
||||||
f"'@install_dir/adists/adists{ext} @args @input' "
|
f"'{path} @args @input' "
|
||||||
"WHERE name='default-AdisTS'"
|
"WHERE name='default-AdisTS'"
|
||||||
)
|
)
|
||||||
|
|
||||||
if int(release) < 7:
|
if int(release) < 7:
|
||||||
posix = os.name == 'posix'
|
posix = os.name == 'posix'
|
||||||
ext = "" if posix else ".exe"
|
ext = "" if posix else ".exe"
|
||||||
|
path = os.path.join("@install_dir",
|
||||||
|
"rubar", f"rubarbe{ext}")
|
||||||
|
|
||||||
self.execute(f"""
|
self.execute(f"""
|
||||||
INSERT INTO solver VALUES (
|
INSERT INTO solver VALUES (
|
||||||
|
|
@ -178,13 +184,13 @@ class Config(SQL):
|
||||||
'', '', '',
|
'', '', '',
|
||||||
|
|
||||||
'',
|
'',
|
||||||
'@install_dir/rubar/rubar3{ext} @args @input',
|
'{path} @args @input',
|
||||||
''
|
''
|
||||||
)
|
)
|
||||||
""")
|
""")
|
||||||
self.execute(
|
self.execute(
|
||||||
"UPDATE solver SET cmd_solver=" +
|
"UPDATE solver SET cmd_solver=" +
|
||||||
f"'@install_dir/rubar/rubar3{ext} @args @input' "
|
f"'{path} @args @input' "
|
||||||
"WHERE name='default-Rubar3'"
|
"WHERE name='default-Rubar3'"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -350,14 +356,24 @@ class Config(SQL):
|
||||||
ctor = solver_type_list["mage8"]
|
ctor = solver_type_list["mage8"]
|
||||||
new = ctor("default-mage")
|
new = ctor("default-mage")
|
||||||
new._description = "Default Pamhyr2 mage 8 version"
|
new._description = "Default Pamhyr2 mage 8 version"
|
||||||
new._cmd_solver = f""""@install_dir/mage8/mage{ext}" @args @input"""
|
path = os.path.join("@install_dir", "mage8", "mage")
|
||||||
|
new._cmd_solver = f""""{path}{ext}" @args @input"""
|
||||||
self._solvers.append(new)
|
self._solvers.append(new)
|
||||||
|
|
||||||
# AdisTS
|
# AdisTS
|
||||||
ctor = solver_type_list["adistswc"]
|
ctor = solver_type_list["adistswc"]
|
||||||
new = ctor("default-AdisTS")
|
new = ctor("default-AdisTS")
|
||||||
new._description = "Default Pamhyr2 AdisTS version"
|
new._description = "Default Pamhyr2 AdisTS version"
|
||||||
new._cmd_solver = f""""@install_dir/adists/adists{ext}" @args @input"""
|
path = os.path.join("@install_dir", "adists", "adists")
|
||||||
|
new._cmd_solver = f""""{path}{ext}" @args @input"""
|
||||||
|
self._solvers.append(new)
|
||||||
|
|
||||||
|
# Rubar3
|
||||||
|
ctor = solver_type_list["rubar3"]
|
||||||
|
new = ctor("default-Rubar3")
|
||||||
|
new._description = "Default Pamhyr2 Rubar 3 version"
|
||||||
|
path = os.path.join("@install_dir", "rubar", f"rubarbe{ext}")
|
||||||
|
new._cmd_solver = f""""{path}" @args @input"""
|
||||||
self._solvers.append(new)
|
self._solvers.append(new)
|
||||||
|
|
||||||
# Rubar3
|
# Rubar3
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue