如何在modelica的if语句中使用Multiple And运算符?

JAG*_*KOO 0 if-statement operator-keyword modelica dymola

我正在对热传递中的 LMTD 方法进行编码,并且在同时使用 和 运算符两次以上时遇到了一些错误。

if (del_T1 > beta) and (del_T2 > beta) and (del_T1<>del_T2) then
    T_LMTD = (del_T1-del_T2) / ( (log(del_T1)) - (log(del_T2)));
  elseif (del_T1 > beta) and (del_T2 > beta) and (del_T1==del_T2) then
    T_LMTD = (del_T1-del_T2) / 2;
  elseif (del_T1 > beta) and (del_T2 < beta) then
    T_LMTD = (del_T1 - beta) / ( (log(del_T1/beta)) * (1 - zeta * (del_T2 - beta)));
  elseif (del_T1 < beta) and (del_T2 > beta) then
    T_LMTD = (del_T2 - beta) / ( (log(del_T2/beta)) * (1 - zeta * (del_T1 - beta)));
  elseif (del_T1 < beta) and (del_T2 < beta) then
    T_LMTD = beta / ( (1 - zeta * (del_T1 - beta))  * (1 - zeta * (del_T2 - beta)));
  else
    T_LMTD = beta / ( (1 - zeta * (del_T1 - beta))  * (1 - zeta * (del_T2 - beta)));
  end if;
Run Code Online (Sandbox Code Playgroud)

不幸的是,仅当我在一行中使用 And 运算符两次以上时才模拟模型时,错误消息会打印如下。

在此处输入图片说明

如何多次使用 And 运算符?还是因为其他问题?

Han*_*son 7

问题不在于 and 运算符,而是相等运算符,del_T1<>del_T2del_T1==del_T2.

如果您删除了和部分,它们将生成错误消息“连续时间内的非实方程不合法:”。

如果您设法生成代码,它会给出更准确的错误消息:Real 类型的变量无法比较是否相等。

这在 Modelica 规范的第 3.5 节中有说明,https: //specification.modelica.org/v3.4/Ch3.html#equality-relational-and-logical-operators

一种解决方法是将其替换为“足够接近”;例如,替换del_T1==del_T2abs(del_T1-del_T2)<tol,以获得一些容差。

这给出了一个工作示例:

  Real T_LMTD;
  input Real del_T1;
  input Real del_T2;
  input Real zeta;
  parameter Real beta=0.7;
  parameter Real tol=1e-6;
equation 
 if (del_T1 > beta) and (del_T2 > beta) and abs(del_T1-del_T2)>tol then
    T_LMTD = (del_T1-del_T2) / ( (log(del_T1)) - (log(del_T2)));
  elseif (del_T1 > beta) and (del_T2 > beta) and abs(del_T1-del_T2)<tol then
    T_LMTD = (del_T1-del_T2) / 2;
  elseif (del_T1 > beta) and (del_T2 < beta) then
    T_LMTD = (del_T1 - beta) / ( (log(del_T1/beta)) * (1 - zeta * (del_T2 - beta)));
  elseif (del_T1 < beta) and (del_T2 > beta) then
    T_LMTD = (del_T2 - beta) / ( (log(del_T2/beta)) * (1 - zeta * (del_T1 - beta)));
  elseif (del_T1 < beta) and (del_T2 < beta) then
    T_LMTD = beta / ( (1 - zeta * (del_T1 - beta))  * (1 - zeta * (del_T2 - beta)));
  else
    T_LMTD = beta / ( (1 - zeta * (del_T1 - beta))  * (1 - zeta * (del_T2 - beta)));
  end if;
Run Code Online (Sandbox Code Playgroud)

(显然可以更改变量声明。)