MassFlowSource_T

model MassFlowSource_T "Ideal flow source that produces a prescribed mass flow with prescribed temperature, mass fraction and trace substances"
    import Modelica.Media.Interfaces.Choices.IndependentVariables;

    extends Sources.BaseClasses.PartialFlowSource;

    parameter Boolean use_m_flow_in = false "Get the mass flow rate from the input connector"
        annotation (
            Evaluate = true,
            HideResult = true,
            choices(checkBox = true));
    parameter Boolean use_T_in = false "Get the temperature from the input connector"
        annotation (
            Evaluate = true,
            HideResult = true,
            choices(checkBox = true));
    parameter Boolean use_X_in = false "Get the composition from the input connector"
        annotation (
            Evaluate = true,
            HideResult = true,
            choices(checkBox = true));
    parameter Boolean use_C_in = false "Get the trace substances from the input connector"
        annotation (
            Evaluate = true,
            HideResult = true,
            choices(checkBox = true));
    parameter Medium.MassFlowRate m_flow = 0 "Fixed mass flow rate going out of the fluid port"
        annotation (Dialog(enable = not use_m_flow_in));
    parameter Medium.Temperature T = Medium.T_default "Fixed value of temperature"
        annotation (Dialog(enable = not use_T_in));
    parameter Medium.MassFraction X[Medium.nX] = Medium.X_default "Fixed value of composition"
        annotation (Dialog(enable = not use_X_in and 0 < Medium.nXi));
    parameter Medium.ExtraProperty C[Medium.nC](quantity = Medium.extraPropertiesNames) = Medium.C_default "Fixed values of trace substances"
        annotation (Dialog(enable = not use_C_in and 0 < Medium.nC));
    Modelica.Blocks.Interfaces.RealInput m_flow_in if use_m_flow_in "Prescribed mass flow rate"
        annotation (Placement(
            transformation(extent = {
                {-120, 60}, 
                {-80, 100}}),
            iconTransformation(extent = {
                {-120, 60}, 
                {-80, 100}})));
    Modelica.Blocks.Interfaces.RealInput T_in if use_T_in "Prescribed fluid temperature"
        annotation (Placement(
            transformation(extent = {
                {-140, 20}, 
                {-100, 60}}),
            iconTransformation(extent = {
                {-140, 20}, 
                {-100, 60}})));
    Modelica.Blocks.Interfaces.RealInput X_in[Medium.nX] if use_X_in "Prescribed fluid composition"
        annotation (Placement(transformation(extent = {
            {-140, -60}, 
            {-100, -20}})));
    Modelica.Blocks.Interfaces.RealInput C_in[Medium.nC] if use_C_in "Prescribed boundary trace substances"
        annotation (Placement(transformation(extent = {
            {-120, -100}, 
            {-80, -60}})));
protected
    Modelica.Blocks.Interfaces.RealInput m_flow_in_internal "Needed to connect to conditional connector";
    Modelica.Blocks.Interfaces.RealInput T_in_internal "Needed to connect to conditional connector";
    Modelica.Blocks.Interfaces.RealInput X_in_internal[Medium.nX] "Needed to connect to conditional connector";
    Modelica.Blocks.Interfaces.RealInput C_in_internal[Medium.nC] "Needed to connect to conditional connector";
equation
    connect(C_in,C_in_internal);
    connect(T_in,T_in_internal);
    connect(X_in,X_in_internal);
    connect(m_flow_in,m_flow_in_internal);
    if not use_C_in then 
        C_in_internal = C;
    end if;
    if not use_T_in then 
        T_in_internal = T;
    end if;
    if not use_X_in then 
        X_in_internal = X;
    end if;
    if not use_m_flow_in then 
        m_flow_in_internal = m_flow;
    end if;
    if Medium.ThermoStates == IndependentVariables.ph or Medium.ThermoStates == IndependentVariables.phX then 
        medium.h = Medium.specificEnthalpy(Medium.setState_pTX(medium.p, T_in_internal, X_in_internal));
    else 
        medium.T = T_in_internal;
    end if;
    Utilities.checkBoundary(Medium.mediumName, Medium.substanceNames, Medium.singleState, true, X_in_internal, "MassFlowSource_T");
    medium.Xi = X_in_internal[1:Medium.nXi];
    ports.C_outflow = fill(C_in_internal, nPorts);
    sum(ports.m_flow) = -m_flow_in_internal;

    annotation (
        defaultComponentName = "boundary",
        Icon(
            coordinateSystem(
                preserveAspectRatio = true,
                extent = {
                    {-100, -100}, 
                    {100, 100}}),
            graphics = {
                Rectangle(
                    extent = {
                        {35, 45}, 
                        {100, -45}},
                    fillPattern = FillPattern.HorizontalCylinder,
                    fillColor = {0, 127, 255}), 
                Ellipse(
                    extent = {
                        {-100, 80}, 
                        {60, -80}},
                    lineColor = {0, 0, 255},
                    fillColor = {255, 255, 255},
                    fillPattern = FillPattern.Solid), 
                Polygon(
                    points = {
                        {-60, 70}, 
                        {60, 0}, 
                        {-60, -68}, 
                        {-60, 70}},
                    lineColor = {0, 0, 255},
                    fillColor = {0, 0, 255},
                    fillPattern = FillPattern.Solid), 
                Text(
                    extent = {
                        {-54, 32}, 
                        {16, -30}},
                    lineColor = {255, 0, 0},
                    textString = "m"), 
                Text(
                    extent = {
                        {-150, 130}, 
                        {150, 170}},
                    textString = "%name",
                    lineColor = {0, 0, 255}), 
                Ellipse(
                    extent = {
                        {-26, 30}, 
                        {-18, 22}},
                    lineColor = {255, 0, 0},
                    fillColor = {255, 0, 0},
                    fillPattern = FillPattern.Solid), 
                Text(
                    visible = use_m_flow_in,
                    extent = {
                        {-185, 132}, 
                        {-45, 100}},
                    textString = "m_flow"), 
                Text(
                    visible = use_T_in,
                    extent = {
                        {-111, 71}, 
                        {-71, 37}},
                    textString = "T"), 
                Text(
                    visible = use_X_in,
                    extent = {
                        {-153, -44}, 
                        {-33, -72}},
                    textString = "X"), 
                Text(
                    visible = use_C_in,
                    extent = {
                        {-155, -98}, 
                        {-35, -126}},
                    textString = "C")}),
        Documentation(info = "<html>\n<p>\nModels an ideal flow source, with prescribed values of flow rate, temperature, composition and trace substances:\n</p>\n<ul>\n<li> Prescribed mass flow rate.</li>\n<li> Prescribed temperature.</li>\n<li> Boundary composition (only for multi-substance or trace-substance flow).</li>\n</ul>\n<p>If <code>use_m_flow_in</code> is false (default option), the <code>m_flow</code> parameter\nis used as boundary pressure, and the <code>m_flow_in</code> input connector is disabled; if <code>use_m_flow_in</code> is true, then the <code>m_flow</code> parameter is ignored, and the value provided by the input connector is used instead.</p>\n<p>The same thing goes for the temperature and composition</p>\n<p>\nNote, that boundary temperature,\nmass fractions and trace substances have only an effect if the mass flow\nis from the boundary into the port. If mass is flowing from\nthe port into the boundary, the boundary definitions,\nwith exception of boundary flow rate, do not have an effect.\n</p>\n</html>"));
end MassFlowSource_T;