mirror of
https://github.com/Doctorado-ML/benchmark.git
synced 2025-08-17 16:35:54 +00:00
Add build grid experiments
This commit is contained in:
81
experiments/build_grid_experiments.py
Executable file
81
experiments/build_grid_experiments.py
Executable file
@@ -0,0 +1,81 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
import os
|
||||||
|
import argparse
|
||||||
|
import datetime
|
||||||
|
|
||||||
|
|
||||||
|
def parse_arguments():
|
||||||
|
ap = argparse.ArgumentParser()
|
||||||
|
ap.add_argument(
|
||||||
|
"-s",
|
||||||
|
"--score",
|
||||||
|
type=str,
|
||||||
|
required=False,
|
||||||
|
default="accuracy",
|
||||||
|
help="score used in gridsearch experiment",
|
||||||
|
)
|
||||||
|
ap.add_argument(
|
||||||
|
"-p",
|
||||||
|
"--platform",
|
||||||
|
type=str,
|
||||||
|
required=True,
|
||||||
|
choices=["pbs", "slurm"],
|
||||||
|
help="Platform used to run the gridsearch experiments {pbs, slurm}",
|
||||||
|
)
|
||||||
|
ap.add_argument(
|
||||||
|
"-m",
|
||||||
|
"--model",
|
||||||
|
type=str,
|
||||||
|
required=True,
|
||||||
|
help="model to use",
|
||||||
|
)
|
||||||
|
args = ap.parse_args()
|
||||||
|
|
||||||
|
return (args.score, args.platform, args.model)
|
||||||
|
|
||||||
|
|
||||||
|
def content(file_name):
|
||||||
|
with open(file_name) as f:
|
||||||
|
return f.read().splitlines()
|
||||||
|
|
||||||
|
|
||||||
|
def generate_experiment(dataset, model, score, platform):
|
||||||
|
path = content("path.txt")[0]
|
||||||
|
file_name = "experiment.pbs" if platform == "pbs" else "experiment.slurm"
|
||||||
|
lines = content(file_name)
|
||||||
|
lines.extend(content("script_grid.txt"))
|
||||||
|
day = (
|
||||||
|
f"{datetime.datetime.now().month:02d}{datetime.datetime.now().day:02d}"
|
||||||
|
)
|
||||||
|
file_name = f"grid_{model}_{platform}_{day}_{dataset}"
|
||||||
|
output_file_name = os.path.join("grid", f"{file_name}.sh")
|
||||||
|
strings = [
|
||||||
|
("<date>", day),
|
||||||
|
("<folder>", path),
|
||||||
|
("<score>", score),
|
||||||
|
("<model>", model),
|
||||||
|
("<file_name>", file_name),
|
||||||
|
("<dataset>", dataset),
|
||||||
|
]
|
||||||
|
data = lines.copy()
|
||||||
|
for item, value in strings:
|
||||||
|
data = [line.replace(item, value) for line in data]
|
||||||
|
with open(output_file_name, "w") as f:
|
||||||
|
f.write("\n".join(data))
|
||||||
|
return output_file_name
|
||||||
|
|
||||||
|
|
||||||
|
(
|
||||||
|
score,
|
||||||
|
platform,
|
||||||
|
model,
|
||||||
|
) = parse_arguments()
|
||||||
|
|
||||||
|
with open(os.path.join("..", "data", "all.txt")) as f:
|
||||||
|
lines = f.read().splitlines()
|
||||||
|
for dataset in lines:
|
||||||
|
if dataset.startswith("#") or dataset.strip() == "":
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
file_name = generate_experiment(dataset, model, score, platform)
|
||||||
|
print(f"Generated {file_name}")
|
2
experiments/grid/.gitignore
vendored
Normal file
2
experiments/grid/.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
*
|
||||||
|
!.gitignore
|
2
experiments/script_grid.txt
Normal file
2
experiments/script_grid.txt
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
cd <folder>
|
||||||
|
python src/grid.py -q 1 -m <model> -s <score> -d <dataset>
|
@@ -377,6 +377,7 @@ class GridSearch:
|
|||||||
score = grid.best_score_
|
score = grid.best_score_
|
||||||
hyperparameters = grid.best_params_
|
hyperparameters = grid.best_params_
|
||||||
self.results[name] = [score, hyperparameters, message]
|
self.results[name] = [score, hyperparameters, message]
|
||||||
|
print(f"{name:30s} {score} {hyperparameters} {message}")
|
||||||
|
|
||||||
def do_gridsearch(self):
|
def do_gridsearch(self):
|
||||||
now = time.time()
|
now = time.time()
|
||||||
|
Reference in New Issue
Block a user