<
From version < 9.1 >
edited by cbu
on 2014/05/12 21:16
To version < 11.1 >
edited by cbu
on 2014/05/12 21:26
>
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -13,7 +13,7 @@
13 13  Remember, you are going to present your controller at the end of the summer term! Getting this task done right is a very important step to succeed with your controller and this project!
14 14  {{/info}}
15 15  
16 -
16 +== **Goals** ==
17 17  
18 18  **The following goals should definitely be reached (if we get modules in Kieler):**
19 19  
... ... @@ -32,8 +32,11 @@
32 32  Trains should drive slowly at the points
33 33  )))
34 34  
35 -**Road Map:**
35 +== **Road Map:** ==
36 36  
37 +**
38 +**
39 +
37 37  {{code}}
38 38  13.5. Presentation
39 39  27.5. Station-Station Controller + C-Interface
... ... @@ -48,16 +48,49 @@
48 48  **
49 49  **
50 50  
51 -**Work distribution: **
54 +=== **Current work distribution: ** ===
52 52  
53 -**
54 -**
56 +|=(((
57 +Task
58 +)))|=(((
59 +Assigned Persons
60 +)))
61 +|(((
62 +C-Inteface
63 +)))|(((
64 +Alexander
65 +)))
66 +|(((
67 +Mutual Exclusion
68 +)))|(((
69 +Nis
70 +)))
71 +|(((
72 +Station-to-Station
73 +)))|(((
74 +Personal assignments
75 +)))
76 +|(((
77 +Test Scenarios
78 +)))|(((
79 +Expert-groups
80 +)))
81 +|(((
82 +Deadlocks
83 +)))|(((
84 +Carsten
85 +)))
86 +|(((
87 +Integration
88 +)))|(((
89 +Small groups, dynamic time schedule
90 +)))
55 55  
56 -**Implementation in short:**
92 +== **Implementation in short:** ==
57 57  
58 58  The main idea is, that we have a universal model of the track segments. From these single track segments, track sections, that connect train stations are modeled and from those track sections, all final schedules for the trains should be build. On each track segment, there should be at most one train: In order to drive over a track, a train must request this track, and afterwards it must free it again (details below). If two trains request the same track section, the priority, which is derived from the train number, decides, which train gets the track section. A train must request all tracks until the next possibility to stop an wait in order to avoid collisions. If the train does not get all track segments, it must free them again in order to avoid deadlocks or delays of other trains. Deadlocks might occur at the exists of all train stations, and additionally, if one train with a low priority exists the Kicking-Horse-path while another train with a higher priority sends an entry-request. It remains to be seen, if additional deadlocks occur. Deadlocks can be resolved by using a superior Mutex-Controller.
59 59  
60 -=== **Implementation in detail:** ===
96 +== **Implementation in detail:** ==
61 61  
62 62  **Basic Track:**
63 63  
... ... @@ -102,10 +102,10 @@
102 102  
103 103  [[image:attach:csp_default_pass.png]]
104 104  
105 -=== Station-Station Modules ===
141 +**Station-Station Modules**
106 106  
107 -Input: Zugnummer, Startgleis, Zielgleis, Cleanup, (Mutex Variablen?)
108 -Output: "Echtes" Zielgleis (Ausweichgleis?)
143 +Input: train number, departure track, destination track, Cleanup flag, (mutex variables necessary?)
144 +Output: "real" destination track (alternative destination track)
109 109  
110 110  Modules needed:
111 111  
... ... @@ -126,9 +126,9 @@
126 126  
127 127  === [[image:attach:nbw-mutex-sct.png]] ===
128 128  
129 -=== C-Interface ===
165 +**C-Interface**
130 130  
131 -The C-Interface wraps some general functions, in order to prevent long and ugly host-code statements within the SCCharts. It especially hides the railway pointer. In addition, the C-Interface provides a persistent environment during a macro step.
167 +The C-Interface wraps some general functions, in order to prevent long and ugly host-code statements within the SCCharts. It especially hides the railway pointer. In addition, the C-Interface provides a persistent environment during a macro step. To bring in some randomness, the time, which a train has to wait in a station, is controlled by the C-Interface. Therefore, trains have to notify the interface about their arrival and their departure.
132 132  
133 133  
134 134  
... ... @@ -144,7 +144,7 @@
144 144  
145 145  
146 146  
147 -== Organization ==
183 +== **Organization** ==
148 148  
149 149  Meetings: Every Wednesday at 4 pm.
150 150  
Confluence.Code.ConfluencePageClass[0]
Id
... ... @@ -1,1 +1,1 @@
1 -9470776
1 +9470780
URL
... ... @@ -1,1 +1,1 @@
1 -https://rtsys.informatik.uni-kiel.de/confluence//wiki/spaces/SS14Railway/pages/9470776/Project goals
1 +https://rtsys.informatik.uni-kiel.de/confluence//wiki/spaces/SS14Railway/pages/9470780/Project goals