Skip to content

Commit

Permalink
Merge pull request #4221 from NREL/Geometry_Improvements
Browse files Browse the repository at this point in the history
Geometry improvements
  • Loading branch information
tijcolem authored Apr 13, 2021
2 parents 74b17d8 + debd914 commit f2930bb
Show file tree
Hide file tree
Showing 49 changed files with 147,557 additions and 25 deletions.
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -17,3 +17,6 @@ developer/msvc/Visualizers/all_concat.natvis
.clangd/
cppcheck.txt*
clang_format.patch
/0003-Added-ruby-tests-for-the-geometry-improvements.patch
/0002-Formatting-corrections.patch
/0001-Adds-exposedPerimeter-for-Surface.patch
2 changes: 1 addition & 1 deletion Jenkinsfile_develop_osx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
//Jenkins pipelines are stored in shared libaries. Please see: https://github.com/NREL/cbci_jenkins_libs

@Library('cbci_shared_libs') _
@Library('cbci_shared_libs@geometry_improvements') _

// Build for PR to develop branch only.
if ((env.CHANGE_ID) && (env.CHANGE_TARGET) ) {
Expand Down
2 changes: 1 addition & 1 deletion Jenkinsfile_develop_ubuntu_1804
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@

//Jenkins pipelines are stored in shared libaries. Please see: https://github.com/NREL/cbci_jenkins_libs

@Library('cbci_shared_libs') _
@Library('cbci_shared_libs@geometry_improvements') _

// Build for PR to develop branch only.
if ((env.CHANGE_ID) && (env.CHANGE_TARGET) ) {
Expand Down
2 changes: 1 addition & 1 deletion Jenkinsfile_develop_ubuntu_2004
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@

//Jenkins pipelines are stored in shared libaries. Please see: https://github.com/NREL/cbci_jenkins_libs

@Library('cbci_shared_libs') _
@Library('cbci_shared_libs@geometry_improvements') _

// Build for PR to develop branch only.
if ((env.CHANGE_ID) && (env.CHANGE_TARGET) ) {
Expand Down
2 changes: 1 addition & 1 deletion Jenkinsfile_develop_windows
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
//Jenkins pipelines are stored in shared libaries. Please see: https://github.com/NREL/cbci_jenkins_libs

@Library('cbci_shared_libs') _
@Library('cbci_shared_libs@geometry_improvements') _

// Build for PR to develop branch only.
if ((env.CHANGE_ID) && (env.CHANGE_TARGET) ) {
Expand Down
5 changes: 5 additions & 0 deletions resources/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,11 @@ set(ENERGYPLUS_OUTPUTS "")
set(model_resources_src
model/OpenStudio.idd
model/schedulefile.csv

model/two_stories_pre_intersect.osm
model/floorplan_school.osm
model/7-7_Windows_Complete.osm
model/15023_Model12.osm
)


Expand Down
55,540 changes: 55,540 additions & 0 deletions resources/model/15023_Model12.osm

Large diffs are not rendered by default.

81,406 changes: 81,406 additions & 0 deletions resources/model/7-7_Windows_Complete.osm

Large diffs are not rendered by default.

4,468 changes: 4,468 additions & 0 deletions resources/model/floorplan_school.osm

Large diffs are not rendered by default.

Empty file.
292 changes: 292 additions & 0 deletions ruby/test/Building_exteriorPerimeter_Test.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,292 @@
########################################################################################################################
# OpenStudio(R), Copyright (c) 2008-2020, Alliance for Sustainable Energy, LLC, and other contributors. All rights reserved.
#
# Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
# following conditions are met:
#
# (1) Redistributions of source code must retain the above copyright notice, this list of conditions and the following
# disclaimer.
#
# (2) Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following
# disclaimer in the documentation and/or other materials provided with the distribution.
#
# (3) Neither the name of the copyright holder nor the names of any contributors may be used to endorse or promote products
# derived from this software without specific prior written permission from the respective party.
#
# (4) Other than as required in clauses (1) and (2), distributions in any form of modifications or other derivative works
# may not use the "OpenStudio" trademark, "OS", "os", or any other confusingly similar designation without specific prior
# written permission from Alliance for Sustainable Energy, LLC.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER(S) AND ANY CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER(S), ANY CONTRIBUTORS, THE UNITED STATES GOVERNMENT, OR THE UNITED
# STATES DEPARTMENT OF ENERGY, NOR ANY OF THEIR EMPLOYEES, BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES LOSS OF
# USE, DATA, OR PROFITS OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
########################################################################################################################
require 'openstudio'
require_relative 'model.rb'
require 'logger'
require 'openstudio/measure/ShowRunnerOutput'
require 'fileutils'
require 'minitest/autorun'
require 'csv'

class Building_exteriorPerimeter_Test < Minitest::Test
def test_Building_exteriorPerimeter

model = OpenStudio::Model::Model.new

tz1 = OpenStudio::Model::ThermalZone.new(model)
story1 = OpenStudio::Model::BuildingStory.new(model)

p1 = OpenStudio::Point3dVector.new


p1.push(OpenStudio::Point3d.new(36, 168, 0))
p1.push(OpenStudio::Point3d.new(36, 138, 0))
p1.push(OpenStudio::Point3d.new(0, 138, 0))
p1.push(OpenStudio::Point3d.new(0, 168, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Classroom 101")

p1.clear()
p1.push(OpenStudio::Point3d.new(220, 168, 0))
p1.push(OpenStudio::Point3d.new(220, 150, 0))
p1.push(OpenStudio::Point3d.new(220, 124, 0))
p1.push(OpenStudio::Point3d.new(220, 70, 0))
p1.push(OpenStudio::Point3d.new(220, 30, 0))
p1.push(OpenStudio::Point3d.new(200, 30, 0))
p1.push(OpenStudio::Point3d.new(200, 168, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Mechanical 114")

p1.clear()
p1.push(OpenStudio::Point3d.new(288, 70, 0))
p1.push(OpenStudio::Point3d.new(288, 0, 0))
p1.push(OpenStudio::Point3d.new(220, 0, 0))
p1.push(OpenStudio::Point3d.new(220, 30, 0))
p1.push(OpenStudio::Point3d.new(220, 70, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Offices 117")

p1.clear()
p1.push(OpenStudio::Point3d.new(288, 124, 0))
p1.push(OpenStudio::Point3d.new(288, 70, 0))
p1.push(OpenStudio::Point3d.new(220, 70, 0))
p1.push(OpenStudio::Point3d.new(220, 124, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Gym 118")

p1.clear()
p1.push(OpenStudio::Point3d.new(158, 168, 0))
p1.push(OpenStudio::Point3d.new(158, 138, 0))
p1.push(OpenStudio::Point3d.new(98, 138, 0))
p1.push(OpenStudio::Point3d.new(98, 168, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Artroom 103")

p1.clear()
p1.push(OpenStudio::Point3d.new(288, 150, 0))
p1.push(OpenStudio::Point3d.new(288, 124, 0))
p1.push(OpenStudio::Point3d.new(220, 124, 0))
p1.push(OpenStudio::Point3d.new(220, 150, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Kitchen 119")

p1.clear()
p1.push(OpenStudio::Point3d.new(288, 200, 0))
p1.push(OpenStudio::Point3d.new(288, 150, 0))
p1.push(OpenStudio::Point3d.new(220, 150, 0))
p1.push(OpenStudio::Point3d.new(220, 168, 0))
p1.push(OpenStudio::Point3d.new(220, 200, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Cafeteria 120")

p1.clear()
p1.push(OpenStudio::Point3d.new(158, 138, 0))
p1.push(OpenStudio::Point3d.new(158, 128, 0))
p1.push(OpenStudio::Point3d.new(36, 128, 0))
p1.push(OpenStudio::Point3d.new(0, 128, 0))
p1.push(OpenStudio::Point3d.new(0, 138, 0))
p1.push(OpenStudio::Point3d.new(36, 138, 0))
p1.push(OpenStudio::Point3d.new(98, 138, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Corridor 104")

p1.clear()
p1.push(OpenStudio::Point3d.new(36, 128, 0))
p1.push(OpenStudio::Point3d.new(36, 98, 0))
p1.push(OpenStudio::Point3d.new(0, 98, 0))
p1.push(OpenStudio::Point3d.new(0, 128, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Classroom 105")

p1.clear()
p1.push(OpenStudio::Point3d.new(158, 128, 0))
p1.push(OpenStudio::Point3d.new(158, 98, 0))
p1.push(OpenStudio::Point3d.new(36, 98, 0))
p1.push(OpenStudio::Point3d.new(36, 128, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Classroom 106")

p1.clear()
p1.push(OpenStudio::Point3d.new(158, 30, 0))
p1.push(OpenStudio::Point3d.new(158, 40, 0))
p1.push(OpenStudio::Point3d.new(158, 70, 0))
p1.push(OpenStudio::Point3d.new(158, 98, 0))
p1.push(OpenStudio::Point3d.new(158, 128, 0))
p1.push(OpenStudio::Point3d.new(158, 138, 0))
p1.push(OpenStudio::Point3d.new(158, 168, 0))
p1.push(OpenStudio::Point3d.new(200, 168, 0))
p1.push(OpenStudio::Point3d.new(200, 30, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Corridor 107")

p1.clear()
p1.push(OpenStudio::Point3d.new(36, 40, 0))
p1.push(OpenStudio::Point3d.new(36, 70, 0))
p1.push(OpenStudio::Point3d.new(158, 70, 0))
p1.push(OpenStudio::Point3d.new(158, 40, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Classroom 108")

p1.clear()
p1.push(OpenStudio::Point3d.new(0, 40, 0))
p1.push(OpenStudio::Point3d.new(0, 70, 0))
p1.push(OpenStudio::Point3d.new(36, 70, 0))
p1.push(OpenStudio::Point3d.new(36, 40, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Classroom 109")

p1.clear()
p1.push(OpenStudio::Point3d.new(98, 168, 0))
p1.push(OpenStudio::Point3d.new(98, 138, 0))
p1.push(OpenStudio::Point3d.new(36, 138, 0))
p1.push(OpenStudio::Point3d.new(36, 168, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Classroom 102")

p1.clear()
p1.push(OpenStudio::Point3d.new(158, 40, 0))
p1.push(OpenStudio::Point3d.new(158, 30, 0))
p1.push(OpenStudio::Point3d.new(36, 30, 0))
p1.push(OpenStudio::Point3d.new(0, 30, 0))
p1.push(OpenStudio::Point3d.new(0, 40, 0))
p1.push(OpenStudio::Point3d.new(36, 40, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Corridor 110")

p1.clear()
p1.push(OpenStudio::Point3d.new(36, 30, 0))
p1.push(OpenStudio::Point3d.new(36, 0, 0))
p1.push(OpenStudio::Point3d.new(0, 0, 0))
p1.push(OpenStudio::Point3d.new(0, 30, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Classroom 111")

p1.clear()
p1.push(OpenStudio::Point3d.new(158, 30, 0))
p1.push(OpenStudio::Point3d.new(158, 0, 0))
p1.push(OpenStudio::Point3d.new(36, 0, 0))
p1.push(OpenStudio::Point3d.new(36, 30, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Classroom 112")

p1.clear()
p1.push(OpenStudio::Point3d.new(158, 0, 0))
p1.push(OpenStudio::Point3d.new(158, 30, 0))
p1.push(OpenStudio::Point3d.new(200, 30, 0))
p1.push(OpenStudio::Point3d.new(220, 30, 0))
p1.push(OpenStudio::Point3d.new(220, 0, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Lobby 113")

p1.clear()
p1.push(OpenStudio::Point3d.new(220, 200, 0))
p1.push(OpenStudio::Point3d.new(220, 168, 0))
p1.push(OpenStudio::Point3d.new(200, 168, 0))
p1.push(OpenStudio::Point3d.new(158, 168, 0))
p1.push(OpenStudio::Point3d.new(158, 200, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Bathroom 115")

p1.clear()
p1.push(OpenStudio::Point3d.new(220, 268, 0))
p1.push(OpenStudio::Point3d.new(220, 200, 0))
p1.push(OpenStudio::Point3d.new(158, 200, 0))
p1.push(OpenStudio::Point3d.new(158, 268, 0))
sp1 = OpenStudio::Model::Space::fromFloorPrint(p1, 13.125, model)
sp1 = sp1.get
sp1.setBuildingStory(story1)
sp1.setThermalZone(tz1)
sp1.setName("Media Center 116")

assert(model)
buildings = model.getBuilding

# buildings.each do |building|
perimeter = buildings.exteriorPerimeter
assert_in_delta(1428.0,perimeter,0.01)
#end
end
end
Loading

0 comments on commit f2930bb

Please sign in to comment.