From 4e6faeffae152baa3c0ad969b3820135316110a7 Mon Sep 17 00:00:00 2001 From: matsvandecavey Date: Tue, 7 Oct 2014 13:27:37 +0200 Subject: [PATCH] Update pymosim.py Set start_ and stop_time for dsin.txt initialization of dymosim change parameters in dsin.txt, read file one line at a time for memory reasons (big files) allow dsu.txt in simulation call --- awesim/pymosim.py | 162 ++++++++++++++++++++++++++++++++++------------ 1 file changed, 119 insertions(+), 43 deletions(-) diff --git a/awesim/pymosim.py b/awesim/pymosim.py index af557af..84c8d9f 100644 --- a/awesim/pymosim.py +++ b/awesim/pymosim.py @@ -54,12 +54,50 @@ def set_solver(solver, dsin = '', copy_to = None): # only if original dsin had to be replaced if copy_to != None: shutil.copyfile('dsin_temp.txt', copy_to) - -def set_ststst(start = 0, stop = 86400, step = 60, dsin = '', copy_to = None): - """ - better name to be found. set_times? + + +def set_init_from_file(source_path, destination_path, startTime=None, stopTime=None): """ - pass + replace the 'destination' file with a 'source 'file. + Function to replace a Dymola simulation file (dsin.txt, with initial values for all variables) by + a Dymola simulation file (dsfinal.txt, with end values for every variable). + - startTime: reset the txtline indicating the start of the simulation with startTime (s) + - stopTime: reset the txtline indicating the end of the simulation with stopTime (s) + """ + + if startTime==None and stopTime==None: + shutil.copyfile(source_path,destination_path) + else: + with open(source_path,'r') as input_file, \ + open(destination_path, 'w') as output_file: + + if startTime==None: # startTime is not None + for line in input_file: + if '# StopTime' in line: + output_file.write( str(stopTime) +\ + ' # StopTime Time at which integration stops\n') + else: + output_file.write(line) + + if stopTime==None: # stopTime is not None + for line in input_file: + if'# StartTime' in line: + output_file.write( str(startTime) +\ + ' # StartTime Time at which integration starts\n') + else: + output_file.write(line) + + else: # both are not None + for line in input_file: + if '# StopTime' in line: + output_file.write( str(stopTime) +\ + ' # StopTime Time at which integration stops\n') + elif'# StartTime' in line: + output_file.write( str(startTime) +\ + ' # StartTime Time at which integration starts\n') + else: + output_file.write(line) + def set_par(parameter, value, dsin='dsin.txt', copy_to=None): """ @@ -284,7 +322,7 @@ def cleanup_parrun(workdir, targetdir=None, subdir=None, remove=False): -def set_simulation(path, parameters, values, copy_to = None, dsin = '', dymosim = ''): +def set_simulation(path, parameters, values, copy_to = None, dsin_old = '', dsin_new = '', dymosim = ''): """ This function sets everything ready for starting a new simulation based on the given parameters. @@ -295,39 +333,71 @@ def set_simulation(path, parameters, values, copy_to = None, dsin = '', dymosim values = the values the depicted parameters need to get copy_to = a follow number for creating subfiles """ - - os.chdir(path) - - if dsin == '': + my_wor_dir = os.getcwd() + os.chdir(path) + if dsin_old == '': dsin = 'dsin.txt' - + else: + dsin = dsin_old + + if dsin_new == '': + dsin_new = 'dsin.txt' + + replace_original = False + if dsin==dsin_new: + replace_original=True + dsin_new = dsin_new.strip('.txt')+'temp.txt' + if dymosim == '': dymosim = 'dymosim.exe' - - dsin_file = open(dsin, 'r') - file_data = dsin_file.readlines() - dsin_file.close() - - for i in range(len(file_data)): - for j in range(len(parameters)): - if file_data[i].find(parameters[j]) > -1: - # check structure of file: all on single line or on 2 lines - if file_data[i-1].find(u'#') > -1: - line = i - else: - line = i-1 - splitted = file_data[line].split() - splitted[1] = str(values[j]) - splitted.append('\n') - file_data[line] = ' '.join(splitted) - print 'The parameter %s is found in %s and is replaced by %s' \ - %(parameters[j], dsin, values[j]) - - dsin_temp = open('dsin_temp.txt', 'w') - dsin_temp.writelines(file_data) - dsin_temp.close() + + my_pars = list(parameters) + my_vals = list(values) + # Get parameters from sim in order of appearance + sorted_pars = [] + sorted_vals = [] + with open(dsin,'r') as old_file: + for f in old_file: + #pdb.set_trace() + if '# ' in f: + if any(x in f.split() for x in my_pars): + for i, par in enumerate(my_pars): + if par in f.split(): + sorted_pars.append(par) + sorted_vals.append(my_vals[i]) + my_index = i + my_pars.pop(my_index) + my_vals.pop(my_index) + if len(sorted_pars)