Modelica 阵列元件的冗余连接

Modelica 阵列元件的冗余连接,modelica,dymola,fmi,Modelica,Dymola,Fmi,警告已收到声明我有一个“冗余连接(由于其他连接)。”我正在将一个HeatPort链接到通过使用阵列扩展的多个组件。请参阅下面的代码段 每个的使用似乎都不起作用,或者我没有正确地使用 Redundant connection(s) (due to other connections): connect(topFrontExteriorConvection.solid, module3_PipeComponents[2].port_a); connect(topFrontExteriorConvec

警告已收到声明我有一个“冗余连接(由于其他连接)。”我正在将一个
HeatPort
链接到通过使用阵列扩展的多个组件。请参阅下面的代码段

每个的使用似乎都不起作用,或者我没有正确地使用

Redundant connection(s) (due to other connections):
connect(topFrontExteriorConvection.solid, module3_PipeComponents[2].port_a);
connect(topFrontExteriorConvection.solid, module3_PipeComponents[3].port_a);
connect(topFrontExteriorConvection.solid, module3_PipeComponents[4].port_a);
connect(topFrontExteriorConvection.solid, module3_PipeComponents[5].port_a);
connect(topFrontExteriorConvection.solid, module3_PipeComponents[6].port_a);
in the connection set.
ecoCeramicRadiation.T =module3_PipeComponents[1].port_a.T =module3_PipeComponents[2].port_a.T =module3_PipeComponents[3].port_a.T =module3_PipeComponents[4].port_a.T =module3_PipeComponents[5].port_a.T =module3_PipeComponents[6].port_a.T =topFrontExteriorConvection.solid.T
Note that this is not an actual error, and the redundancy can be removed in several ways.
.solid
.port_a
之间的热量平衡在数学上应该是正确的,但我可能没有在Modelica中正确设置热量平衡。请让我知道是否有一种方法,我可以创建这些连接,而不是他们是多余的。虽然这只是一个警告,但我收到了基于这些警告的以下错误

Edit 1
我设置了一个二级模型,其中组件不再排列,而是在模型中复制了几次。加热端口连接到其他几个加热端口,但我仍然收到上述消息。连接如下所示:

这种连接有问题吗

编辑2
添加代码段。以下是冗余连接警告的相关代码。此模型有更多代码,但为了简洁起见,已将其删除

  parameter Integer numPipes=6 "Number of repeating pipes.";

  Buildings.HeatTransfer.Convection.Exterior topFrontExteriorConvection(
    hFixed=exteriorConvectionCoefficientFixed,
    conMod=extMode,
    azi=Azimuth,
    til=ecoCeramicTopPanelTilt,
    A=surfaceAreaTop);

  Components.Module3_PipeComponents module3_PipeComponents[numPipes](
    each segmentLength=segmentLength,
    each thicknessEco=thicknessEco,
    each pipeVolume=pipeVolume,
    each fluidFlow=fluidFlow,
    each initialFluidTemp=initialFluidTemp,
    each fluidDensity=fluidDensity,
    each pipeDiameter=pipeDiameter,
    each pipeLength=pipeLength,
    each surfaceAreaTop=segSurfaceArea);

equation
  connect(fluidInlet, module3_PipeComponents[1].flowPort_a);
  for i in 1:numPipes - 1 loop
    connect(module3_PipeComponents[i].flowPort_b, module3_PipeComponents[i+1].flowPort_a);
  end for;
  for i in 1:numPipes loop
    connect(ecoCeramicRadiation, module3_PipeComponents[i].port_a);
    connect(topFrontExteriorConvection.solid, module3_PipeComponents[i].port_a);
    connect(module3_PipeComponents[i].port_b, topInsulationConduction.port_a);
  end for;
  connect(module3_PipeComponents[numPipes].flowPort_b, fluidOutlet);

问题在于以下几行:

for i in 1:numPipes loop
    connect(ecoCeramicRadiation,              module3_PipeComponents[i].port_a);
    connect(topFrontExteriorConvection.solid, module3_PipeComponents[i].port_a);
...
end for;
这意味着numPipes*2个连接涉及numPipes+2个连接器,如果numPipes足够大,则意味着冗余连接

避免这种情况的一种方法是:

for i in 1:numPipes loop
    connect(ecoCeramicRadiation,              module3_PipeComponents[i].port_a);
...
end for;
connect(ecoCeramicRadiation, topFrontExteriorConvection.solid);

您能否提供模型的文本,因为通常很难从图表中看到所有内容。对于阵列组合连接,这甚至更加困难,因为其中可能有带有connect的For循环,并且它们根本没有显示在图中。您好@HansOlsson,谢谢您的建议。我添加了一个代码段。