#!/bin/env python # update the version when significant changes are made program = 'goUSNO' version = '0.20' from sys import exit, argv, stdin from time import gmtime, strftime from string import strip, split, lower, upper, find from os import system, chdir, environ, popen from os.path import isfile from datetime import datetime # some tunable parameters email = 'ut1@nrao.edu' baseDir = '/home/vlbiobs/astronomy' templateFile = '/users/vlbaops/STDFILES/usno_template.key' sched_base = '/usr/local/sched' sched = '/usr/local/sched/bin/sched' # temporary hack to get around bug in released sched version # sched_base = '/users/cwalker/files/sched_beta' # sched = '/users/cwalker/files/sched_beta/bin/LINUX64SPICE/sched' queueVex = 'queueVex' # add to environment environ['PYTHONPATH'] = '/home/swc/difx/x86_64/lib/python2.4/site-packages' environ['LD_LIBRARY_PATH'] = '%s:%s' % (environ['LD_LIBRARY_PATH'], '/home/swc/DiFX-trunk/lib') environ['LD_LIBRARY_PATH'] = '%s:%s' % (environ['LD_LIBRARY_PATH'], '/home/oracle/LinuxClient_x86_64/product/10.2.0.1/lib') environ['PATH'] = '%s:%s' % (environ['PATH'], '/home/swc/DiFX-trunk/bin') environ['ORACLE_BASE'] = '/home/oracle' environ['ORACLE_VERSION'] = '10.2.0.1' environ['ORACLE_HOME'] = '/home/oracle/LinuxClient_x86_64/product/10.2.0.1' environ['VLBA_DB'] = 'vlba/chandra1999@vlba10' environ['SCHED'] = sched_base # NOTHING SHOULD NEED CHANGING BY OPERATIONS BELOW HERE dateFormat = '%Y %b %d [doy %j] %H:%M:%S' verbose = 1 def genDir(start, projectCode): monthnames = ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec'] return '%s/%s%02d/%s/MARK5C' % (baseDir, monthnames[start[1]-1], start[0]%100, projectCode) def doy(year, mo, day): return datetime(year, mo, day, 0, 0).timetuple().tm_yday def args2time(args, now): mon = int(args[0]) day = int(args[1]) yr = now[0] if mon < now[1]: yr += 1 t = split(args[2]+':0:0', ':') h = int(t[0]) m = int(t[1]) s = int(t[2]) return (yr, mon, day, h, m, s, -1, doy(yr, mon, day), -1) def execute(cmd): if verbose > 1: print 'Executing: %s' % cmd system(cmd) def genStationList(argList): ants = [] legalAnts = ['BR', 'FD', 'HN', 'KP', 'LA', 'MK', 'NL', 'OV', 'PT', 'SC', 'VLBA'] for a in argList: if upper(a) not in legalAnts: print 'Error: %s is not a legal antenna name.' % upper(a) exit(0) ants.append(a) if len(ants) > 1 and 'VLBA' in ants: print 'Error: cannot include VLBA and other antennas in list' exit(0) if len(ants) == 0: return 'VLBA_MK, VLBA_PT' if len(ants) == 1: if upper(argList[0] != 'VLBA'): print 'Error: only one antenna listed. Stopping.' exit(0) else: return 'VLBA_BR, VLBA_FD, VLBA_HN, VLBA_KP, VLBA_LA, VLBA_MK, VLBA_NL, VLBA_OV, VLBA_PT, VLBA_SC' response = 'VLBA_%s' % ants[0] for a in ants[1:]: response += ', VLBA_%s' % a return response # FIXME: clean up by using datetime now = gmtime() # format: (2011, 9, 12, 15, 47, 47, 0, 255, 0) force = False testmode = False edit = False nrao = False noSend = False band = 'S/X' mode = 'sx' if strip(popen('uname -s').readline()) != 'Linux': print 'Must be run on a Linux machine' exit(0) args = [] for a in argv[1:]: if a in ['-f', '--force']: force = True elif a in ['-v', '--verbose']: verbose += 1 elif a in ['-q', '--quiet']: verbose -= 1 elif a in ['-t', '--test']: testmode = True elif a in ['-e', '--edit']: edit = True elif a in ['--nrao']: nrao = True elif a in ['-n', '--nosend']: noSend = True elif a in ['-c', '--cband']: band = 'C' mode = 'cc' else: args.append(a) if len(args) < 4: print '\n%s version %s\n' % (program, version) print 'Usage: %s [options] []\n' % argv[0] print 'options can include:' print ' -f or --force : proceed even if this project has already been queued' print ' -v or --verbose : print more output' print ' -q or --quiet : print less output' print ' -t or --test : schedule project as test' print ' -e or --edit : allow .py files to be edited' print ' -n or --nosend : generate files but don\'t run queueVex\n' print ' --nrao : use NRAO Mark5C/DBE, not USNO\n' print ' is the project code to be used (e.g., N2059)\n' print ' is the numeric month of year to run the project (e.g., 2)\n' print ' is the numeric day of the month (e.g., 29)\n' print ' is the UTC time to start obsserving (HH or HH:MM or HH:MM:SS)' print ' (e.g., 18 or 18:30 or 18:30:00)\n' print ' is an optional list of stations to run on. If provided' print ' then it is assumed that the NRAO Mark5C units will be used. Stations' print ' can be listed separately by name (e.g., BR HN), or be VLBA for the' print ' whole array.\n\n' exit(0) stations = genStationList(args[4:]) if len(args) > 4: nrao = True print 'Station list: %s' % stations start = args2time(args[1:], now) defaultProjectCode = 'n%d%03d' % (start[0]%10, start[7]) projectCode = lower(args[0]) if projectCode == 'auto': projectCode = defaultProjectCode outDir = genDir(start, projectCode) if verbose > 0: print '' print 'Now it is: %s UTC' % strftime(dateFormat, now) print 'Start time scheduled for: %s UTC' % strftime(dateFormat, start) print 'Output directory is: %s' % outDir print 'Project code is: %s' % projectCode print '\nThis program will:' print '1. generate a schedule (.key) file' print '2. run sched to generate .vex and crd files' print '3. run db2vex to add predicted EOPs and clocks to a .vex.preobs file' if not noSend: print '4. run vex2script to generate executor control files' print '5. copy executor Mark5C control files to VLBA stations' print '6. update the Mark5C observ.tx file on the new systems at VLBA stations' print '7. email %s with a confirmation' % email if find(projectCode, defaultProjectCode) < 0: print '\nWARNING: project expected to contain %s but does not!' % defaultProjectCode # Verify the user wants to go ahead # FIXME: should --force skip this? while 1: print '\nDo you wish to continue? [y/n]' a = stdin.readline() if a[0] in ['n', 'N']: print 'Operation cancelled' exit(0) elif a[0] in ['y', 'Y']: break; newFile = '%s.key' % projectCode execute('mkdir -p %s' % outDir) chdir(outDir) execute('mkdir -p %s/sniffer' % outDir) execute('chmod a+w %s/sniffer' % outDir) execute("sed -e 's/%%year%%/%d/' -e 's/%%month%%/%d/' -e 's/%%day%%/%d/' -e 's/%%utc%%/%d:%02d:%02d/' -e 's/%%expcode%%/%s/' -e 's/%%stations%%/%s/' -e 's/%%mode%%/%s/' <%s >%s" % (start[0], start[1], start[2], start[3], start[4], start[5], projectCode, stations, mode, templateFile, newFile) ) execute("%s < %s" % (sched, newFile) ) execute('db2vex --preobs --force %s.vex' % projectCode) if nrao: options = "" else: options = "--usno" if edit: options += " --edit" if noSend: print 'NOT running %s %s %s.vex' % (queueVex, options, projectCode) else: execute("%s %s %s.vex" % (queueVex, options, projectCode) ) if email != None: cmd = "mail -s '%s scheduled' %s" % (projectCode, email) out = popen(cmd, "w") out.write('Start time = %s UTC\n' % strftime(dateFormat, start)) out.write('Project directory = %s\n' % outDir) out.write('Antenna list = %s\n' % stations) if nrao: out.write('\nThis data will be recorded on NRAO Mark5 units and correlated in Socorro\n') out.write('\nThis observation will be done at %s-band.\n\n' % band) if testmode: out.write('\n*** This is a test observation and may not provide real data ***\n\n') out.write('\nemail sent by %s version %s\n' % (program, version)) out.close() print '\nFinished.\n' print "*** Don't forget to: ***" print "1. copy crd files to legacy systems" print "2. update observ.tx on legacy systems" print "3. update OMS as necessary" print "************************" print '\nArchive files are in: %s\n' % outDir preobsFile = '%s.vex.preobs' % projectCode if not isfile(preobsFile): print 'WARNING ... File %s was not made. Contact Walter immediately.\n' % preobsFile