Sep-19-2020, 01:23 PM
HI,
I am using subprocess to automate my Trnsys simulation for multiple inputs.
The problem I am having is each run should produce multiple results which its not producing? it moves to next run after giving me the first output for one objective (leaves others without showing any error and moves on).
Another issue: I have is that I want to store the results in folders(being created by python)for each and numbered for that run. So that I can avoid sorting them at the end of the process (having to avoid doing it manually).
my code is like this:
I am using subprocess to automate my Trnsys simulation for multiple inputs.
The problem I am having is each run should produce multiple results which its not producing? it moves to next run after giving me the first output for one objective (leaves others without showing any error and moves on).
Another issue: I have is that I want to store the results in folders(being created by python)for each and numbered for that run. So that I can avoid sorting them at the end of the process (having to avoid doing it manually).
my code is like this:
# -*- coding: utf-8 -*- """ Created on Fri Sep 18 21:49:09 2020 @author: """ ## This Python script runs automated TRNSYS simulation # prepared by Sachin Gangwar (PhD student, URV) from the references of Hakan İbrahim Tol and Len Rijvers # Libraries Imported import subprocess # to run the TRNSYS simulation import shutil # to duplicate the output txt file import time # to measure the computation time import numpy as np # to measure the computation time import os # to create directories for storing results import sys # List of Parameters to be Evaluated list_VolumeISS =[1] # Volume of seasonal storage tank list_HeightISS =[1] # Height of seasonal storage tank list_VolumeDHW =[0.5] # Volume of DH tank list_HeightDHW =[1] # Height of DH tank list_AreaSC =[1] # Area of flat plate solar collector label_no=0 # Looping through Each of Combinations (List of Parameters) for VolumeISS in list_VolumeISS: for HeightISS in list_HeightISS: for VolumeDHW in list_VolumeDHW: for HeightDHW in list_HeightDHW: for AreaSC in list_AreaSC: # 1) Assigning parameter values as input in the TRNSYS (.dck) file with open(r'C:\Users\Desktop\v0.0\z_PH_TEMPLATE.dck', 'r') as file_in: filedata = file_in.read() # - changing/replacing the py tags to parameter values in the .dck text filedata = filedata.replace('PH_VolumeISS', str(VolumeISS)) filedata = filedata.replace('PH_HeightISS', str(HeightISS)) filedata = filedata.replace('PH_VolumeDHW', str(VolumeDHW)) filedata = filedata.replace('PH_HeightDHW', str(HeightDHW)) filedata = filedata.replace('PH_AreaSC', str(AreaSC)) # - (over)writing the modified template .dck file to the original .dck file (to be run by TRNSYS) with open(r'C:\Users\Desktop\v0.0\IRLPHv00.dck', 'w') as dckfile_out: dckfile_out.write(filedata) # 2) Running TRNSYS simulation start_time=time.time() # Measuring time (start point) subprocess.run([r"C:/TRNSYS18/Exe\TrnEXE64.exe",r"C:\Users\Desktop\v0.0\IRLPHv00.dck","/h"]) elapsed_time = time.time() - start_time # Measuring time (end point) print(elapsed_time) # 3) Generating the output .out file name for each of the simulation results (i.e. first one as 001.out) # creating the path where the folder needs to be created and result to be stored label_no+=1 t=str(label_no) os.chdir(r'C:\Users\Downloads') os.makedirs(results,float,1) Newfolder = t filename_out=t.rjust(4,'0')+'.out' # if .out doesnt work change to .txt shutil.copy('1economic.out', filename_out) shutil.copy(r'2environmental.out', filename_out) shutil.copy(r'3Wsum.out', filename_out) shutil.copy(r'4energyoutput.out', filename_out) shutil.copy(r'5economcheck.out', filename_out) shutil.copy(r'6environcheck.out', filename_out) shutil.copy(r'7tempcheck.out', filename_out)