Running: ./testmodel.py --libraries=/home/hudson/saved_omc/libraries/.openmodelica/libraries --ompython_omhome=/usr Modelica_LinearSystems2_dev_Modelica_LinearSystems2.Controller.Examples.Interpolator.conf.json loadFile("/home/hudson/saved_omc/libraries/.openmodelica/libraries/DymolaCommands master/package.mo", uses=false) loadFile("/home/hudson/saved_omc/libraries/.openmodelica/libraries/ModelicaServices 4.0.0+maint.om/package.mo", uses=false) loadFile("/home/hudson/saved_omc/libraries/.openmodelica/libraries/Complex 4.0.0+maint.om/package.mo", uses=false) loadFile("/home/hudson/saved_omc/libraries/.openmodelica/libraries/Modelica 4.0.0+maint.om/package.mo", uses=false) loadFile("/home/hudson/saved_omc/libraries/.openmodelica/libraries/Modelica_LinearSystems2 3.0.0-dev/package.mo", uses=false) Using package Modelica_LinearSystems2 with version 3.0.0-dev (/home/hudson/saved_omc/libraries/.openmodelica/libraries/Modelica_LinearSystems2 3.0.0-dev/package.mo) Using package Modelica with version 4.0.0 (/home/hudson/saved_omc/libraries/.openmodelica/libraries/Modelica 4.0.0+maint.om/package.mo) Using package Complex with version 4.0.0 (/home/hudson/saved_omc/libraries/.openmodelica/libraries/Complex 4.0.0+maint.om/package.mo) Using package ModelicaServices with version 4.0.0 (/home/hudson/saved_omc/libraries/.openmodelica/libraries/ModelicaServices 4.0.0+maint.om/package.mo) Using package DymolaCommands with version 0.0.0 (/home/hudson/saved_omc/libraries/.openmodelica/libraries/DymolaCommands master/package.mo) Running command: translateModel(Modelica_LinearSystems2.Controller.Examples.Interpolator,tolerance=1e-06,outputFormat="empty",numberOfIntervals=5000,variableFilter="",fileNamePrefix="Modelica_LinearSystems2_dev_Modelica_LinearSystems2.Controller.Examples.Interpolator") translateModel(Modelica_LinearSystems2.Controller.Examples.Interpolator,tolerance=1e-06,outputFormat="empty",numberOfIntervals=5000,variableFilter="",fileNamePrefix="Modelica_LinearSystems2_dev_Modelica_LinearSystems2.Controller.Examples.Interpolator") Notification: Performance of loadFile(/home/hudson/saved_omc/libraries/.openmodelica/libraries/DymolaCommands master/package.mo): time 0.0005788/0.0005788, allocations: 40.36 kB / 16.35 MB, free: 6.508 MB / 14.72 MB Notification: Performance of loadFile(/home/hudson/saved_omc/libraries/.openmodelica/libraries/ModelicaServices 4.0.0+maint.om/package.mo): time 0.0009616/0.0009616, allocations: 107.8 kB / 17.19 MB, free: 5.871 MB / 14.72 MB Notification: Performance of loadFile(/home/hudson/saved_omc/libraries/.openmodelica/libraries/Complex 4.0.0+maint.om/package.mo): time 0.001078/0.001078, allocations: 195 kB / 18.14 MB, free: 4.934 MB / 14.72 MB Notification: Performance of loadFile(/home/hudson/saved_omc/libraries/.openmodelica/libraries/Modelica 4.0.0+maint.om/package.mo): time 1.203/1.203, allocations: 222.9 MB / 241.8 MB, free: 15.05 MB / 206.1 MB Notification: Performance of loadFile(/home/hudson/saved_omc/libraries/.openmodelica/libraries/Modelica_LinearSystems2 3.0.0-dev/package.mo): time 0.2396/0.2396, allocations: 44.72 MB / 336.7 MB, free: 3.07 MB / 270.1 MB Notification: Performance of FrontEnd - Absyn->SCode: time 1.597e-05/1.597e-05, allocations: 2.281 kB / 466.3 MB, free: 15.84 MB / 350.1 MB Notification: Performance of NFInst.instantiate(Modelica_LinearSystems2.Controller.Examples.Interpolator): time 0.003204/0.003228, allocations: 2.747 MB / 469 MB, free: 13.07 MB / 350.1 MB Notification: Performance of NFInst.instExpressions: time 0.001174/0.004415, allocations: 0.8883 MB / 469.9 MB, free: 12.18 MB / 350.1 MB Notification: Performance of NFInst.updateImplicitVariability: time 0.0001019/0.004527, allocations: 7.938 kB / 469.9 MB, free: 12.17 MB / 350.1 MB Notification: Performance of NFTyping.typeComponents: time 0.0002834/0.004817, allocations: 63.44 kB / 470 MB, free: 12.11 MB / 350.1 MB Notification: Performance of NFTyping.typeBindings: time 8.14e-05/0.004908, allocations: 43.72 kB / 470 MB, free: 12.07 MB / 350.1 MB Notification: Performance of NFTyping.typeClassSections: time 0.0004091/0.005332, allocations: 195.6 kB / 470.2 MB, free: 11.88 MB / 350.1 MB Notification: Performance of NFFlatten.flatten: time 0.0003371/0.005679, allocations: 399.2 kB / 470.6 MB, free: 11.48 MB / 350.1 MB Notification: Performance of NFFlatten.resolveConnections: time 0.0001533/0.005841, allocations: 80.83 kB / 470.7 MB, free: 11.4 MB / 350.1 MB Notification: Performance of NFEvalConstants.evaluate: time 0.0001574/0.006005, allocations: 147.5 kB / 470.8 MB, free: 11.26 MB / 350.1 MB Notification: Performance of NFSimplifyModel.simplify: time 0.0001369/0.006151, allocations: 139.3 kB / 471 MB, free: 11.12 MB / 350.1 MB Notification: Performance of NFPackage.collectConstants: time 3.846e-05/0.006197, allocations: 28 kB / 471 MB, free: 11.09 MB / 350.1 MB Notification: Performance of NFFlatten.collectFunctions: time 3.442e-05/0.006237, allocations: 28 kB / 471 MB, free: 11.07 MB / 350.1 MB Notification: Performance of combineBinaries: time 0.0002541/0.006495, allocations: 407.3 kB / 471.4 MB, free: 10.66 MB / 350.1 MB Notification: Performance of replaceArrayConstructors: time 0.0001119/0.006614, allocations: 244.2 kB / 471.7 MB, free: 10.42 MB / 350.1 MB Notification: Performance of NFVerifyModel.verify: time 4.234e-05/0.006661, allocations: 43.81 kB / 471.7 MB, free: 10.38 MB / 350.1 MB Notification: Performance of FrontEnd: time 2.643e-05/0.006693, allocations: 15.94 kB / 471.7 MB, free: 10.36 MB / 350.1 MB Notification: Model statistics after passing the front-end and creating the data structures used by the back-end: * Number of equations: 54 (50) * Number of variables: 54 (48) Notification: Performance of Bindings: time 0.001046/0.007744, allocations: 1.187 MB / 472.9 MB, free: 9.066 MB / 350.1 MB Notification: Performance of FunctionAlias: time 7.267e-05/0.007822, allocations: 41.05 kB / 472.9 MB, free: 9.027 MB / 350.1 MB Notification: Performance of Early Inline: time 0.0006108/0.00844, allocations: 0.7257 MB / 473.7 MB, free: 8.273 MB / 350.1 MB Notification: Performance of simplify1: time 4.092e-05/0.008488, allocations: 39.94 kB / 473.7 MB, free: 8.234 MB / 350.1 MB Notification: Performance of Alias: time 0.0009977/0.009491, allocations: 1.023 MB / 474.7 MB, free: 7.062 MB / 350.1 MB Notification: Performance of simplify2: time 2.718e-05/0.009528, allocations: 31.94 kB / 474.8 MB, free: 7.031 MB / 350.1 MB Notification: Performance of Events: time 0.0001522/0.009685, allocations: 131.6 kB / 474.9 MB, free: 6.902 MB / 350.1 MB Notification: Performance of Detect States: time 0.0003711/0.01006, allocations: 426.5 kB / 475.3 MB, free: 6.473 MB / 350.1 MB Notification: Performance of Partitioning: time 0.0002787/0.01035, allocations: 259.5 kB / 475.6 MB, free: 6.203 MB / 350.1 MB Error: Internal error NBSorting.tarjan failed to sort system: system vars Variables (36/42) ******************************* (1) [DISS] (1) protected Real interpolator2.discreteInterpolator.pre_u (2) [DISC] (1) Boolean $SEV_3 (3) [DISC] (1) Boolean $SEV_2 (4) [ALGB] (1) Real $FUN_1 (5) [DISC] (1) Boolean $SEV_1 (6) [DISC] (1) Boolean $SEV_0 (7) [DISS] (1) protected Integer interpolator2.discreteInterpolator.ticks (fixed = true, start = 1) (8) [DISS] (4) protected discrete Real[4] interpolator3.discreteFIR.sum (9) [DISS] (1) protected Boolean interpolator2.discreteInterpolator.sampleIn (10) [DISS] (1) protected discrete Real interpolator3.discreteFIR.u_sampled (11) [DISC] (1) protected Boolean interpolator3.discreteFIR.sampleTrigger (12) [DISS] (1) protected Integer interpolator2.discreteInterpolator.outputTicks (fixed = true, start = 0) (13) [DISS] (4) protected discrete Real[4] interpolator3.discreteFIR.x (14) [DISS] (1) protected Integer interpolator3.discreteInterpolator.outputTicks (fixed = true, start = 0) (15) [DISS] (1) protected Integer sampler.discretePart.ticks (16) [DISS] (1) protected Integer interpolator3.discreteFIR.ticks (17) [DISS] (1) protected discrete Real interpolator3.discreteFIR.y_sampled (18) [DISC] (1) protected Integer interpolator2.discreteInterpolator.inputOutputSampleFactor = div(interpolator2.discreteInterpolator.inputSampleFactor, interpolator2.discreteInterpolator.outputSampleFactor) (19) [DISC] (1) Boolean $TEV_6 (20) [DISC] (1) Boolean $TEV_5 (21) [DISC] (1) Boolean $TEV_4 (22) [DISS] (1) protected Real interpolator3.discreteInterpolator.pre_u (23) [DISC] (1) Boolean $TEV_3 (24) [DISC] (1) Boolean $TEV_2 (25) [DISC] (1) protected Boolean sampler.discretePart.sampleTrigger (26) [DISC] (1) Boolean $TEV_1 (27) [DISS] (1) protected discrete Real sampler.discretePart.u_sampled (28) [DISC] (1) Boolean $TEV_0 (29) [DISS] (1) protected Boolean interpolator3.discreteInterpolator.sampleIn (30) [DISC] (1) Boolean sampleClock.sampleTrigger (31) [DISS] (1) protected Integer interpolator3.discreteInterpolator.ticks (fixed = true, start = 1) (32) [DISS] (1) protected Real interpolator3.discreteInterpolator.y (33) [DISC] (1) protected Boolean interpolator2.discreteInterpolator.outputSampleTrigger (34) [DISS] (1) protected Real interpolator2.discreteInterpolator.y (35) [DISC] (1) protected Boolean interpolator3.discreteInterpolator.outputSampleTrigger (36) [ALGB] (1) Real interpolator1.y system eqns Equations (38/42) ******************************* (1) [WHEN] (1)when {initial(), sampler.discretePart.sampleTrigger} then (1) [----] sampler.discretePart.u_sampled := interpolator1.y (1) [----] end when; (2) [SCAL] (1) interpolator3.discreteFIR.sampleTrigger = $SEV_1 ($RES_SIM_11) (3) [WHEN] (1)when sampleClock.sampleTrigger then (3) [----] interpolator3.discreteFIR.ticks := if $PRE.interpolator3.discreteFIR.ticks < 4 then $PRE.interpolator3.discreteFIR.ticks + 1 else 1 (3) [----] end when; (4) [WHEN] (1)when {initial(), interpolator3.discreteFIR.sampleTrigger} then (4) [----] interpolator3.discreteFIR.sum[1] := interpolator3.discreteFIR.a[2] * interpolator3.discreteFIR.x[1] (4) [----] end when; (5) [SCAL] (1) interpolator2.discreteInterpolator.outputSampleTrigger = $SEV_3 ($RES_SIM_30) (6) [WHEN] (3)when {initial(), interpolator3.discreteFIR.sampleTrigger} then (6) [----] interpolator3.discreteFIR.x[2:4] := $PRE.interpolator3.discreteFIR.x (6) [----] end when; (7) [SCAL] (1) interpolator2.discreteInterpolator.inputOutputSampleFactor = div(interpolator2.discreteInterpolator.inputSampleFactor, interpolator2.discreteInterpolator.outputSampleFactor) ($RES_$AUX_58) (8) [WHEN] (1)when sampleClock.sampleTrigger then (8) [----] interpolator2.discreteInterpolator.outputTicks := if $PRE.interpolator2.discreteInterpolator.outputTicks < interpolator2.discreteInterpolator.outputSampleFactor then $PRE.interpolator2.discreteInterpolator.outputTicks + 1 else 1 (8) [----] end when; (9) [WHEN] (1)when {initial(), interpolator3.discreteFIR.sampleTrigger} then (9) [----] interpolator3.discreteFIR.y_sampled := interpolator3.discreteFIR.a[1] * interpolator3.discreteInterpolator.y + interpolator3.discreteFIR.sum[4] (9) [----] end when; (10) [SCAL] (1) $FUN_1 = sin(6.283185307179586 * sine.f * (time - sine.startTime) + sine.phase) ($RES_$AUX_59) (11) [WHEN] (1)when {initial(), interpolator3.discreteFIR.sampleTrigger} then (11) [----] interpolator3.discreteFIR.x[1] := $PRE.interpolator3.discreteInterpolator.y (11) [----] end when; (12) [WHEN] (3)when {initial(), interpolator3.discreteFIR.sampleTrigger} then (12) [----] interpolator3.discreteFIR.sum[2:4] := interpolator3.discreteFIR.a[3:5] * diagonal(interpolator3.discreteFIR.x[2:4]) + interpolator3.discreteFIR.sum[1:3] (12) [----] end when; (13) [SCAL] (1) sampleClock.sampleTrigger = $TEV_5 ($RES_SIM_34) (14) [WHEN] (1)when {initial(), interpolator3.discreteFIR.sampleTrigger} then (14) [----] interpolator3.discreteFIR.u_sampled := interpolator3.discreteInterpolator.y (14) [----] end when; (15) [SCAL] (1) interpolator1.y = sine.offset + (if $TEV_6 then 0.0 else sine.amplitude * $FUN_1) ($RES_SIM_35) (16) [SCAL] (1) $TEV_0 = $PRE.sampler.discretePart.ticks ($RES_EVT_60) (17) [SCAL] (1) $TEV_1 = $PRE.interpolator3.discreteFIR.ticks ($RES_EVT_61) (18) [SCAL] (1) $TEV_2 = $PRE.interpolator3.discreteFIR.x ($RES_EVT_62) (19) [SCAL] (1) $TEV_3 = $PRE.interpolator3.discreteInterpolator.pre_u ($RES_EVT_63) (20) [SCAL] (1) $TEV_4 = $PRE.interpolator2.discreteInterpolator.pre_u ($RES_EVT_64) (21) [SCAL] (1) $TEV_5 = sample(1, sampleClock.sampleTime, sampleClock.sampleTime) ($RES_EVT_65) (22) [SCAL] (1) $TEV_6 = time < sine.startTime ($RES_EVT_66) (23) [SCAL] (1) $SEV_0 = sampleClock.sampleTrigger and sampler.discretePart.ticks >= sampler.discretePart.sampleFactor ($RES_EVT_67) (24) [WHEN] (1)when {initial(), interpolator3.discreteInterpolator.sampleIn} then (24) [----] interpolator3.discreteInterpolator.pre_u := $PRE.sampler.discretePart.u_sampled (24) [----] end when; (25) [SCAL] (1) $SEV_1 = sampleClock.sampleTrigger and interpolator3.discreteFIR.ticks >= 4 ($RES_EVT_68) (26) [WHEN] (1)when interpolator3.discreteInterpolator.outputSampleTrigger then (26) [----] interpolator3.discreteInterpolator.sampleIn := interpolator3.discreteInterpolator.ticks == 1 (26) [----] end when; (27) [SCAL] (1) $SEV_2 = sampleClock.sampleTrigger and interpolator3.discreteInterpolator.outputTicks >= 4 ($RES_EVT_69) (28) [WHEN] (1)when interpolator3.discreteInterpolator.outputSampleTrigger then (28) [----] interpolator3.discreteInterpolator.y := if interpolator3.discreteInterpolator.ticks == 1 then (sampler.discretePart.u_sampled - $PRE.sampler.discretePart.u_sampled) / 5 + $PRE.sampler.discretePart.u_sampled else $PRE.interpolator3.discreteInterpolator.pre_u + (interpolator3.discreteInterpolator.ticks / 5) * ($PRE.sampler.discretePart.u_sampled - $PRE.interpolator3.discreteInterpolator.pre_u) (28) [----] end when; (29) [WHEN] (1)when interpolator3.discreteInterpolator.outputSampleTrigger then (29) [----] interpolator3.discreteInterpolator.ticks := if $PRE.interpolator3.discreteInterpolator.ticks < 5 then $PRE.interpolator3.discreteInterpolator.ticks + 1 else 1 (29) [----] end when; (30) [SCAL] (1) interpolator3.discreteInterpolator.outputSampleTrigger = $SEV_2 ($RES_SIM_24) (31) [WHEN] (1)when sampleClock.sampleTrigger then (31) [----] interpolator3.discreteInterpolator.outputTicks := if $PRE.interpolator3.discreteInterpolator.outputTicks < 4 then $PRE.interpolator3.discreteInterpolator.outputTicks + 1 else 1 (31) [----] end when; (32) [WHEN] (1)when {initial(), interpolator2.discreteInterpolator.sampleIn} then (32) [----] interpolator2.discreteInterpolator.pre_u := $PRE.sampler.discretePart.u_sampled (32) [----] end when; (33) [WHEN] (1)when interpolator2.discreteInterpolator.outputSampleTrigger then (33) [----] interpolator2.discreteInterpolator.sampleIn := interpolator2.discreteInterpolator.ticks == 1 (33) [----] end when; (34) [WHEN] (1)when interpolator2.discreteInterpolator.outputSampleTrigger then (34) [----] interpolator2.discreteInterpolator.ticks := if $PRE.interpolator2.discreteInterpolator.ticks < interpolator2.discreteInterpolator.inputOutputSampleFactor then $PRE.interpolator2.discreteInterpolator.ticks + 1 else 1 (34) [----] end when; (35) [WHEN] (1)when interpolator2.discreteInterpolator.outputSampleTrigger then (35) [----] interpolator2.discreteInterpolator.y := if interpolator2.discreteInterpolator.ticks == 1 then (sampler.discretePart.u_sampled - $PRE.sampler.discretePart.u_sampled) / interpolator2.discreteInterpolator.inputOutputSampleFactor + $PRE.sampler.discretePart.u_sampled else $PRE.interpolator2.discreteInterpolator.pre_u + (interpolator2.discreteInterpolator.ticks / interpolator2.discreteInterpolator.inputOutputSampleFactor) * ($PRE.sampler.discretePart.u_sampled - $PRE.interpolator2.discreteInterpolator.pre_u) (35) [----] end when; (36) [WHEN] (1)when sampleClock.sampleTrigger then (36) [----] sampler.discretePart.ticks := if $PRE.sampler.discretePart.ticks < sampler.discretePart.sampleFactor then $PRE.sampler.discretePart.ticks + 1 else 1 (36) [----] end when; (37) [SCAL] (1) sampler.discretePart.sampleTrigger = $SEV_0 ($RES_SIM_7) (38) [SCAL] (1) $SEV_3 = sampleClock.sampleTrigger and interpolator2.discreteInterpolator.outputTicks >= interpolator2.discreteInterpolator.outputSampleFactor ($RES_EVT_70) =================== Scalar Matching =================== variable to equation ********************** var 1 --> eqn 36 var 2 --> eqn 42 var 3 --> eqn 31 var 4 --> eqn 12 var 5 --> eqn 29 var 6 --> eqn 27 var 7 --> eqn 38 var 8 --> eqn 4 var 9 --> eqn 16 var 10 --> eqn 15 var 11 --> eqn 14 var 12 --> eqn 37 var 13 --> eqn 18 var 14 --> eqn 2 var 15 --> eqn 10 var 16 --> eqn 13 var 17 --> eqn 8 var 18 --> eqn 7 var 19 --> eqn 6 var 20 --> eqn 35 var 21 --> eqn 40 var 22 --> eqn 3 var 23 --> eqn 11 var 24 --> eqn 9 var 25 --> eqn 26 var 26 --> eqn 25 var 27 --> eqn 24 var 28 --> eqn 28 var 29 --> eqn 23 var 30 --> eqn 22 var 31 --> eqn 41 var 32 --> eqn 21 var 33 --> eqn 1 var 34 --> eqn 20 var 35 --> eqn 30 var 36 --> eqn 17 var 37 --> eqn 33 var 38 --> eqn 32 var 39 --> eqn 5 var 40 --> eqn 39 var 41 --> eqn 34 var 42 --> eqn 19 equation to variable ********************** eqn 1 --> var 33 eqn 2 --> var 14 eqn 3 --> var 22 eqn 4 --> var 8 eqn 5 --> var 39 eqn 6 --> var 19 eqn 7 --> var 18 eqn 8 --> var 17 eqn 9 --> var 24 eqn 10 --> var 15 eqn 11 --> var 23 eqn 12 --> var 4 eqn 13 --> var 16 eqn 14 --> var 11 eqn 15 --> var 10 eqn 16 --> var 9 eqn 17 --> var 36 eqn 18 --> var 13 eqn 19 --> var 42 eqn 20 --> var 34 eqn 21 --> var 32 eqn 22 --> var 30 eqn 23 --> var 29 eqn 24 --> var 27 eqn 25 --> var 26 eqn 26 --> var 25 eqn 27 --> var 6 eqn 28 --> var 28 eqn 29 --> var 5 eqn 30 --> var 35 eqn 31 --> var 3 eqn 32 --> var 38 eqn 33 --> var 37 eqn 34 --> var 41 eqn 35 --> var 20 eqn 36 --> var 1 eqn 37 --> var 12 eqn 38 --> var 7 eqn 39 --> var 40 eqn 40 --> var 21 eqn 41 --> var 31 eqn 42 --> var 2