#region Copyright /* * Copyright (c) 2005,2006,2007, OpenMI Association * 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 OpenMI Association 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 "OpenMI Association" ``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 "OpenMI Association" 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. */ #endregion using System; using OpenMI.Standard; using RTCTools.OpenMI.Sdk.Backbone; namespace RTCTools.OpenMI.Sdk.Wrapper { /// /// The class RTCTools.OpenMI.Sdk.Wrapper.LinkableEngine will access the model engine through /// this interface. /// public interface IEngine : IRunEngine { /// /// Returns the ModelID. The ModelID identifies the populated model component. /// Example: "River Rhine" /// /// ModelID string GetModelID(); /// /// Return the Model Description. The Model Description is a description of the populated /// model component. /// /// Model description string GetModelDescription(); /// /// Return the time horison for the populated model compoent. The Time Horizon for a model i typically /// the same as the simulation period, which normally depend on de available input data. When you model /// is running in the OpenMI environment, the model component must be able to return values within the /// TimeHorizon /// /// TimeHorizon ITimeSpan GetTimeHorizon(); /// /// Returns the number of input exchange items for the populated model component. /// /// InputExchangeItemCount int GetInputExchangeItemCount(); /// /// Returns the number of output exchange items for the populated model component. /// /// OutputExchangeItemCount int GetOutputExchangeItemCount(); /// /// Returns a specific output exchange item from the populated model component. /// /// index number /// OutputExchangeItem according the the index number OutputExchangeItem GetOutputExchangeItem(int exchangeItemIndex); /// /// Returns a specific input exchange item from the populated model component. /// /// index number /// InputExchangeItem according the the index number InputExchangeItem GetInputExchangeItem(int exchangeItemIndex); } }