chiark / gitweb /
undo broken deletion
[trains.git] / layout / parts.i4
1 define(`def_thing_l_r',`
2 dnl OBJNAME-EXCLUDING-L
3  defpart $1r
4   abs c 200 200 0
5   objflip $1l c c =
6  enddef
7 ')
8
9 # Conventionally, points' toes are c, the straight through is a
10 # and the curve is b.  Segments run from c towards a and b.
11 #
12 # Crossings (including slips) run `vertically' and have
13 # tl, tr, bl, br.  Segments run from b* to t*.
14
15 define(`def_point_ord',`
16 dnl OBJNAME-EXCLUDING-PT-L ANGLE STRAIGHT-L CURVE-LONGER CURVE-DIVERGE-Y MIN-R
17  defpart pt_$1l
18   abs c 200 200 0
19   segment /P0
20   extend c a len $3
21   rel a b $4 -$5 $2
22   segment /P1
23   join c b $6
24  enddef
25  def_thing_l_r(`pt_$1')
26 ')
27
28 define(`def_point_curve',`
29 dnl OBJNAME-EXCLUDING-PT-L TIGHT-ANG TIGHT-RECT TIGHT-DIVERGE-Y SHALLOW.. MIN-R START-OFFSET-ANG
30  defpart pt_$1l
31   abs c 200 200 0
32   layer s
33   rel c cbase 0 0 $9
34   layer =
35   rel cbase a $6 -$7 $5
36   rel cbase b $3 -$4 $2
37   segment /P0
38   join c a $8
39   segment /P1
40   join c b $8
41  enddef
42  def_thing_l_r(`pt_$1')
43 ')
44
45 define(`def_point_y',`
46 dnl OBJNAME-EXCLUDING-PT HALF-ANG RECT HALF-DIVERGE-Y MIN-R
47  defpart pt_$1
48   abs c 200 200 0
49   rel c l $3 -$4  $2
50   rel c r $3  $4 -$2
51   segment /P0
52   join c l $5
53   segment /P1
54   join c r $5
55  enddef
56 ')
57
58 define(`def_crossing',`
59 dnl OBJNAME-EXCLUDING-CROSS HALF-ANG HALF-LENGTH
60  defpart cross_$1
61   abs m 200 200 0
62   rel m ml 0 0 $2
63   rel m mr 0 0 -$2
64   segment F
65   extend mr tr len $3
66   extend mr bl len -$3
67   segment B
68   extend ml tl len $3
69   extend ml br len -$3
70  enddef
71 ')
72
73 def_point_ord(`peco_s', 22.5, 87,  -0.5, 17,    200) #ST-5,6     not minr 230 ?
74 def_point_ord(`peco_m', 14,  126.5,-1.55,13.21, 315) #SL-395,396 not minr 457 ?
75 def_point_ord(`peco_l',  8,  160,  -0.4, 13.21, 914) #SL-388,389
76  # catalogue says 123.7 for STRAIGHT-L ?!
77  # SL-<n> and SL-E<n> have the same geometry
78
79 def_point_ord(`pecofguess_l',  10,  160,  -1.0, 13.21, 800) #SLE-388F,389F
80  # not minr 914 ?
81  # 36 sleepers just like 36
82  # has 5.2mm gauge, 8.15mm rails offset:
83  # unlike 4.9mm gauge, 7.15mm rails offset: 
84  # SL-<n>F and SL-<n> do NOT have the same geometry
85
86 def_point_curve(`peco_c', 11, 154.5, 14.0,  2, 156.4, 0.4, 457, 1) #SL-386,387
87
88 def_point_y(`peco_y', 8, 124.2, 7.9, 800) # not minr 762 ?
89
90 #def_crossing(`mythical',7,   80)
91 def_crossing(`peco_l',  4,   93.75) # SL-394
92 def_crossing(`peco_s', 12.5, 46)    # ST-7
93 def_crossing(`pecof_s', 10,  51.85) # SL-E391F,E392F
94 def_crossing(`pecof_l',  5,  77.00) # SL-E394F
95
96
97 def_crossing(`atlas_15',   7.5, 64)
98 def_crossing(`atlas_15m',  7.5, 61)
99 def_crossing(`atlas_90',  45,   62.4)
100 def_crossing(`atlas_90m', 45,    8.5)
101 def_crossing(`atlas_30',  15,   32.9)
102 def_crossing(`atlas_30m', 15,   30.9)
103 def_crossing(`atlas_60',  30,   48.5)
104 def_crossing(`atlas_60m', 30,   14.5)
105 def_crossing(`atlas_20',  10,   63.5)
106 def_crossing(`atlas_20m', 10,   46.0)
107 def_crossing(`atlas_45',  22.5, 50.9)
108 def_crossing(`atlas_45m', 22.5, 19.5)
109
110 define(`def_point_shino',`
111 dnl OBJNAME-EXCLUDING-PT-L($1) A($2) B($3) Q($4)
112 dnl not R($5)
113  defpart pt_$1l
114   abs c 200 200 0
115   layer s
116   rel c strintersect $3 0 $4
117   rel strintersect strbackanal -$3
118   layer =
119   rel strbackanal b $2
120   segment /P1
121   join c b 240 arcline
122   segment /P0
123   extend c a len $2
124  enddef
125  def_thing_l_r(`pt_$1')
126 ')
127
128 def_point_shino(`shino_4', 136, 45, 14.25)
129 def_point_shino(`shino_6', 177, 49,  9.50)
130 def_point_y(`shino_y', 7.125, 140, 10.9, 750) # not minr 500 ?
131
132 defpart pt_shino_x3
133   abs c 200 200 0
134   layer s
135   rel c strintersectc  74 0   9.5
136   rel c strintersectb 103 0 -12
137   layer =
138   rel strintersectc l 141
139   rel strintersectb r 112
140   segment /P1
141   extend c m len 215
142   segment /P0
143   join c l 315 arcline
144   segment /P2
145   join c r 315 arcline
146 enddef
147
148 define(`def_slip2',`
149 dnl OBJNAME-EXCLUDING-SLIP2 HALF-LEN HALF-ANG
150  defpart slip2_$1
151   # configurations:  bl-tl 0  bl-tr 1  br-tl 2  br-tr 3
152   abs m 200 200 0
153   rel m ml 0 0  $3
154   rel m mr 0 0 -$3
155   segment /S2
156   extend ml tl len $2
157   segment -/S2
158   extend ml br len -$2
159   segment /S1
160   extend mr tr len $2
161   segment -/S1
162   extend mr bl len -$2
163   segment /S0
164   join bl tl 500
165   segment /S3
166   join br tr 500
167  enddef
168 ')
169
170 def_slip2(`shino', 114, 4.75)
171 def_slip2(`pecof',  77, 5.00)
172
173 define(`def_scis',`
174 dnl OBJNAME-EXCLUDING-SCIS HALF-LENGTH HALF-SPACING HALF-ANG MIN-R
175  defpart scis_$1
176   abs bl 200 200 0
177   rel bl m $2 $3
178   rel m br -$2 $3
179   extend bl ml len $2
180   extend ml tl len $2
181   extend br mr len $2
182   extend mr tr len $2
183   layer s
184   rel m mxl 0 0 $4
185   rel m mxr 0 0 -$4
186   layer =
187   join bl mxr $5
188   join mxr tr $5
189   join br mxl $5
190   join mxl tl $5
191  enddef
192 ')
193
194 def_scis(`pecof', 135.42, 13.5,  10, 315)
195 def_scis(`shino', 154,    13.5, 9.5, 315)
196
197 define(`tt_do_circle',`
198  layer s
199  rel mid forcirc0$2 0 $1 0
200  rel mid forcirc1$2 0 -$1 180
201  layer l
202  join forcirc0$2 forcirc1$2 0
203  join forcirc1$2 forcirc0$2 0
204  layer =
205 ')
206
207 defpart tt_peco
208  layer =
209  abs mid 200 200 0
210  extend mid out len 80
211  extend -mid -in len 80
212
213  tt_do_circle(80, `')
214 enddef
215
216 define(`tt_atlas_out',`
217  layer s
218  rel mid mid$1 0 0 $1
219  layer =
220  rel mid$1 out$1 109 0
221 ')
222
223 defpart tt_atlas
224  layer =
225  abs mid 200 200 0
226  extend mid out len 109
227  extend -mid -in len 109
228
229  tt_atlas_out(`0')
230  tt_atlas_out(`15')
231  tt_atlas_out(`30')
232  tt_atlas_out(`45')
233  tt_atlas_out(`60')
234  tt_atlas_out(`75')
235  tt_atlas_out(`90')
236  tt_atlas_out(`105')
237  tt_atlas_out(`120')
238  tt_atlas_out(`135')
239  tt_atlas_out(`150')
240  tt_atlas_out(`165')
241  tt_atlas_out(`180')
242  tt_atlas_out(`195')
243  tt_atlas_out(`210')
244  tt_atlas_out(`225')
245  tt_atlas_out(`240')
246  tt_atlas_out(`255')
247  tt_atlas_out(`270')
248  tt_atlas_out(`285')
249  tt_atlas_out(`300')
250  tt_atlas_out(`315')
251  tt_atlas_out(`330')
252  tt_atlas_out(`345')
253
254  tt_do_circle(95.25, i)
255  tt_do_circle(109, `')
256 enddef
257
258 defpart tt_atlas_motor
259  abs cout 200 200 0
260  layer p
261  rel cout bl -40 -40
262  rel cout br -40  40
263  extend bl tl len 89
264  extend br tr len 89
265  join tl -tr 0.1
266 enddef
267
268 ident $Revision$
269