From 47aad95393c8eed47d20e69736af5d7967d2020a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Sj=C3=B6lund?= Date: Tue, 19 Dec 2017 08:58:27 +0100 Subject: [PATCH] Add differentiation of DAE.RSUB Belonging to [master]: - OpenModelica/OMCompiler#2076 - OpenModelica/OpenModelica-testsuite#810 --- Compiler/BackEnd/Differentiate.mo | 31 ++++++++++++++++++++----------- 1 file changed, 20 insertions(+), 11 deletions(-) diff --git a/Compiler/BackEnd/Differentiate.mo b/Compiler/BackEnd/Differentiate.mo index 6898fe1f53..03c6458ed1 100644 --- a/Compiler/BackEnd/Differentiate.mo +++ b/Compiler/BackEnd/Differentiate.mo @@ -685,21 +685,30 @@ algorithm then (res, functionTree); // differentiate tsub - case DAE.TSUB(exp=e1, ix=i, ty=tp) equation - //se1 = ExpressionDump.printExpStr(inExp); - //print("\nExp-TSUB\nDifferentiate exp: " + se1); + case DAE.TSUB(exp=e1, ix=i, ty=tp) + algorithm + (res1, functionTree) := differentiateExp(e1, inDiffwrtCref, inInputData, inDiffType, inFunctionTree, maxIter-1); - (res1, functionTree) = differentiateExp(e1, inDiffwrtCref, inInputData, inDiffType, inFunctionTree, maxIter-1); + if not referenceEq(e1, res1) then + res := DAE.TSUB(res1, i, tp); + (res,_) := ExpressionSimplify.simplify1(res); + else + res := inExp; + end if; + then (res, functionTree); - res = DAE.TSUB(res1, i, tp); - (res,_) = ExpressionSimplify.simplify1(res); - //(res,_) = ExpressionSimplify.simplify(res); - //se1 = ExpressionDump.printExpStr(res); - //print("\nresults to exp: " + se1); - then (res, functionTree); + // differentiate tsub + case e1 as DAE.RSUB() + algorithm + (res1, functionTree) := differentiateExp(e1.exp, inDiffwrtCref, inInputData, inDiffType, inFunctionTree, maxIter-1); + if not referenceEq(e1.exp, res1) then + e1.exp := res1; + (e1,_) := ExpressionSimplify.simplify1(e1); + end if; + then (e1, functionTree); - // differentiate tuple + // differentiate tuple case DAE.TUPLE(PR=expl) equation //se1 = ExpressionDump.printExpStr(inExp); //print("\nExp-TUPLE\nDifferentiate exp: " + se1);