For this module, the objective is to provide guidance to developers of a new high-rise building. Since my new building will be a commercial property, the analysis has centered around two key metrics:
- Building’s potential annual rental net income
- Potential electricity cost savings by implementing solar isolation measures
These two key evaluation metrics were used to optimize the original building from Module 5, resulting in the optimized solution presented below.
Original building form:
Recommended building form based on evaluation and analysis:
Dynamo Script Overview:
The script starts in the blue section where input values are gathered for the parametric study covered in Module 5 Part 2. In addition to these inputs, new parameters for evaluating the annual rental net income and cost savings from solar insolation have been added. The green section creates a combination of parameters to be studied, while the evaluation of these values based on the evaluation parameters is performed in the orange custom node. The purple section is part of creating a single-objective optimization scheme to compare and rank the building form alternatives. Finally, the results are exported and printed into Excel in the turquoise section. The pink section provides visual feedback by adjusting the color and opening size of adaptive panels to reflect an evaluation value related to the panels.
Step 1: Create two custom nodes to measure new evaluation metrics for the building form test cases created in Module 5
To model the buildings around the project site, I used Google Earth to gain an understanding of their location, orientation, and height. The tallest building in the vicinity was approximately 450 ft tall, which means that most of the surrounding buildings were shorter than the proposed project building. These surrounding buildings were simulated as in-place masses.
- New metric 1: Annual Rental Net Income
As a developer, the primary concern is usually the building's potential annual rental net income. To illustrate this concept, I have utilized the formula:
Potential Annual Rental Net Income($) = Total Construction Cost($) - Annual Rent Profit($)
- New metric 2: Potential Electricity Cost Saving Due to Solar Energy
In addition, with the increasing focus on sustainable energy used in building design, another important evaluation metric is the average solar insolation of the building. This metric reflects the roof's potential to generate solar energy, which can help reduce the operational costs of electricity. To illustrate this concept, I have utilized the formula:
Potential Electricity Cost Saving ($) = Cumulative Solar Potential (kWh/ft^2) * Roof Area (ft^2) * Electricity Cost per kWh ($/kWh)
Same as in Module 5, I tested two parameters for my building, namely the Top Rotation and Base Radius.
- The range for Top Rotation was set between 90-130 degrees with increments of 10 degrees.
- The range for Base Radius was set between 160-170 ft with increments of 5 ft.
The building cost increases linearly from $500 per ft2 at ground level to $1000 per ft2 at 750ft above ground level.
For the annual rent, I found that commercial tenants paid, on average, about 90 U.S. dollars per square foot per month of class-A office space in San Francisco. https://www.statista.com/statistics/641394/office-space-rental-rates-san-francisco-by-submarket/
Therefore, I assumed the annual rent increases linearly from $960 per ft2 ($80 per ft2 per month) at ground level to $1200 per ft2 ($100 per ft2 per month) at 750ft above ground level.
The solar insolation input values include the weather, site location, the spring sun setting conditions chosen in Revit, critical shading surfaces from the surrounding buildings, and a selected spacing between points of solar analysis. These values will help to determine the solar insolation in Wh/m^2 for each alternative. I then converted the value to kWh/ft^2.
The custom node created takes in the inputs values described above and from Module 5 to test various building forms based on input Top Rotation and Base Radius, and evaluate them according to annual rental net income and solar potential saving.
Overview of custom node:
Inside custom node “EvaluatePairsOfInputsAndReportCombinedResults”:
In Module 5, we developed a Dynamo logic that generated an updated building form based on the parameter test case instances presented in the orange and blue sections at the top of the figure. The pink section reported the evaluation values of gross floor area, surface area, and volume. In this module, we have added two new evaluation metrics described earlier, as shown in the green section. We will discuss these additional evaluation metrics in greater detail below.
To evaluate the annual rental net income, the custom node shown below is used. This custom node calculates a multiplier that is applied to the associated mass floor area. The multiplier represents the annual rental net income for each level, which is calculated by subtracting the construction cost from the rent profit. Any null values are removed, and the remaining values are summed to determine the overall annual rental net income for each building form.
Evaluation of annual rental net income:
Inside the custom node of “EstaimteNetIncomeByFloorLevel”:
To evaluate the potential electricity savings from solar energy, I used weather and sun path data from the Revit environment to calculate the cumulative solar insolation on the building's roof surface. This roof surface would be the potential location for solar panels placement. The logic for this evaluation process is shown below. First, I selected the roof surfaces and passed them, along with the solar setting, roof area, and potential shading surface, into a custom node.
Evaluation of potential electricity savings from solar energy:
Inside the custom node of “Building Form.SelectRoofSurface”:
I select surfaces that have a normal vector with a z component larger than 0.01 as the roof surface.
Inside the custom node of “BuildingForm.SolarAnylsis”:
Details of cost potential savings for computed solar potential:
My custom node can return the amount of money that would be saved by the solar potential of the roof. The figure above shows the logic of taking the amount of cumulative potential (Wh/m^2) and multiplying that by the area of the roof (ft2) and the cost per kWh ($/kWh) to determine the amount of potential money saved. The average electric rate in San Francisco cost 32 ¢/kWh.
The roof potential was analyzed based on the shading created by the surrounding buildings as shown below:
Step 2: Integrate the custom nodes into your testing node logic and report the new evaluation values
I generated a list of values from the new custom testing node for each test case, which included the input parameter values, gross floor area, gross surface area, gross volume, and the two new evaluation metrics. Finally, the results for each parameter pairing are exported and printed in Excel.
Step 3: Design a Single-Objective Optimization Scheme for Using the Computed Evaluators to Compare and Rank the Building Form Alternatives
With these values computed, the next step was to create a weighted single-objective optimization scheme. In this module, we have the added evaluations of Annual Net Income and Potential Electricity Savings from Solar Energy. In order to properly compare these values and produce a singular best case, some manipulation of the result data is required.
Firstly, the values computed for this module were initially selected as a means to compare the building's annual rental net income and operation cost savings due to solar potential. These two values were first normalized according to the maximum value found for each case and then multiplied by an assigned multiplier.
As a designer and developer, I like to prioritize sustainability and energy efficiency over maximizing rental income. This is because the potential cost savings from utilizing solar energy may have a larger long-term impact on the project's financial performance compared to annual rental income. Therefore, in order to achieve a total score of 100, I assigned weight factors of 40 and 60 to the Annual Rental Net Income and Solar Energy Potential Cost Saving evaluation metrics, respectively. After the combined scores for all alternatives are obtained, they will be exported to Excel.
Inside the custom node of “EvaluationResults.ComputeCombinedEvaluationScore”:
I rescaled the results, so they were all between 0 and 1. Then I put weighted factors for the new two metrics to demonstrate their degrees of importance. Then, I added the weighted scores together.
Step 4: Implement Single-Objective Optimization Scheme
After applying the Single-Object Optimization scheme with node logic in Dynamo, I exported the outcomes of every building form test case, including the input parameter values and all the computed evaluation metrics, in an Excel table presented below
We have a requirement that the gross floor area must be between 1,200,000 and 1,500,000 ft2. Based on this specific requirement, we identified three alternatives with the highest combined scores highlighted in the Excel above:
Case 15: Top Rotation=130 degrees, Base Radius=170ft, Total Weight Building Score=97.83
Case 12: Top Rotation=120 degrees, Base Radius=170ft, Total Weight Building Score=96.47
Case 9: Top Rotation=110 degrees, Base Radius=170ft, Total Weight Building Score=93.71
My recommendation to the clients would be to choose CASE 15 highlighted in gold because it has the highest combined score, making it both profitable and having a high potential for cost savings from utilizing solar energy. Therefore, a building with a top rotation of 130 degrees and a base radius of 170 ft will be the best option.
Step 5: Create a Simple Revit Model Illustrating the Recommended Design
I chose to use the adaptive panel of Rect_Panel with Resizable Opening: Glazing. It can be adjusted in the frame width and height. Then, I grabbed the wall surfaces by using the custom node of “BuildingForm.SelectWallSurfaces”. Finally, I subdivided the surface into U and V panels by using the “Panels.BySurface_U_V” custom node and provided sliders to allow users easily manipulate the number of panels. I had to remove a null list as one of the wall surfaces couldn't be divided into quad panels due to its sharp triangle shape at the bottom.
Inside the custom node of “BuildingForm.SelectWallSurfaces”:
Inside the custom node of “Panels.BySurface_U_V”:
Step 6: Provide Visual Feedback By Adjusting the Appearance of the Panels
Finally, I modified the width, height, and color of the grazing panels based on their directness to the sun. Panels facing the sun are colored red and have a smaller glazing area to minimize the amount of sunlight passing through. Conversely, panels facing away from the sun are colored blue and have a larger glazing area to maximize the amount of sunlight passing through.
Inside the custom node of “Panels.ComputeSunDirectnessOutwardNormals”:
This custom node operates by initially computing the normal vectors to the panel surfaces. Afterward, I utilized “PanelNormals.AllPointUpward” to ensure that the surface normals are oriented in the upward direction. Lastly, based on the dot product of the sun direction and the panel normals, the node generates a list of "directness" indices.
Inside the custom node of “Panels.ColorizeBlueToRedByValue”:
I made the panels change color based on their directness to the sun by using the output of the sun directness list. I added number sliders to allow for simple modification of the panel colors. In this case, I assigned red to indicate panels that are more directly facing the sun, while blue signifies panels that are facing the sun at an angle. Finally, the color is applied to panels by using the “Element.OverrideColorInView” node.
Optimal form with panels adjusted based on the sun: