make_mpi_ensemble_algorithm_experiment.py 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. import os
  2. import sys
  3. # check the python version
  4. if float(sys.version[:3]) <= 3.6:
  5. print("This script require Python 3. !")
  6. print("Try:")
  7. print("\n\tmodule load python3\n\n")
  8. print("and restart this script again.")
  9. print("Aborting...")
  10. sys.exit(1)
  11. if len(sys.argv) < 4:
  12. print('Bad arguments:', sys.argv)
  13. print('Usage:')
  14. print('\n\t python3 make_mpi_ensemble_algorithm_experiment.py where experiment ensemble_size run_folder_name\n')
  15. print('Arguments:\n')
  16. print('\twhere :\t\t\tWhere the experiment ensemble folders are located.')
  17. print('\texperiment :\t\tName of the experiment.')
  18. print('\tensemble_size :\t\tSize of the ensemble.')
  19. print('\trun_folder_name :\tOptional. Addtional name added to the "run_" folder name in plasim folder. Used to selected experiment executable. If not provided, assumes run folder is "run".')
  20. sys.exit(0)
  21. mail = 'jerome.sauer@uclouvain.be'
  22. walltime = '48:00:00'
  23. memory_per_task = '500mb'
  24. home_dir = os.getenv("HOME")
  25. scratch_dir = os.getenv("SCRATCH")
  26. plasim_dir = home_dir + "/PLASIM_ALGORITHM/"
  27. where = sys.argv[1]
  28. experiment = sys.argv[2]
  29. ensemble_size = int(sys.argv[3])
  30. run_folder = plasim_dir+"plasim/run"
  31. if len(sys.argv) == 5:
  32. run_folder_ext = sys.argv[4]
  33. run_folder += '_'+run_folder_ext
  34. if not os.path.isdir(run_folder):
  35. print("PLASIM run directory missing!")
  36. print("Run "+plasim_dir+"/most.x first.")
  37. print("Aborting...")
  38. sys.exit(1)
  39. print('Creating the directory holding the experiment ensemble...')
  40. experiment_folder = where+"/"+experiment+"/"
  41. os.system('mkdir -p '+experiment_folder)
  42. print('Creating the ensemble folders...')
  43. for i in range(1, ensemble_size+1):
  44. member_number = str(i).rjust(2, '0')
  45. ensemble_member_folder = experiment_folder+'run_'+experiment+'_'+member_number
  46. os.system('cp -r '+run_folder+' '+ensemble_member_folder)
  47. job_name = 'plasim_'+experiment+'_'+member_number
  48. f = open(ensemble_member_folder+'/PBS_'+job_name, 'w')
  49. f.write("""#!/bin/ksh
  50. #PBS -S /usr/bin/ksh
  51. #PBS -q nf
  52. #PBS -l EC_total_tasks=16
  53. #PBS -l EC_hyperthreads=1
  54. """)
  55. f.write('#PBS -N '+job_name+'\n')
  56. f.write('#PBS -o '+job_name+'.o\n')
  57. f.write('#PBS -e '+job_name+'.e\n\n')
  58. f.write('#PBS -m abe\n')
  59. f.write('#PBS -M '+mail+'\n\n')
  60. f.write('#PBS -l walltime='+walltime+'\n\n')
  61. f.write('#PBS -l EC_memory_per_task='+memory_per_task+'\n\n')
  62. f.write("""module switch PrgEnv-cray PrgEnv-gnu
  63. module load cray-snplauncher
  64. module load netcdf4
  65. module load netcdf
  66. module load cdo
  67. """)
  68. f.write('cd '+ensemble_member_folder+'\n')
  69. f.write('./most_plasim_run\n')
  70. f.close()
  71. print('Experiment ensemble created and available in the folder:')
  72. print(experiment_folder)