| 1 | within ;
|
|---|
| 2 | package AutoCreateBug
|
|---|
| 3 |
|
|---|
| 4 |
|
|---|
| 5 |
|
|---|
| 6 |
|
|---|
| 7 |
|
|---|
| 8 |
|
|---|
| 9 | model GridOneTrack
|
|---|
| 10 | "One track variable numbers of ESS's and trains, with inner grid (no commutator)"
|
|---|
| 11 | model SimpleVarResis "simple Variable resistor"
|
|---|
| 12 | /* La ridefinizione del resistore si rende necessaria per due ragioni:
|
|---|
| 13 | - consente di attribuire un valore direttamente a R dall'esterno senza
|
|---|
| 14 | necessita' di un'equazione connect
|
|---|
| 15 | - consente di eliminare le equazioni relative alla gestione termica che non
|
|---|
| 16 | interessano
|
|---|
| 17 | */
|
|---|
| 18 | extends Modelica.Electrical.Analog.Interfaces.OnePort;
|
|---|
| 19 | Modelica.SIunits.Resistance R;
|
|---|
| 20 | equation
|
|---|
| 21 | v = R * i;
|
|---|
| 22 | end SimpleVarResis;
|
|---|
| 23 |
|
|---|
| 24 | Modelica.Blocks.Interfaces.RealInput trainPos[numOfTrains]
|
|---|
| 25 | "each train's position" annotation(Placement(transformation(extent = {{-20, 20}, {20, -20}}, rotation = 0, origin = {-180, 0}), iconTransformation(extent = {{-15, -15}, {15, 15}}, origin = {-175, 1})));
|
|---|
| 26 | Modelica.Electrical.MultiPhase.Interfaces.PositivePlug ep(m = numOfSect) annotation(Placement(transformation(extent = {{-10, 50}, {10, 70}}), iconTransformation(extent = {{-8, 52}, {8, 68}})));
|
|---|
| 27 | Modelica.Electrical.MultiPhase.Interfaces.PositivePlug tp(m = numOfTrains) annotation(Placement(transformation(extent = {{-10, -50}, {10, -70}}), iconTransformation(extent = {{-8, -52}, {8, -68}})));
|
|---|
| 28 | constant Real resisSmall=1e-6, resisLarge=1e6;
|
|---|
| 29 | parameter Real iniSecPos[:] = {580, 1744, 3141}
|
|---|
| 30 | "Positions of section borders (typically ESS's abscissas)";
|
|---|
| 31 | parameter Real lineLength = 3500 "total length inclusind terminal trunks";
|
|---|
| 32 | final parameter Integer numOfSect = size(iniSecPos, 1)
|
|---|
| 33 | "Number of sections (typically number of ESS's)";
|
|---|
| 34 | parameter Modelica.SIunits.Resistivity resistivity[numOfSect + 1] = {0.000108, 0.000108, 0.00014, 0.00014}
|
|---|
| 35 | "resistivity of line trunks";
|
|---|
| 36 | //Il numero di resistenze da mmettere lungo la linea è pari al numero di
|
|---|
| 37 | // sezioni + 1 in quanto possono essere differenti le resistività delle due mezze
|
|---|
| 38 | // sezioni di estremità.
|
|---|
| 39 | /*Il numero di resistenze è pari a :
|
|---|
| 40 | 2*(numOfSect-1) per i tratti fra le Ess: uno a SX uno DX del treno
|
|---|
| 41 | 2 per i tratti a sbalzo, a SX della prima ESS e a DX dell'ultima
|
|---|
| 42 | */
|
|---|
| 43 | parameter Integer numOfTrains = 2 "number of trains";
|
|---|
| 44 | SimpleVarResis resisLeft[numOfSect] "Left section-side resistor", resisRight[numOfSect]
|
|---|
| 45 | "Right section-side resistor";
|
|---|
| 46 | /* Nota: resisRight[1] è la resistenza del primo tratto a sbalzo; resisLeft[1])
|
|---|
| 47 | è la resistenza di sinistra della prima sezione completa resisRight[2] è la
|
|---|
| 48 | resistenza di destra della prima sezione completa.
|
|---|
| 49 | Inoltre il pin positivo di tutti i resistori è messo a sinistra.
|
|---|
| 50 | In tal modo dentro la sezione resisLeft[i].n è connesso a resisRight[i+1].p,
|
|---|
| 51 | e ai confini di sezione resisRight[i].n è connesso a resisLeft[i].p,
|
|---|
| 52 | */
|
|---|
| 53 | SimpleVarResis resisConn[numOfTrains,numOfSect+1];
|
|---|
| 54 | Integer z[numOfTrains];
|
|---|
| 55 | Modelica.SIunits.Power lostPower;
|
|---|
| 56 | // Interfaccia della rete verso l'esterno: gli input con le posizioni dei treni
|
|---|
| 57 | // e i pin di connessione alle ESS e ai treni
|
|---|
| 58 | //Ora trovo la sezione z in cui si trova il treno:
|
|---|
| 59 | algorithm
|
|---|
| 60 | for train in 1:numOfTrains loop
|
|---|
| 61 | z[train] := 1;
|
|---|
| 62 | for sect in 1:numOfSect loop
|
|---|
| 63 | if trainPos[train] > iniSecPos[sect] then
|
|---|
| 64 | z[train] := z[train] + 1;
|
|---|
| 65 | end if;
|
|---|
| 66 | end for;
|
|---|
| 67 | end for;
|
|---|
| 68 | equation
|
|---|
| 69 | //Collegamenti delle resistenze di linea fra loro:
|
|---|
| 70 | for i in 1:numOfSect - 1 loop
|
|---|
| 71 | connect(resisRight[i].n, resisLeft[i].p);
|
|---|
| 72 | connect(resisLeft[i].n, resisRight[i + 1].p);
|
|---|
| 73 | connect(resisRight[i].n, ep.pin[i]);
|
|---|
| 74 | end for;
|
|---|
| 75 | connect(resisRight[numOfSect].n, resisLeft[numOfSect].p);
|
|---|
| 76 | connect(resisRight[numOfSect].n, ep.pin[numOfSect]);
|
|---|
| 77 |
|
|---|
| 78 | //Collegamenti dei treni alle sezioni di linea:
|
|---|
| 79 | for i in 1:numOfTrains loop
|
|---|
| 80 | for j in 1:numOfSect loop
|
|---|
| 81 | connect(resisConn[i,j].p,resisRight[j].p);
|
|---|
| 82 | connect(resisConn[i,j].n,tp.pin[i]);
|
|---|
| 83 | end for;
|
|---|
| 84 | connect(resisConn[i,numOfSect+1].p,resisLeft[numOfSect].n);
|
|---|
| 85 | connect(resisConn[i,numOfSect+1].n,tp.pin[i]);
|
|---|
| 86 | end for;
|
|---|
| 87 |
|
|---|
| 88 | //Scelgo i valori delle resistenze dei resistori di collegamento:
|
|---|
| 89 | for i in 1:numOfTrains loop
|
|---|
| 90 | for j in 1:numOfSect+1 loop
|
|---|
| 91 | if z[i]==j then
|
|---|
| 92 | resisConn[i,j].R = resisSmall;
|
|---|
| 93 | else
|
|---|
| 94 | resisConn[i,j].R = resisLarge;
|
|---|
| 95 | end if;
|
|---|
| 96 | end for;
|
|---|
| 97 | end for;
|
|---|
| 98 | /*Calcolo i valori delle resistenze. In questa versione preliminare divido equamente
|
|---|
| 99 | le resistenze di sezione fra i due lati left e right; poi aggiusto i valori
|
|---|
| 100 | della sola sezione in cui vi è il treno.
|
|---|
| 101 | La numerazione è conforme a quanto riportato nel file "Schema rete.docx".
|
|---|
| 102 | */
|
|---|
| 103 | for i in 1:numOfSect - 1 loop
|
|---|
| 104 | resisLeft[i].R = resistivity[i + 1] * (iniSecPos[i + 1] - iniSecPos[i]) / 2.0;
|
|---|
| 105 | if i == 1 then
|
|---|
| 106 | resisRight[1].R = resistivity[1] * iniSecPos[1];
|
|---|
| 107 | else
|
|---|
| 108 | resisRight[i].R = resisLeft[i - 1].R;
|
|---|
| 109 | end if;
|
|---|
| 110 | end for;
|
|---|
| 111 | resisLeft[numOfSect].R = resistivity[numOfSect + 1] * (lineLength - iniSecPos[numOfSect]);
|
|---|
| 112 | resisRight[numOfSect].R = resisLeft[numOfSect - 1].R;
|
|---|
| 113 |
|
|---|
| 114 | // #### Correzione delle resistenze per le sezioni z_k (da implementare
|
|---|
| 115 | //Potenza perduta:
|
|---|
| 116 | algorithm
|
|---|
| 117 | lostPower := 0;
|
|---|
| 118 | for i in 1:numOfSect loop
|
|---|
| 119 | lostPower := lostPower + resisLeft[i].v * resisLeft[i].i;
|
|---|
| 120 | lostPower := lostPower + resisRight[i].v * resisRight[i].i;
|
|---|
| 121 | end for;
|
|---|
| 122 | annotation(Documentation(info="<html>
|
|---|
| 123 | <p>Modello di rete ad una linea per generazione di sistemi a semplice binario con numero variabile di treni e sottostazioni. </p>
|
|---|
| 124 | <p>A sinistra della prima sottostazione e a destra dell'ultima vi deve essere un tratto di linea, di lunghezza non nulla. La resistività della linea è la medesima per ogni tratta fra le ESS. </p>
|
|---|
| 125 | <p>L'intera linea viene divisa in <i>Sezioni</i>. Ogni sezione di linea è da due resistori in serie, un punto di contatto a SX, uno al centro, uno a DX. </p>
|
|---|
| 126 | <p>Il treno è collegato al centro, i punti a SX e a DX alle estremità di sezione. Quindi ogni sezione può contenere al più un treno. </p>
|
|---|
| 127 | <p>All'interno d'uso più naturale di questa logica è di fare in modo che le sezioni coincidano con il tratto di linea fra due sottostazioni. Se però le sottostazioni sono distanti e quindi vi possono essere due treni marcianti nel tratto fra due sottostazioni, fra di esse occorrerà mettere più sezioni. </p>
|
|---|
| 128 | <p>Essenso il caso standard costituito da confini di sezione i corrispondenza di sottostazioni, il "numOfEss" scritto come numero di dsottostazioni, è un realtà il numero di Sezioni. Qualora si volesse realizzare la rete con un numero di sezioni superiore al numero di sottostazioni reali, al corrispondente pin non si connetterà nulla. </p>
|
|---|
| 129 | <p>Inoltre vi è una mezza sezione a sinistra della prima sottostazione e a destra dell'ultima: in questi tratti l'alimentazione sarà monolatera. </p>
|
|---|
| 130 | <p>La tecnica con cui la rete è realizzata prevede la generazione all'inizio della simulazione di tutte le sezioni con resistori a resistenza variabile con resistenza funzione della posizione del treno presente al centro di sezione (o, nel solo caso dei tratti a sbalzo all'estremità di sezione). </p>
|
|---|
| 131 | <p>Il treno è connesso dinamicamente alle varie sezioni in funzione della sua posizione, attraverso ulteriori resistori che posso avere valori molto piccoli (1e-6) o molto grandi (1e6) rispettivamente per treno connesso o disconnesso.</p>
|
|---|
| 132 | </html>"), Diagram(coordinateSystem(preserveAspectRatio = false, extent = {{-160, -60}, {160, 60}}), graphics), Icon(coordinateSystem(extent = {{-160, -60}, {160, 60}}, preserveAspectRatio = false), graphics={ Rectangle(extent = {{-160, 60}, {160, -60}}, lineColor = {0, 0, 255}, fillColor = {215, 215, 215},
|
|---|
| 133 | fillPattern = FillPattern.Solid), Line(points = {{-158, 2}, {158, 2}}, color = {135, 135, 135}), Rectangle(lineColor = {135, 135, 135}, fillColor = {255, 255, 255},
|
|---|
| 134 | fillPattern = FillPattern.Solid, extent = {{-116, 8}, {-96, -2}}), Rectangle(lineColor = {135, 135, 135}, fillColor = {255, 255, 255},
|
|---|
| 135 | fillPattern = FillPattern.Solid, extent = {{-70, 8}, {-50, -2}}), Rectangle(lineColor = {135, 135, 135}, fillColor = {255, 255, 255},
|
|---|
| 136 | fillPattern = FillPattern.Solid, extent = {{50, 8}, {70, -2}}), Rectangle(lineColor = {135, 135, 135}, fillColor = {255, 255, 255},
|
|---|
| 137 | fillPattern = FillPattern.Solid, extent = {{98, 8}, {118, -2}}), Text(extent = {{-160, -12}, {158, -26}}, lineColor = {0, 0, 0}, fillColor = {255, 255, 255},
|
|---|
| 138 | fillPattern = FillPattern.Solid, textString = "%numOfTrains trains"), Text(extent = {{-160, -34}, {160, -44}}, lineColor = {0, 0, 0}, fillColor = {255, 255, 255},
|
|---|
| 139 | fillPattern = FillPattern.Solid, textString = "ESS's in %iniSecPos"), Text(extent = {{-158, 42}, {158, 24}}, lineColor = {0, 0, 255}, fillColor = {255, 255, 255},
|
|---|
| 140 | fillPattern = FillPattern.Solid, textString = "%name")}));
|
|---|
| 141 | end GridOneTrack;
|
|---|
| 142 |
|
|---|
| 143 |
|
|---|
| 144 |
|
|---|
| 145 |
|
|---|
| 146 |
|
|---|
| 147 | model gridTest21
|
|---|
| 148 |
|
|---|
| 149 | GridOneTrack gridOneTrack(
|
|---|
| 150 | iniSecPos={580,1744},
|
|---|
| 151 | lineLength=2500,
|
|---|
| 152 | resistivity={0.000108,0.000108,0.00014},
|
|---|
| 153 | numOfTrains=1)
|
|---|
| 154 | annotation (Placement(transformation(extent={{-20,-20},{80,20}})));
|
|---|
| 155 | Modelica.Blocks.Sources.Constant pos1(k = 1000) annotation(Placement(transformation(extent={{-60,-10},
|
|---|
| 156 | {-40,10}})));
|
|---|
| 157 | Modelica.Electrical.Analog.Basic.Ground ground annotation(Placement(transformation(extent={{20,-88},
|
|---|
| 158 | {40,-68}})));
|
|---|
| 159 | Modelica.Electrical.Analog.Sources.ConstantVoltage ess1(V = 100) annotation(Placement(transformation(extent = {{-10, -10}, {10, 10}}, rotation = 90, origin = {-2, 58})));
|
|---|
| 160 | Modelica.Electrical.Analog.Sources.ConstantVoltage ess2(V = 100) annotation(Placement(transformation(extent = {{-10, -10}, {10, 10}}, rotation = 90, origin = {30, 58})));
|
|---|
| 161 | Modelica.Electrical.Analog.Basic.Ground ground1 annotation(Placement(transformation(extent = {{20, 96}, {40, 76}})));
|
|---|
| 162 | Modelica.Electrical.MultiPhase.Basic.PlugToPin_p sTn1(m = 2, k = 1) annotation(Placement(transformation(extent = {{-10, -10}, {10, 10}}, rotation = 90, origin = {-2, 38})));
|
|---|
| 163 | Modelica.Electrical.MultiPhase.Basic.PlugToPin_p sTn2(m = 2, k = 2) annotation(Placement(transformation(extent = {{-10, -10}, {10, 10}}, rotation = 90, origin = {30, 38})));
|
|---|
| 164 | Modelica.Electrical.MultiPhase.Basic.PlugToPin_p tTn(m=1, k=1) annotation (
|
|---|
| 165 | Placement(visible=true, transformation(
|
|---|
| 166 | origin={30,-32},
|
|---|
| 167 | extent={{10,-10},{-10,10}},
|
|---|
| 168 | rotation=90)));
|
|---|
| 169 | Modelica.Electrical.Analog.Sources.ConstantCurrent tr1(I=100) annotation(Placement(visible = true, transformation(origin={30,-50}, extent = {{-10, -10}, {10, 10}}, rotation = -90)));
|
|---|
| 170 | equation
|
|---|
| 171 | connect(tr1.n, ground.p) annotation(Line(points={{30,-60},{30,-68}}));
|
|---|
| 172 | connect(tTn.pin_p, tr1.p)
|
|---|
| 173 | annotation (Line(points={{30,-34},{30,-38},{30,-40}}, color={0,0,255}));
|
|---|
| 174 | connect(tTn.plug_p, gridOneTrack.tp)
|
|---|
| 175 | annotation (Line(points={{30,-30},{30,-30},{30,-20}}, color={0,0,255}));
|
|---|
| 176 | connect(ground1.p, ess1.n) annotation(Line(points = {{30, 76}, {30, 68}, {-2, 68}}, color = {0, 0, 255}, smooth = Smooth.None));
|
|---|
| 177 | connect(ess2.n, ess1.n) annotation(Line(points = {{30, 68}, {-2, 68}}, color = {0, 0, 255}, smooth = Smooth.None));
|
|---|
| 178 | connect(ground1.p, ess2.n) annotation(Line(points = {{30, 76}, {30, 68}}, color = {0, 0, 255}, smooth = Smooth.None));
|
|---|
| 179 | connect(ess1.p, sTn1.pin_p) annotation(Line(points = {{-2, 48}, {-2, 40}}, color = {0, 0, 255}, smooth = Smooth.None));
|
|---|
| 180 | connect(sTn2.pin_p, ess2.p) annotation(Line(points = {{30, 40}, {30, 48}}, color = {0, 0, 255}, smooth = Smooth.None));
|
|---|
| 181 | connect(sTn2.plug_p, gridOneTrack.ep) annotation (Line(
|
|---|
| 182 | points={{30,36},{30,20}},
|
|---|
| 183 | color={0,0,255},
|
|---|
| 184 | smooth=Smooth.None));
|
|---|
| 185 | connect(sTn1.plug_p, gridOneTrack.ep) annotation (Line(
|
|---|
| 186 | points={{-2,36},{-2,28},{30,28},{30,20}},
|
|---|
| 187 | color={0,0,255},
|
|---|
| 188 | smooth=Smooth.None));
|
|---|
| 189 | connect(gridOneTrack.trainPos[1], pos1.y) annotation (Line(
|
|---|
| 190 | points={{-24.6875,0.333333},{-32,0.333333},{-32,0},{-39,0}},
|
|---|
| 191 | color={0,0,127},
|
|---|
| 192 | smooth=Smooth.None));
|
|---|
| 193 | annotation(Diagram(coordinateSystem(preserveAspectRatio=false, extent={{-100,
|
|---|
| 194 | -100},{100,100}}), graphics));
|
|---|
| 195 | end gridTest21;
|
|---|
| 196 | annotation(Icon(coordinateSystem(extent = {{-100, -100}, {100, 100}}, preserveAspectRatio = true, initialScale = 0.1, grid = {2, 1})), Diagram(coordinateSystem(extent = {{-100, -100}, {100, 100}}, preserveAspectRatio = true, initialScale = 0.1, grid = {2, 2})), uses(Modelica(version = "3.2.1")));
|
|---|
| 197 | end AutoCreateBug;
|
|---|