-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgeos-chem-schedule.py
executable file
·87 lines (72 loc) · 3.12 KB
/
geos-chem-schedule.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
#!/usr/bin/env python
"""
A script to split up GEOS-Chem jobs and submit via a job scheduler
Notes
-------
- Jobs can be split by day, week, month, or numbers of months etc...
- This allows simple management of job submission
- Large jobs can also be fitted in queues with lower time limits
- fairer access
- You can either pass as arguments or run a UI if no arguments are passed.
- The jobs can call the next job in the sequence meaning you can submit in the same way.
- see "$ python geos-chem-schedule.py --help" for more information.
"""
import subprocess
import json
import os
import stat
import sys
import shutil
import datetime
import calendar
from dateutil.relativedelta import relativedelta
import pytest
# Import the functions called here for now...
from core import GC_Job, get_arguments, check_inputs, get_start_and_end_dates, list_of_times_to_run, backup_the_input_files, create_the_input_files, run_job_script
from core import create_PBS_queue_files, create_PBS_run_script
from core import create_SLURM_queue_files, create_SLURM_run_script, create_SLURM_run_script2submit_together
# Master debug switch for the main driver
DEBUG = False
def main(debug=DEBUG):
"""
Run the main driver of the 'geos-chem-schedule' module
"""
# Get the default inputs as a class
inputs = GC_Job()
# Get the arguments from the command line or UI
inputs = get_arguments(inputs, debug=DEBUG)
# Check all the inputs are valid
inputs = check_inputs(inputs, debug=DEBUG)
# Check the start and end dates are compatible with the script
start_date, end_date = get_start_and_end_dates()
# Calculate the list of times to run the model for
times = list_of_times_to_run(start_date, end_date, inputs)
# Make a backup of the input.geos file
backup_the_input_files(inputs=inputs)
# Create the individual time input files
create_the_input_files(times, inputs=inputs)
# Create the files required by the specific scheduler
if inputs.scheduler == 'PBS':
# Create the PBS queue files
create_PBS_queue_files(times, inputs=inputs, debug=DEBUG)
# Create the PSB run script
create_PBS_run_script(time)
# Send the script to the queue if requested
run_job_script(inputs.run_script, filename="run_geos_PBS.sh")
elif (inputs.scheduler == 'SLURM') and (not inputs.submit_jobs_together):
# Create the SLURM queue files
create_SLURM_queue_files(times, inputs=inputs, debug=DEBUG)
# Create the SLURM run script
create_SLURM_run_script(time)
# Send the script to the queue if requested
run_job_script(inputs.run_script, filename="run_geos_SLURM.sh")
elif (inputs.scheduler == 'SLURM') and (inputs.submit_jobs_together):
# Create the SLURM queue files
create_SLURM_queue_files(times, inputs=inputs, debug=DEBUG)
# Create the SLURM run script
create_SLURM_run_script2submit_together(times)
# Send the script to the queue if requested
filename = "run_geos_SLURM_queue_all_jobs.sh"
run_job_script(inputs.run_script, filename=filename)
if __name__ == '__main__':
main(debug=DEBUG)