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 运算符?还是因为其他问题?
问题不在于 and 运算符,而是相等运算符,del_T1<>del_T2而del_T1==del_T2.
如果您删除了和部分,它们将生成错误消息“连续时间内的非实方程不合法:”。
如果您设法生成代码,它会给出更准确的错误消息:Real 类型的变量无法比较是否相等。
这在 Modelica 规范的第 3.5 节中有说明,https: //specification.modelica.org/v3.4/Ch3.html#equality-relational-and-logical-operators
一种解决方法是将其替换为“足够接近”;例如,替换del_T1==del_T2为abs(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)
(显然可以更改变量声明。)
| 归档时间: |
|
| 查看次数: |
73 次 |
| 最近记录: |