-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmake_targets.py
executable file
·114 lines (104 loc) · 4.74 KB
/
make_targets.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
#! /usr/bin/env python
import argparse,os,subprocess,json
from wpipe import *
import glob
def register(PID,task_name):
myPipe = Pipeline.get(PID)
myTask = Task(task_name,myPipe).create()
_t = Task.add_mask(myTask,'*','start',task_name)
return
def discover_targets(Pipe,config_file,data_dir):
myPipe = Pipe
myTarget = Target(name='start_targ', pipeline=myPipe).create()
targlist = get_targ_list(data_dir)
_c = Configuration(name='test_config',target=myTarget).create()
config_id = _c['config_id'].values[0]
myConfig = Configuration.get(config_id)
params={'a':0,'x':12,'note':'testing this'}
myParams = Parameters(params).create(myConfig)
_job = Job(config=myConfig).create() #need to create dummy job to keep track of events
job_id = int(_job.job_id)
myJob = Job.get(job_id)
for targ in targlist:
myTarget = Target(name=targ,pipeline=myPipe).create(create_dir=True)
#print("NAME",myTarget.name[0])
_params = json.load(open(config_file))[0]
conffilename = config_file.split('/')[-1]
confname = conffilename.split('.')[0]
conf = Configuration(name=confname,target=myTarget).create(params=_params,create_dir=True)
confret = Configuration.get(int(conf['config_id'].item()))
targid = myTarget['target_id'].item()
logprint(confret,myJob,''.join(['Target ',targ,' with ID ',str(targid),' created with Configuration ',confname,' and ID ',str(confret.config_id)]))
_t = subprocess.run(['cp',config_file,conf.confpath.values[0]+'/'],stdout=subprocess.PIPE)
_dp = DataProduct(filename=conffilename,relativepath=myPipe.config_root,group='conf',configuration=conf).create()
targetfiles = get_target_files(data_dir,targ)
comp_name = 'completed'+targ
options = {comp_name:0}
_opt = Options(options).create('job',job_id)
for files in targetfiles:
subprocess.run(['cp',files,conf.rawpath.values[0]],stdout=subprocess.PIPE)
filename = files.split('/')[-1]
_dp = DataProduct(filename=filename,relativepath=conf.rawpath.values[0],group='raw',configuration=conf).create()
testtarg = Target.get(int(_dp.target_id))
send(_dp,conf,comp_name,len(targetfiles),myJob) #send catalog to next step
return
def get_targ_list(data_dir):
data = os.listdir(data_dir)
target_names= []
for dat in data:
# each prefix is a target
checkname = dat.split('.')[:-1][0]
if checkname in target_names:
continue
target_names.append(dat.split('.')[:-1][0])
return target_names
def get_target_files(data_dir,targ):
targfiles = glob.glob(data_dir+'/'+targ+'*')
return targfiles
def send(dp,conf,comp_name,total,job):
filepath = dp.relativepath[0]+'/'+dp.filename[0]
dpid = int(dp.dp_id)
confid = int(conf.config_id)
print('TEST',dp.filename[0],filepath)
data = np.loadtxt(filepath, dtype=str, usecols=0)
if 'type' in str(data[0]):
print('File ',filepath,' has type keyword, assuming STIPS-ready')
event = Job.getEvent(job,'new_stips_catalog',options={'dp_id':dpid,'to_run':total,'name':comp_name})
fire(event)
else:
print('File ',filepath,' does not have type keyword, assuming MATCH output')
event = Job.getEvent(job,'new_match_catalog',options={'dp_id':dpid,'to_run':total,'name':comp_name, 'config_id':confid})
fire(event)
return
def parse_all():
parser = argparse.ArgumentParser()
parser.add_argument('--R','-R', dest='REG', action='store_true',
help='Specify to Register')
parser.add_argument('--N','-n',type=str, dest='task_name',
help='Name of Task to be Registered')
parser.add_argument('--P','-p',type=int, dest='PID',
help='Pipeline ID')
parser.add_argument('--C','-c',type=str, dest='config_file',
help='Configuration File Path')
parser.add_argument('--T','-t',type=str, dest='data_dir',
help='Path to directory with input lists')
parser.add_argument('--E','-e',type=int, dest='event_id',
help='Event ID')
parser.add_argument('--J','-j',type=int, dest='job_id',
help='Job ID')
return parser.parse_args()
if __name__ == '__main__':
args = parse_all()
if args.REG:
_t = register(int(args.PID),str(args.task_name))
else:
if args.PID is None:
exit("Need to define a pipeline ID")
if args.config_file is None:
exit("Need to define a configuration file")
if args.data_dir is None:
exit("Need to define a directory with input star lists")
myPipe = Pipeline.get(args.PID)
discover_targets(myPipe,args.config_file,args.data_dir)
# placeholder for additional steps
print('done')