Ticket #2756: AutoCreateBug.mo

File AutoCreateBug.mo, 13.7 KB (added by ceraolo, 10 years ago)
Line 
1within ;
2package 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&apos;ultima vi deve essere un tratto di linea, di lunghezza non nulla. La resistivit&agrave; della linea &egrave; la medesima per ogni tratta fra le ESS. </p>
125<p>L&apos;intera linea viene divisa in <i>Sezioni</i>. Ogni sezione di linea &egrave; da due resistori in serie, un punto di contatto a SX, uno al centro, uno a DX. </p>
126<p>Il treno &egrave; collegato al centro, i punti a SX e a DX alle estremit&agrave; di sezione. Quindi ogni sezione pu&ograve; contenere al pi&ugrave; un treno. </p>
127<p>All&apos;interno d&apos;uso pi&ugrave; naturale di questa logica &egrave; di fare in modo che le sezioni coincidano con il tratto di linea fra due sottostazioni. Se per&ograve; le sottostazioni sono distanti e quindi vi possono essere due treni marcianti nel tratto fra due sottostazioni, fra di esse occorrer&agrave; mettere pi&ugrave; sezioni. </p>
128<p>Essenso il caso standard costituito da confini di sezione i corrispondenza di sottostazioni, il &QUOT;numOfEss&QUOT; scritto come numero di dsottostazioni, &egrave; un realt&agrave; 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&agrave; nulla. </p>
129<p>Inoltre vi &egrave; una mezza sezione a sinistra della prima sottostazione e a destra dell&apos;ultima: in questi tratti l&apos;alimentazione sar&agrave; monolatera. </p>
130<p>La tecnica con cui la rete &egrave; realizzata prevede la generazione all&apos;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&apos;estremit&agrave; di sezione). </p>
131<p>Il treno &egrave; 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")));
197end AutoCreateBug;