# ********************************************************************************* # URBANopt, Copyright (c) 2019-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: # # Redistributions of source code must retain the above copyright notice, this list # of conditions and the following disclaimer. # # 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. # # Neither the name of the copyright holder nor the names of its contributors may be # used to endorse or promote products derived from this software without specific # prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 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 OR CONTRIBUTORS 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. # ********************************************************************************* module URBANopt module Scenario class ScenarioPostProcessorBase ## # ScenarioPostProcessorBase post-processes a Scenario to create scenario level results. ## # [parameters:] # +scenario_base+ - _ScenarioBase_ - An object of ScenarioBase class. def initialize(scenario_base) @scenario_base = scenario_base end attr_reader :scenario_base ## # Run the post processor on this Scenario. ## def run raise 'run not implemented for ScenarioPostProcessorBase, override in your class' end ## # Add results from a simulation_dir to this result. ## # [parameters:] # +simulation_dir+ - _SimulationDirOSW_ - An object on SimulationDirOSW class. def add_simulation_dir(simulation_dir) raise 'add_simulation_dir not implemented for ScenarioPostProcessorBase, override in your class' end ## # Save scenario result. ## def save raise 'save not implemented for ScenarioPostProcessorBase, override in your class' end end end end