.VehicleInterfaces.Atmospheres.Tutorial

Information

Tutorial - Defining a new atmosphere model

This tutorial will guide you through the definition of the ConstantAtmosphere model.

  1. Start creating a new model by extending the base atmosphere definition which can be found at VehicleInterfaces.Atmospheres.Interfaces.Base.
  2. This base atmosphere definition includes 4 partial function definitions that we need to provide complete functions for in our new atmosphere model. The following functions need to be defined:
  3. Determine the model assumptions to be used. We will create a model with constant atmospheric conditions, i.e. fixed pressure, temperature, humidity and a constant wind. Create the following functions within the model created in step 1.
  4. Define the windVelocity function. This function is used to define the wind velocity based on the position relative to the world axis:
    function constantWindVelocity
      extends VehicleInterfaces.Atmospheres.Interfaces.Base.windVelocity;
      input Modelica.SIunits.Velocity[3] windVelocity;
    algorithm
      v := windVelocity;
    end constantWindVelocity;
          
  5. Define the density function. This function is used to define the density based on the position relative to the world axis:
    function constantDensity "Determine density"
      extends VehicleInterfaces.Atmospheres.Interfaces.Base.density;
      input Modelica.SIunits.Density density "Density";
    algorithm
      rho := density;
    end constantDensity;
          
  6. Define the temperature function. This function is used to define the temperature based on the position relative to the world axis:
    function constantTemperature "Determine temperature"
      extends VehicleInterfaces.Atmospheres.Interfaces.Base.temperature;
      input Modelica.SIunits.Temperature T0 "Constant temperature";
    algorithm
      T := T0;
    end constantTemperature;
          
  7. Define the humidity function. This function is used to define the humidity based on the position relative to the world axis:
    function constantHumidity "Determine humidity"
      extends VehicleInterfaces.Atmospheres.Interfaces.Base.humidity;
      input Real h0 "Constant humidity";
    algorithm
      h := h0;
    end constantTemperature;
          
  8. We now need to redeclare the functions in the base atmosphere definition to be the functions shown above. We do this with the following code assuming that the above functions have been defined within the class ConstantAtmosphere:
    model ConstantAtmosphere "Atmosphere with constant conditions"
      extends VehicleInterfaces.Atmospheres.Interfaces.Base(
        redeclare final function windVelocity = constantWindVelocity (windVelocity=v),
        redeclare final function density = constantDensity (density=rho),
        redeclare final function temperature = constantTemperature (T0=T),
        redeclare final function humidity = constantHumidity(h0=h));
    
      //Rest of model definition
      ...
    end ConstantAtmosphere;
          
  9. Adding these redeclares also means we need to add 4 parameters to the model v, rho, h and T which are the constant wind velocity, density, humidity and temperature respectively.
  10. This model is now complete and can be used. The ConstantAtmosphere definition included in VehicleInterfaces actually has pressure, temperature and wind velocity as it's parameters and automatically calculates the air density.

Generated at 2025-01-21T19:25:52Z by OpenModelicaOpenModelica 1.24.3 using GenerateDoc.mos