Интерпретация плоского кода и счетные уравнения в Димоле

У меня проблемы с поиском источника дополнительного неизвестного в проекте моделирования, над которым я работаю. Я получаю сообщение о том, что у меня 34 неизвестных и 33 уравнения. Я решил взглянуть на сплющенный код в Dymola, и хотя я могу подсчитать правильное количество переменных, я не могу найти способ достичь 33 уравнений. Ниже приведен плоский код:

model HeatStorage
  parameter Modelica.SIunits.Diameter D = 18.667 "Diameter";
  parameter Modelica.SIunits.Height H = 20 "Height";
  parameter Boolean enable_losses = false "= true enable thermal losses with environment";
  parameter Modelica.SIunits.CoefficientOfHeatTransfer alpha = 1 
    "Constant heat transfer coefficient with the ambient";
  parameter Real L_start = 0 "Start value of level in %";
  parameter Modelica.SIunits.Temperature T_start = Modelica.SIunits.Conversions.from_degC
    (300) "Start value of temperature";
  parameter Modelica.SIunits.Temperature T_max = Modelica.SIunits.Conversions.from_degC
    (550) "Maximum tank temperature";
  parameter Modelica.SIunits.Temperature T_set = Modelica.SIunits.Conversions.from_degC
    (300) "Tank Heater Temperature Set-Point";
  parameter Modelica.SIunits.Power W_max = 3000000000.0 "Hot Tank Heater Capacity";
  parameter Modelica.SIunits.Efficiency e_ht = 0.99 "Tank Heater Efficiency";
  parameter Boolean medium.preferredMediumStates = false "= true if StateSelect.prefer shall be used for the independent property variables of the medium";
  parameter Boolean medium.standardOrderComponents = true "If true, and reducedX = true, the last element of X will be computed from the other ones";
  input Modelica.Blocks.Interfaces.RealInput Q_heater;
  parameter Modelica.SIunits.Volume V_t = H*3.141592653589793*D^2/4;

  Modelica.Media.Interfaces.PartialMedium.MassFlowRate fluid_a.m_flow 
    "Mass flow rate from the connection point into the component";
  Modelica.Media.Interfaces.Types.AbsolutePressure fluid_a.p "Thermodynamic pressure in the connection point";
  Modelica.Media.Interfaces.Types.SpecificEnthalpy fluid_a.h_outflow 
    "Specific thermodynamic enthalpy close to the connection point if m_flow < 0";
  Modelica.Media.Interfaces.Types.MassFraction fluid_a.Xi_outflow[0] 
    "Independent mixture mass fractions m_i/m close to the connection point if m_flow < 0";
  Modelica.Media.Interfaces.Types.ExtraProperty fluid_a.C_outflow[0](start = 
    fill(1.0, size(fluid_a.C_outflow, 1))) "Properties c_i/m close to the connection point if m_flow < 0";
  Modelica.Media.Interfaces.PartialMedium.MassFlowRate fluid_b.m_flow 
    "Mass flow rate from the connection point into the component";
  Modelica.Media.Interfaces.Types.AbsolutePressure fluid_b.p "Thermodynamic pressure in the connection point";
  Modelica.Media.Interfaces.Types.SpecificEnthalpy fluid_b.h_outflow 
    "Specific thermodynamic enthalpy close to the connection point if m_flow < 0";
  Modelica.Media.Interfaces.Types.MassFraction fluid_b.Xi_outflow[0] 
    "Independent mixture mass fractions m_i/m close to the connection point if m_flow < 0";
  Modelica.Media.Interfaces.Types.ExtraProperty fluid_b.C_outflow[0](start = 
    fill(1.0, size(fluid_b.C_outflow, 1))) "Properties c_i/m close to the connection point if m_flow < 0";
  Modelica.SIunits.Temperature heat_PB.T "Port temperature";
  Modelica.SIunits.HeatFlowRate heat_PB.Q_flow "Heat flow rate (positive if flowing from outside into the component)";
  Modelica.SIunits.Temperature heat_DS.T "Port temperature";
  Modelica.SIunits.HeatFlowRate heat_DS.Q_flow "Heat flow rate (positive if flowing from outside into the component)";
  Modelica.SIunits.Volume V;
  Modelica.SIunits.Mass m;
  Modelica.Media.Interfaces.PartialMedium.BaseProperties_D1.InputAbsolutePressure 
    medium.p(nominal = 100000.0, unit = "Pa", displayUnit = "bar", min = 0.0) 
    "Absolute pressure of medium";
  Modelica.Media.Interfaces.PartialMedium.BaseProperties_D1.InputMassFraction 
    medium.Xi[0](start = {}, unit = "1", min = 0.0, max = 1.0) "Structurally independent mass fractions";
  Modelica.Media.Interfaces.PartialMedium.BaseProperties_D1.InputSpecificEnthalpy 
    medium.h(unit = "J/kg") "Specific enthalpy of medium";
  Modelica.Media.Interfaces.Types.Density medium.d "Density of medium";
  Modelica.Media.Interfaces.Types.Temperature medium.T(start = 800, min = 573.15,
     max = 873.15) "Temperature of medium";
  Modelica.Media.Interfaces.Types.MassFraction medium.X[2](start = {0.5, 0.5}) 
    "Mass fractions (= (component mass)/total mass  m_i/m)";
  Modelica.Media.Interfaces.Types.SpecificInternalEnergy medium.u 
    "Specific internal energy of medium";
  Modelica.Media.Interfaces.Types.SpecificHeatCapacity medium.R "Gas constant (of mixture if applicable)";
  Modelica.Media.Interfaces.Types.MolarMass medium.MM "Molar mass (of mixture or single fluid)";
  Modelica.Media.Interfaces.Types.AbsolutePressure medium.state.p 
    "Absolute pressure of medium";
  Modelica.Media.Interfaces.Types.SpecificEnthalpy medium.state.h 
    "Specific enthalpy";
  Modelica.SIunits.Conversions.NonSIunits.Temperature_degC medium.T_degC = 
    Modelica.SIunits.Conversions.to_degC(medium.T) "Temperature of medium in [degC]";
  Modelica.SIunits.Conversions.NonSIunits.Pressure_bar medium.p_bar = 
    Modelica.SIunits.Conversions.to_bar(medium.p) "Absolute pressure of medium in [bar]";
  Modelica.SIunits.Area A;
  Modelica.SIunits.HeatFlowRate Q_losses;
  Modelica.Media.Interfaces.Types.AbsolutePressure state_i.p "Absolute pressure of medium";
  Modelica.Media.Interfaces.Types.SpecificEnthalpy state_i.h "Specific enthalpy";
  Modelica.SIunits.Power W_net;
  Modelica.SIunits.Power W_loss;
  output Modelica.Blocks.Interfaces.RealOutput L "Tank level in %";
  Modelica.SIunits.HeatFlowRate Q_PB "Heat Flow to PowerBlock";
  Modelica.SIunits.HeatFlowRate Q_desal "Heat Flow to Desalination";

// Equations and algorithms

  // Component medium
  // class SolarTherm.Media.MoltenSalt.MoltenSalt_base.BaseProperties
    // extends Modelica.Media.Interfaces.PartialMedium.BaseProperties_D1
    equation
      if (medium.standardOrderComponents) then 
        medium.Xi = medium.X[1:0];
        medium.X = {0.5, 0.5};
        for i in (1:2) loop
          assert(medium.X[i] >= -1E-005 and medium.X[i] <= 1.00001, 
            "Mass fraction X["+       String(i, true, 0)+"] = "+       String(
            medium.X[i], true, 0)+"of substance "+{"NaNO3", "KNO3"}[i]+
            "\nof medium "+"MoltenSalt"+" is not in the range 0..1");
        end for;
      end if;
      assert(medium.p >= 0.0, "Pressure (= "+       String(medium.p, true, 0)+
        " Pa) of medium \""+"MoltenSalt"+"\" is negative\n(Temperature = "+
               String(medium.T, true, 0)+" K)");
    // end of extends 
  equation
    medium.d = SolarTherm.Media.MoltenSalt.MoltenSalt_Utilities.rho_T(medium.T);
    medium.h = medium.state.h;
    medium.u = medium.h-medium.p/medium.d;
    medium.MM = 0.091438;
    medium.R = 8.3144/medium.MM;
    medium.state.p = medium.p;
    medium.T = SolarTherm.Media.MoltenSalt.MoltenSalt_Utilities.T_h(medium.h);

  // This model
  // class PentakomoPlant.Storage.HeatStorage
  equation
    Q_losses =  -0.939*exp(Modelica.SIunits.Conversions.to_degC(medium.T)*
      0.005111)*1000*5/7;
    fluid_a.p = medium.p;
    fluid_b.p = medium.p;
    fluid_a.h_outflow = medium.h;
    fluid_b.h_outflow = medium.h;
    der(m) = fluid_a.m_flow+fluid_b.m_flow;
    m*der(medium.h)+der(m)*medium.h = Q_losses+Q_PB+Q_desal+W_net+fluid_a.m_flow
      *inStream(fluid_a.h_outflow)+fluid_b.m_flow*medium.h;
    V = m/medium.d;
    L = 100*(max(medium.T, T_set)-T_set)/(T_max-T_set);
    A = 6.283185307179586*(D/2)*H;
    W_net = Q_heater;
    W_loss = W_net/e_ht;
    heat_PB.Q_flow = Q_PB;
    heat_DS.Q_flow = Q_desal;
    heat_PB.T = medium.T;
    heat_DS.T = medium.T;

// Initial equations and algorithms

  // This model
  // class PentakomoPlant.Storage.HeatStorage
  initial equation
    medium.h = specificEnthalpy_Unique3(
      state_i);
    m = density_Unique4(
      state_i)*V_t;

end HeatStorage;

Если бы кто-то мог пролить некоторый свет на то, как именно уравнения считаются из плоского кода, чтобы помочь мне найти мою отсутствующую переменную, я был бы очень признателен!!

1 ответ

Решение

К сожалению, уплощенный код не содержит всей необходимой информации.

Тем не менее, это хорошее начало и содержит 27 уравнений:

  • 2 уравнения связывания
  • 2 скалярных уравнения в расширениях Modelica.Media.Interfaces.PartialMedium.BaseProperties_D1
  • 7 уравнений в SolarTherm.Media.MoltenSalt.MoltenSalt_base.BaseProperties вне базового класса
  • 16 уравнений в PentakomoPlant.Storage.HeatStorage.

Но кроме того, может быть по крайней мере:

  • Привязки записей (в данном случае нет)
  • Переменные потока в общедоступных коннекторах верхнего уровня; в этом случае я бы предположил, что это 2+2+1+1 (liquid_a, liquid_b, heat_PB, heat_DS).

Публичный ввод верхнего уровня Q_heater может обрабатываться двумя способами, и, насколько я помню, Димола использовал оба варианта: либо он не вносит вклад ни в неизвестные, ни в уравнения (рассматриваемые как известная переменная), либо добавляет один к обоим.

Другие вопросы по тегам