Commit 2d3e92d7 authored by Bognár, Á.'s avatar Bognár, Á.
Browse files

Small bug fixes

Removing unnecessary print() from grid_2d func.
parent 3f97e6be
......@@ -59,7 +59,7 @@ def grid_2d(bbox_2d, d):
x2 = y2* a/b
y = max(y1, y2)
x = y * a/b
print('a={}; b={}; x={}; y={}; n={}'.format(a,b,x,y,n))
#print('a={}; b={}; x={}; y={}; n={}'.format(a,b,x,y,n))
xs = (bbox_2d.vertices_list[0][0], bbox_2d.vertices_list[2][0])
ys = (bbox_2d.vertices_list[0][1], bbox_2d.vertices_list[2][1])
xv = np.linspace(xs[0], xs[1], round(x+1, 0))
......
%% Cell type:markdown id: tags:
## Before we start
Make sure that DASIM, Radiance, EnergyPlus and the following Python dependencies are installed:
* pandas
* numpy
* matplotlib
* geomeppy
* eppy
* plotly
%% Cell type:markdown id: tags:
## Importing necessary modules
Check if bin_dir is actually your DAYSIM bin folder and change it if necessary.
Also copy the "obj2rad.exe" from your "...\Radiance\bin" directory to your "...\DAYSIM\bin" directory.
%% Cell type:code id: tags:
``` python
import pandas as pd
from matplotlib import pyplot as plt
from geomeppy import IDF
from geomeppy import view_geometry
import os
import sys
sys.path.append(os.path.dirname(os.getcwd()) + r'\\daypym')
from daypym import *
from geomeppy.geom.polygons import (break_polygons, Polygon2D, Polygon3D, Vector2D, Vector3D)
from geomeppy.geom.transformations import align_face, invert_align_face
## DAYSIM bin folder path:
bin_dir=r'c:\DAYSIM\bin\\'
## Managing folder structure
cwd = os.getcwd()
for f in os.listdir():
if f.endswith('.idf'):
project_name = f[:-4]
# create folders if they don't exist yet
for folder in ['res', 'tmp', 'wea', 'geo', 'pts', 'res\\vis']: # res: final results from Daysim with .ill and .dc files, tmp: Daysim poops temp files here, wea: converted wea file, geo: obj rad and pts files. Inputs, such as the idf and sketchup files are in the working directory
pathlib.Path(folder).mkdir(exist_ok=True)
```
%% Cell type:markdown id: tags:
## Reading IDF geometry with Geomeppy
**Set the correct path for the EnergyPlus .idd**
For making this example easier to work, I uploaded an EnergyPlus.idd file to the repository, but under normal use the iddfile path should point to your EnergyPlus installation's .idd
%% Cell type:code id: tags:
``` python
source_idf_name = r'{}.idf'.format(project_name)
iddfile = r'Energy+.idd'
IDF.setiddname(iddfile)
source_idf = IDF(source_idf_name)
source_idf.to_obj(fname=cwd + r'\geo\\'+ project_name +'.obj', mtllib=None)
```
%% Cell type:markdown id: tags:
## Finding PV surfaces in the IDF and putting them in a list
When we made the IDF, we made sure that all the surfaces that represent PV modules in the IDF file have the construction: 'PV_Construction'.
We use Geomeppy to filter for the surfaces with this construction name, because we only want to generate sensorpoints over surfaces that are representing PV modules.
%% Cell type:code id: tags:
``` python
surfaces = surface=source_idf.idfobjects['BUILDINGSURFACE:DETAILED']
act_surf_id = 'PV_Construction' # 'BIPV_Construction' this is the active (PV) surface identifier. Surfaces with construction names like this will get a sensor point mesh over them
act_surfs = [surface for surface in surfaces if surface.Construction_Name == act_surf_id]
```
%% Cell type:markdown id: tags:
## Creating DAYSIM sensorpoints
Now we loop through the active surfaces and create sensorpoints over each cell of the modules.
We have to provide the number of cell rows and columns in the module. Interpret rows and columns as n_row > n_col!
Currently this implementation only works with rectangular modules that have a horizontal edge-pair. That is, it can have any tilt or orientation, but its "top" and "bottom" edges shoud be horizontal.
%% Cell type:code id: tags:
``` python
n_row = 10
n_col = 6
sps = []
for surface in act_surfs:
poly = IDFsurf_to_poly(surface=surface) # make poly from idf (daypym)
poly_trans = align_face(poly).order_points('upperleftcorner') # translate poly to the x-y plane (geomeppy)
poly_trans_2d = poly_trans.project_to_2D() # make the poly 2D (geomeppy)
poly_trans_bbox_2d = poly_trans.bounding_box.project_to_2D() # make a 2d bbox of the translated surface on the xy pane (geomeppy)
test_grid = grid_2d_pvmodule(n_row=n_row, n_col=n_col, bbox_2d=poly_trans_bbox_2d) # makes an offset grid over the cells (daypym)
pip = gridpoints_in_poly_2d(grid_2d=test_grid, poly_2d=poly_trans_2d) # makes a list of points, that are inside the 2D poly (daypym)
ri, ci = pos_in_module(n_row=n_row, n_col=n_col, test_grid_transp=test_grid) # this is for keeping track of in which row and column of the module the sensorpoint is. This will be useful later when we want to use these results for cell-level PV system simulations (daypym)
sp = create_sensor_points(surf_name=surface['Name'], points_in_poly_2d=pip, row_index=ri, col_index=ci, original_poly=poly, sp_offset=0.01, sp_pos_round=3) # sensor point data dict (daypym)
sps.append(sp)
translate_to_ds_pts(surf_sensor_points=sps, p_name=project_name) # use the sensor-point data dicts to make .pts file (That DAYSIM needs) and and a csv, which as additional info about the sensorpoints for postprocessing
```
%% Cell type:markdown id: tags:
Each sensorpoint here is now saved by the "translate_to_ds_pts" function to a .pts file (that DAYSIM will use) and also a .csv is saved that contains supplementary information about the sensorpoints (e.g. in which row and column of the corresponding PV module they are) which can be useful if we later want to use the simulated irradiance for cell-level PV system simulations.
%% Cell type:markdown id: tags:
## Visualizing the sensorpoints
This will plot the IDF geometry (with Geomeppy) and add the sensorpoints to the plot
%% Cell type:code id: tags:
``` python
view_idf_and_sps(p_name=project_name, idf_name=source_idf_name, sps=sps) # plot the sensorpoints and the idf together (daypym-geomeppy)
```
%%%% Output: display_data
![]()
%% Cell type:markdown id: tags:
Here is a larger image where the individual sensorpoints are visible:
![alt text](sensor_points.PNG)
%% Cell type:markdown id: tags:
## Making the .wea file and writing the .hea file that DAYSIM uses as input for the simulations
%% Cell type:code id: tags:
``` python
# make wea file from epw
wea_data = ds_epw2wea('NLD_Amsterdam.062400_IWEC.epw', project_name) # maybe check for negative altitude!
# make a rad file form obj (this is a Radiance program. Put this one to the Daysim bin folder)
rad_obj2rad(input_obj=project_name + r'.obj', output_rad=project_name)
# we make the site info dict. This is all the input we set here, the rest are default values
site_info = {
'ground_eflectance':0,
'first_weekday':1,
'time_step':5, # if this is not 60, we need to run the ds_ds_shortterm
'wea_data_file':cwd + '/wea//' + project_name + '.wea', # this needs full abs path
'weather_data_file_units':1,
'wea_data_short_file':'/wea//' + project_name + '_short.wea', # this is an output and an input in this case
'wea_data_short_file_units':1,
'lower_direct_threshold':2,
'lower_diffuse_threshold':2
}
# add wea file data to the site info
site_info.update(wea_data)
# write hea
write_ds_hea(p_name=project_name, p_dir=cwd, bin_dir=bin_dir, uni_mat_file=r'daysim_all_mat.rad', site_info=site_info, model_info=None, radiance_params=None)
```
%% Cell type:markdown id: tags:
## Running conversion, ds_shortterm, gen_dc and ds_illum
There are quite a lot of sensorpoints in the model, so ds_gen_dc might run for several minutes.
Check the terminal window where you started this notebook from. DAYSIM is probably printing messages there. You can check there when it finishes.
%% Cell type:code id: tags:
``` python
#run conversion, dc and ill
ds_radfiles2daysim(p_name=project_name, hea_file_name=None)
ds_ds_shortterm(project_name, hea_file_name=None)
ds_gen_dc(p_name=project_name, hea_file_name=None)
ds_ds_illum(p_name=project_name, hea_file_name=None)
```
%% Cell type:markdown id: tags:
## Checking results
After the simulation finished, the .ill results (in W/m2) are in the .../res folder.
......@@ -30,24 +30,25 @@
from geomeppy.geom.transformations import align_face, invert_align_face
## DAYSIM bin folder path:
bin_dir=r'c:\DAYSIM\bin\\'
## navigate to the working folder and run
## Managing folder structure
cwd = os.getcwd()
for f in os.listdir():
if f.endswith('.idf'):
project_name = f[:-4]
## create folders if they don't exist yet
# create folders if they don't exist yet
for folder in ['res', 'tmp', 'wea', 'geo', 'pts', 'res\\vis']: # res: final results from Daysim with .ill and .dc files, tmp: Daysim poops temp files here, wea: converted wea file, geo: obj rad and pts files. Inputs, such as the idf and sketchup files are in the working directory
pathlib.Path(folder).mkdir(exist_ok=True)
```
%% Cell type:markdown id: tags:
## Reading IDF geometry with Geomeppy
**Set the correct path for the EnergyPlus .idd**For making this example easier to work, I uploaded an EnergyPlus.idd file to the repository, but under normal use the iddfile path should point to your EnergyPlus installation's .idd
**Set the correct path for the EnergyPlus .idd**
For making this example easier to work, I uploaded an EnergyPlus.idd file to the repository, but under normal use the iddfile path should point to your EnergyPlus installation's .idd
%% Cell type:code id: tags:
``` python
source_idf_name = r'{}.idf'.format(project_name)
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment