A simple experimental utility to estimate the solar potential of building roof surface(s) from a 3D city model stored in CityGML.
The scripts compute the solar irradiation data thanks to the solpy library.
The estimation of the solar irradiation of roof surfaces is one of the prominent use-cases of 3D city models. This use-case is important for estimating the feasibility of installing a photovoltaic panel on a roof. Such estimations are usually done on a large-scale, e.g. on the area of a municipality. For instance, see an example in Germany. Further, there are many academic articles that explore this topic.
Despite the popularity of this 3D use-case, there are two drawbacks:
- the software packages are not available for free, and
- utilities that support data stored in CityGML are seldom.
I have created this utility to fill this gap. This experimental software prototype was developed as a part of my PhD research.
This software is free to use. You are kindly asked to acknowledge its use by citing it in a research paper you are writing, reports, and/or other applicable materials; and mentioning the 3D Geoinformation group at the Delft University of Technology. If you used it for making a nice publication, please cite this paper:
Biljecki, F., Heuvelink, G. B. M., Ledoux, H., & Stoter, J. (2015). Propagation of positional error in 3D GIS: estimation of the solar irradiation of building roofs. International Journal of Geographical Information Science, 29(12):2269-2294. DOI: http://doi.org/10.1080/13658816.2015.1073292
@article{Biljecki:2015iw,
author = {Biljecki, Filip and Heuvelink, Gerard B M and Ledoux, Hugo and Stoter, Jantien},
title = {{Propagation of positional error in 3D GIS: estimation of the solar irradiation of building roofs}},
journal = {International Journal of Geographical Information Science},
year = {2015},
volume = {29},
number = {12},
pages = {2269--2294},
month = dec,
doi = {10.1080/13658816.2015.1073292}
}
I would be very happy to hear if you find this tool useful in your workflow. If you find it useful and/or have suggestions for its improvement, please let me know. Furthermore, I am maintaining a list of users that I notify of corrections and updates.
This short section gives an overview of the estimation of the solar irradiation, for understanding how the utility works.
The solar irradiation is the amount of solar energy received over a given time (e.g. one year) on an area (e.g. one metre squared). Contemporary solar panels are able to utilise 10-15% of this energy and convert it to electric energy.
The solar radiation is composed of three components:
- Direct radiation--the unobstructed radiation that reaches the surface directly.
- Diffuse radiation--the solar radiation scattered in the atmosphere (e.g. clouds). There are many empirical models to estimate the diffuse radiation.
- Reflected radiation--the fraction of the solar radiation that is reflected, e.g. from the ground.
The global solar radiation is the sum of these three components.
Clouds have a significant influence on the radiation. Therefore it is important to know the weather conditions on a location in order to account the estimation. For this, historic data is usually used.
The magnitude of the three radiation components is different depending on the day and time (i.e. position of the sun). Hence, the yearly irradiation is computed by integrating the magnitudes over the year, i.e. estimating the irradiation for many epochs during the year and summing them up (e.g. every 1 hour for every day).
The solar radiation differs depending on the tilt and orientation of a surface. The plot below show that TOF (tilt-orientation-factors) for Delft in the Netherlands. It is visible that the difference between the irradiation on differently tilted and oriented surfaces is significant.
You can use Solar3Dcity to compute the optimal tilt for almost every location on Earth:
The global solar irradiation on a tilted and oriented surface at location can be estimated from the following components of the surface:
- location
- tilt (of the normal)
- orientation (azimuth)
- historical weather (cloud) data
The annual irradiation is expressed in kWh/m^2. If the area of the surface is available, the normalised irradiation is multiplied with the surface area in order to obtain the irradiation in kWh.
3D city models are very important for the following reasons:
- it is possible to extract the tilt and orientation of the normal of each roof surface,
- it is possible to estimate the area of each roof surface,
- the location of a building is available.
This is precisely what these scripts utilise.
Python packages:
- Numpy (likely already on your system)
- lxml
- solpy - python library to model solar system power performance similar to PVWatts or NREL's System Advisor Model(SAM)
- caelum - python library wrapper for various typical historical weather sources
- Pickle
Optional (for plotting):
- matplotlib
- seaborn
- LaTeX
The software has been developed on Mac OSX in Python 2.7, and has not been tested with other configurations. Hence, it is possible that some of the functions will not work on Windows and on Python 3.
- All your polygons and buildings must have gml:ids, e.g.:
<bldg:Building gml:id="080a3632-c2b3-4488-945e-09701513f98d">
<gml:Polygon gml:id="6a37401c-d150-4c7c-a895-f02a72cf313d">
The utility does the following:
- reads the CityGML file and extracts the roof surfaces for each building
- computes the tilt, area, and orientation for each roof surface
- estimates the yearly solar irradiation thanks to the solpy library and EPW weather data (thanks to the caelum library)
- writes the data back in the CityGML file
It is important to note the following:
- The utility supports LOD3 models, for accounting the holes in the roof surfaces.
- The weather and other data is loaded in the EnergyPlus weather file format (EPW), which is downloaded automatically.
- Unfortunately the code does not take shadows into account. This is a notable shortcoming, which has not be implemented because of computational reasons.
The code is composed of multiple Python files. Please follow these steps.
There are some parametres that need to be modified prior to running the code.
- Open the
irr.py
, scroll to the end, and for the variableSTATION_CODE
put the code of the nearest weather station to your location. This can be found here. - In
Solar3Dcity.py
go to line 196 and manually change the latitude and longitude of the area.
Without these changes, the code will give wrong estimates. I plan to automate this in future work.
In case you have a large dataset (>1000 buildings), it is advised that first you compute the tilt-orientation factors. Then the software samples and interpolates the value of the yearly irradiation directly from this precomputed dataset. This is done with the TOF.py
script.
python TOF.py -lat 52.01 -lon 4.36 -s 5
where -lat and -long are the latitude and the longitude of the location of your models (it is not extracted from them), and -s the resolution of the computations in degrees. The smaller the value, the better the estimation. If you have time put this to 1, if not put to 10 or 15.
Here are some examples of how much time it takes my computer to precompute the TOFs depending on the resolution:
Resolution [degree] | Time |
---|---|
15 | 3 min |
10 | 7 min |
5 | 28 min |
2 | 2 h 41 min |
1 | 11 h |
The TOF will be saved as a file TOF.dict
in the same directory. The code will then sample the irradiation directly from the precomputed values, saving you a lot of time.
If you toggle the -p
option at the end you will get the plot as the one above. (Please note that the plot above has been computed with the option of -s 1, i.e. a very high resolution, so if you use a coarser resolution you will not get a very nice plot.)
python TOF.py -lat 52.01 -lon 4.36 -s 15 -p True
If you have precomputed the factors, and you just want to plot them run the following:
python TOF.py -lat 52.01 -lon 4.36 -s 15 -p True -f TOF.dict
The Perez et al. (1990) empirical model is used for the estimations.
Put your CityGML file(s) in a separate directory. If you have precomputed the TOFs, run this:
python Solar3Dcity.py -i /path/to/CityGML/files/ -o /path/to/new/CityGML/files/ -f /path/to/the/TOF.dict
The tool will run the analysis on all *.gml
it finds in that folder. The new files with the information on the solar irradiation of the building and its roof surface(s) will have the extension -solar.gml
. That's it.
If you have not precomputed the TOFs, run this instead:
python Solar3Dcity.py -i /path/to/CityGML/files/ -o /path/to/new/CityGML/files/
to obtain the same result.
Please note that this will increase the computational time, as shown in the following table.
Level of detail | Without precomputed TOF [sec] | With loaded TOF [sec] | Faster by |
---|---|---|---|
LOD2 | 3.20 | 0.02 | 160x |
LOD3 | 5.95 | 0.06 | 100x |
Hence, if you have a large dataset, you might want to precompute the tilt-orientation factors.
This is not really a part of the utility, but might be helpful to understand how the estimation of the solar irradiation works. The script dailyplot.py
plots the global solar irradiance on a tilted and oriented surface at a location on a specific date. Multiple locations, multiple surfaces, and multiple dates are possible in order to compare the settings.
Go through the code to adjust the settings and then simply run:
python dailyplot.py
You will get something like this:
This is the magnitude of the irradiation during the day. Solar3Dcity integrates these values over the year in order to estimate the yearly irradiation.
It is important to note that this is an experimental research software. This means that it is not user-friendly, it has some limitations, and I cannot provide extensive support.
Solar3Dcity does not estimate the shadowing from other objects (e.g. other buildings, chimneys, dormers, ...), which might be severe. This was out of scope of this work. If you have a suggestion how to efficiently implement this feature without sleepless weekends, please let me know.
The input/output files are read/stored in CityGML 2.0. Support for legacy versions 0.4 and 1.0 is not available.
This software has been programmed with Python 2.7. Version 3 is not supported.
- The program is known to crash in peculiar situations, e.g. when the geometry is invalid. For instance, a polygon is not planar. Please check your data.
- The utility supports only local coordinate systems.
- The utility is not extracting the latitude and longitude of a building, they have to be input manually.
Please do not use CityGML files with more than one LOD because the utility does not split between representations. However, multi-LOD files are seldom, so this should not be a problem.
The results of the computations are added directly to the <gml:Polygon>
and <bldg:Building>
level. I am aware that this does not conform to CityGML. I did not have time yet to make an ADE or to store the data as generic attributes.
This utility just stores the data of the solar estimations directly in the CityGML file. It does not have any GUI. However, data can be visualised by converting this to an enhanced OBJ with my utility CityGML2OBJs. An example is shown in the beginning of this file and here below.
Check also the animation.
Filip Biljecki
3D Geoinformation Research Group
Delft University of Technology
email: fbiljecki at gmail dot com
-
This research is supported by the Dutch Technology Foundation STW, which is part of the Netherlands Organisation for Scientific Research (NWO), and which is partly funded by the Ministry of Economic Affairs (project code: 11300).
-
Nathan Charles, the author of the Solpy and Caelum Python libraries, on which this package relies. Nathan promptly answered my questions and gave suggestions. Thank you.
-
People who gave suggestions and reported errors.
- Biljecki, F., Heuvelink, G. B. M., Ledoux, H., & Stoter, J. (2015). Propagation of positional error in 3D GIS: estimation of the solar irradiation of building roofs. International Journal of Geographical Information Science, 29(12):2269-2294. doi:10.1080/13658816.2015.1073292
- Perez, R. et al., 1990. Modeling daylight availability and irradiance components from direct and global irradiance. Solar Energy, 44(5), pp. 271–289.
- Hofierka, J. & Zlocha, M., 2012. A New 3-D Solar Radiation Model for 3-D City Models. Transactions in GIS, 16(5), pp. 681–690.
- Šúri, M. et al., 2007. Potential of solar electricity generation in the European Union member states and candidate countries. Solar Energy, 81(10), pp. 1295–1305.
- Freitas, S. et al., 2015. Modelling solar potential in the urban environment: State-of-the-art review. Renewable and Sustainable Energy Reviews, 41, pp. 915–931.