Parent: [3445a0] (diff)

Download this file

FMatEA.def    446 lines (389 with data), 26.0 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
DEFINITION MODULE FMatEA;
(*------------------------------------------------------------------------*)
(* Routinen zur Ein- Ausgabe von Vektoren und Matrizen. *)
(* Routines for input and output of Vectors and matrices. *)
(*------------------------------------------------------------------------*)
(* Implementation : Michael Riedl *)
(* Licence : GNU Lesser General Public License (LGPL) *)
(*------------------------------------------------------------------------*)
(* $Id: FMatEA.def,v 1.7 2017/10/01 07:45:04 mriedl Exp mriedl $ *)
FROM Deklera IMPORT PMATRIX;
FROM FileSystem IMPORT File;
PROCEDURE LesePaare(VAR Ein : File;
VAR X,Y : ARRAY OF LONGREAL;
VAR dim : CARDINAL); (* Anzahl der Datenpaare *)
(*----------------------------------------------------------------*)
(* Lie\3t von der Datei Ein solange Datenpaare X_i,X_i, bis das *)
(* Dateiende erreicht ist. *)
(*----------------------------------------------------------------*)
PROCEDURE LeseMat(VAR Ein : File;
VAR Mat : ARRAY OF ARRAY OF LONGREAL;
VAR dim : CARDINAL);
(*----------------------------------------------------------------*)
(* Einlesen einer Matrix im einfachen Format *)
(* *)
(* 1.1 1.2 1.3 *)
(* 2.1 2.2 2.3 *)
(* 3.1 3.2 3.3 *)
(*----------------------------------------------------------------*)
PROCEDURE LeseSV(VAR Ein : File;
VAR SV : ARRAY OF LONGREAL; (* SUPERVEKTOR *)
VAR dim : CARDINAL);
(*----------------------------------------------------------------*)
(* Einlesen eines Supervektors im einfachen Format *)
(* *)
(* 1.0 *)
(* 2.0 3.0 *)
(* 4.0 4.0 6.0 *)
(*----------------------------------------------------------------*)
PROCEDURE LeseMatAus(VAR Ein : File;
VAR Mat : ARRAY OF ARRAY OF LONGREAL;
dim : CARDINAL; (* Dimension der Matrix *)
Spalten : CARDINAL; (* Vektorenanzahl je Block *)
VekAnz : CARDINAL); (* Anzahl der Vektoren *)
(*----------------------------------------------------------------*)
(* Lie\3t eine mit der Routine MATaus geschriebene Matrix von der *)
(* Datei Ein. *)
(*----------------------------------------------------------------*)
PROCEDURE Ausgabe(VAR Aus : File;
VAR VEK : ARRAY OF LONGREAL;
Kurzname : ARRAY OF CHAR;
Name : ARRAY OF CHAR;
dim : CARDINAL;
FeldBr : CARDINAL;
Form : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt den Vektor VEK auf die Datei Aus in der Feldbreite *)
(* Breite. Wenn Form = 1 in E-Format, sonst in F-FormatE aus. Der *)
(* Name wird dabei als "Uberschrift ausgegeben und Kurzname bei *)
(* jedem einzelen Vektorelement. *)
(*----------------------------------------------------------------*)
PROCEDURE CAusgabe(VAR Aus : File;
VAR VEK : ARRAY OF LONGCOMPLEX;
Kurzname : ARRAY OF CHAR;
Name : ARRAY OF CHAR;
dim : CARDINAL;
Breite : CARDINAL;
Form : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt den komplexen Vektor VEK auf die Datei Aus in der *)
(* Feldbreite Breite. Wenn Form = 1 in E-Format, sonst in *)
(* F-FormatE aus. Der Name wird dabei als Ueberschrift ausgegeben *)
(* und Kurzname bei jedem einzelen Vektorelement. *)
(*----------------------------------------------------------------*)
PROCEDURE MATein(VAR Ein : File;
VAR MAT : ARRAY OF ARRAY OF LONGREAL; (* Einzules. MATRIX *)
VAR Name : ARRAY OF CHAR;
VAR dim : CARDINAL; (* dim : Dimension der MATRIX *)
VAR halt : CARDINAL;
sym : CARDINAL);
(*----------------------------------------------------------------*)
(* Lie\3t eine quadratische Matrix MAT von Ein *)
(* *)
(* 1.Zeile : Kommentar ==> Name *)
(* 2.Zeile : Dimension der Matrix ==> dim *)
(* 3.Zeile : Indices von MAT(I,J) , Wert von MAT(I,J) *)
(* IND = 0, wenn keine weitren Matrixelemnte, *)
(* sonst 1 *)
(* halt : Gibt an rufendes Programm zur"uck,ob noch *)
(* Datens"atze auf Ein vorhanden sind. *)
(* halt = 0 : Keine weiteren Daten. *)
(* halt = 1 : Weiteren Daten vorhanden. *)
(* sym = 1 : Symmetrische Matrix MAT(I,J) = MAT(J,I) *)
(* sym = 0 : Matrix wie in Ein angegeben. *)
(* Beispiel: NAME *)
(* 3 *)
(* 1 1 1.0 1 1 0 0 *)
(* 2 2 1.0 1 ergibt 0 1 0 in LONGREAL-Form *)
(* 3 1 1.0 1 1 0 2 *)
(* 3 3 2.0 0 *)
(* 0 *)
(* *)
(* Die im Fehlerfalle gemeldete Eingabedateizeile, in der *)
(* der gemeldete Fehler liegen soll, ist nicht immer korrekt. *)
(* Werden auf verschiedenen Kan"alen gleichzeitig Matritzen *)
(* eingelesen, sind diese Zeilennummern sicher falsch. *)
(* Gleiches gilt f"ur die Prozeduren CMATein,SVein und CSVein. *)
(*----------------------------------------------------------------*)
PROCEDURE AsymMatEin(VAR Ein : File;
VAR Mat : ARRAY OF ARRAY OF LONGREAL;
VAR Name : ARRAY OF CHAR;
VAR M : CARDINAL; (* dim : Dimension der MATRIX *)
VAR N : CARDINAL;
trp : BOOLEAN;
VAR halt : CARDINAL);
(*----------------------------------------------------------------*)
(* Lie\3t eine nicht-quadratische Matrix MAT von Ein *)
(* *)
(* Parameter: *)
(* *)
(* trp : Wenn wahr wird Mat wird transponiert eingelesen *)
(* M : Anzahl der Vektoren in Mat *)
(* N : Laenge eines Vektors in Mat *)
(* *)
(* Andere Parameter wie in Prouzedur MATein *)
(*----------------------------------------------------------------*)
PROCEDURE PMatEin(VAR Ein : File;
VAR Mat : PMATRIX;
VAR Name : ARRAY OF CHAR;
VAR M : CARDINAL;
VAR N : CARDINAL;
VAR halt : CARDINAL;
alloc : BOOLEAN);
(*----------------------------------------------------------------*)
(* Parameter: *)
(* *)
(* M : Anzahl der Vektoren in Mat *)
(* N : Laenge eines Vektors in Mat *)
(* alloc : Wenn TRUE allokiert die Routine den Speicher f��r *)
(* die Matrix Mat. Ansonsten muss vorher ausreichend *)
(* Speicherplatz allokiert worden sein. Es finded *)
(* (noch) keine Ueberpruefung statt. *)
(* *)
(* Andere Parameter wie in Prouzedur MATein *)
(*----------------------------------------------------------------*)
PROCEDURE CMATein(VAR Ein : File;
VAR CMAT : ARRAY OF ARRAY OF LONGCOMPLEX; (* Einzules. *)
VAR Name : ARRAY OF CHAR;
VAR dim : CARDINAL; (* dim : Dimension der CMATRIX *)
VAR halt : CARDINAL;
sym : CARDINAL);
(*----------------------------------------------------------------*)
(* Lie\3t eine quadratische komplexe Matrix CMAT von Ein *)
(* *)
(* 1.Zeile : Kommentar ==> Name *)
(* 2.Zeile : Dimension der Matrix ==> dim *)
(* 3.Zeile : Indices von MAT(I,J) , Wert von CMAT(I,J) *)
(* IND = 0, wenn keine weitren Matrixelemnte, *)
(* sonst 1 *)
(* halt : Gibt an rufendes Programm zur"uck,ob noch *)
(* Datens"atze auf Ein vorhanden sind. *)
(* halt = 0 : Keine weiteren Daten. *)
(* halt = 1 : Weiteren Daten vorhanden. *)
(* sym = 1 : Hermitische Matrix CMAT(I,J) = CMAT(J,I)^* *)
(* sym = 0 : Matrix wie in Ein angegeben. *)
(* Beispiel: NAME *)
(* 3 *)
(* 1 1 1.0 0.0 1 *)
(* 2 2 1.0 3.0 1 *)
(* 3 1 1.0 1.0 1 *)
(* 3 3 2.0 -1.0 0 *)
(* 0 *)
(*----------------------------------------------------------------*)
PROCEDURE SVein(VAR Ein : File;
VAR SV : ARRAY OF LONGREAL; (* Einzules. SUPERVEKTOR *)
VAR Name : ARRAY OF CHAR;
VAR dim : CARDINAL; (* dim : Dimension der MATRIX *)
VAR halt : CARDINAL);
(*----------------------------------------------------------------*)
(* Kommentare siehe MATein, es wird jedoch nur eine gepackte *)
(* symmetrische Matrix eingelesen, daher kein Parameter sym. *)
(*----------------------------------------------------------------*)
PROCEDURE CSVein(VAR Ein : File;
VAR CSV : ARRAY OF LONGCOMPLEX; (* Einzules. SUPERVEKTOR *)
VAR Name : ARRAY OF CHAR;
VAR dim : CARDINAL; (* dim : Dimension der MATRIX *)
VAR halt : CARDINAL);
(*----------------------------------------------------------------*)
(* Kommentare siehe CMATein, es wird jedoch nur eine gepackte *)
(* hermitische Matrix eingelesen, daher kein Parameter sym. *)
(*----------------------------------------------------------------*)
PROCEDURE WrMatAus(VAR Aus : File;
VAR A : ARRAY OF ARRAY OF LONGREAL;
Name : ARRAY OF CHAR;
M,N : CARDINAL;
halt : CARDINAL;
eps : LONGREAL);
(*----------------------------------------------------------------*)
(* Schreibt die Matrix A auf Aus *)
(* Routine ist komplementa"ar zu Prozedur MatEin *)
(* *)
(* 1.Zeile : Kommentar ==> Name *)
(* 2.Zeile : Dimension der Matrix ==> M N *)
(* 3.Zeile : Indizes von Mat(i,j), Wert von Mat(i,j) & Indikator *)
(* ind = 0, wenn keine weiteren Matrixelemente kommen, *)
(* sonst 1 *)
(* halt = 0 : Keine weiteren Daten *)
(* halt = 1 : Weiteren Daten vorhanden die in einem n"achsten *)
(* Auf-uf geschrieben werden sollen *)
(* eps : Matrixelemente kleiner als eps werden nicht ausge- *)
(* schrieben *)
(* Siehe auch Kommentare bei MatEin *)
(*----------------------------------------------------------------*)
PROCEDURE VEKaus(VAR Aus : File;
dim : CARDINAL;
Name : ARRAY OF CHAR;
VAR Vek : ARRAY OF LONGREAL;
Breite : CARDINAL;
FeldBr : CARDINAL;
Form : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt den Vektor Vek auf Aus. *)
(* *)
(* Name : Name des Vektor etc. *)
(* Breite : Gesamtbeite des Ausdrucks *)
(* Feldbr : Feldbreite eines Vektorelements *)
(* Form = 1 : E-Format. *)
(* Form = 2 : Flie\3kommadarstellung. *)
(*----------------------------------------------------------------*)
PROCEDURE CVEKaus(VAR Aus : File;
dim : CARDINAL;
Name : ARRAY OF CHAR;
VAR Vek : ARRAY OF LONGCOMPLEX;
Breite : CARDINAL;
FeldBr : CARDINAL;
Form : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt den komplexen Vektor Vek auf Aus. *)
(* Erklaerungen bei VEKaus *)
(*----------------------------------------------------------------*)
PROCEDURE MATaus(VAR Aus : File;
M,N : CARDINAL; (* Dimension der MATRIX *)
VAR Mat : ARRAY OF ARRAY OF LONGREAL;
GesamtBr : CARDINAL; (* Breite des Ausdrucks *)
FeldBr : CARDINAL; (* Feldbreite einer Komponente *)
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt die Matrix MAT auf Aus. *)
(* Format = 1 : E-Format. *)
(* Format = 2 : Flie\3kommadarstellung. *)
(* Format = 3 : Flie\3kommadarstellung bei der 0 als 0.0{ } *)
(* statt 0.0{0} dargestellt wird *)
(* M : Anzahl der auszuschreibenden Vektoren *)
(* N : Laenges einses Vektors *)
(* Dimensionen von sind also Mat[0..M-1,0..dim-1] *)
(*----------------------------------------------------------------*)
PROCEDURE PMATaus(VAR Aus : File;
M : CARDINAL; (* Anzahl der Vektoren *)
N : CARDINAL; (* L"ange der Vektoren *)
VAR Mat : PMATRIX;
GesamtBr : CARDINAL; (* Breite des Ausdrucks *)
FeldBr : CARDINAL; (* Feldbreite einer Komponente *)
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Uebergabeparameter wie f"ur MATaus *)
(*----------------------------------------------------------------*)
PROCEDURE CMATaus(VAR Aus : File;
M : CARDINAL; (* Anzahl der Vektoren *)
N : CARDINAL; (* Laenge eines Vektors *)
VAR CMat : ARRAY OF ARRAY OF LONGCOMPLEX;
GesamtBr : CARDINAL; (* Breite des Ausdrucks *)
FeldBr : CARDINAL; (* Feldbreite einer Komponente *)
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt die Matrix MAT auf Aus. *)
(* Format = 1 : E-Format. *)
(* Format = 2 : Flie\3kommadarstellung. *)
(* maxVek : Anzahl der auszugebenden Spaltenvektoren. *)
(*----------------------------------------------------------------*)
PROCEDURE SVaus(VAR Aus : File;
dim : CARDINAL; (* Dimension des SUPERVEKTOR *)
maxVek : CARDINAL;
VAR SV : ARRAY OF LONGREAL; (* SUPERVEKTOR *)
GesamtBr : CARDINAL; (* Breite des Ausdrucks *)
FeldBr : CARDINAL; (* Feldbreite einer Komponente *)
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt den Supervektor SV auf Aus. *)
(* Format = 1 : E-Format. *)
(* Format = 2 : Flie\3kommadarstellung. *)
(* maxVek : Anzahl der auszugebenden Spaltenvektoren von SV *)
(*----------------------------------------------------------------*)
PROCEDURE CSVaus(VAR Aus : File;
dim : CARDINAL; (* Dimension des SUPERVEKTOR *)
maxVek : CARDINAL;
VAR CSV : ARRAY OF LONGCOMPLEX; (* SUPERVEKTOR *)
GesamtBr : CARDINAL; (* Breite des Ausdrucks *)
FeldBr : CARDINAL; (* Feldbreite einer Komponente *)
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt den Supervektor CSV auf Aus. *)
(* Format = 1 : E-Format. *)
(* Format = 2 : Flie\3kommadarstellung. *)
(* Format = 3 : Siehe MATaus *)
(* maxVek : Anzahl d. auszugebenden Spaltenvektoren von CSV *)
(*----------------------------------------------------------------*)
PROCEDURE MatVekAus(VAR Aus : File;
M,N : CARDINAL;
VAR Vek : ARRAY OF LONGREAL;
VAR Mat : ARRAY OF ARRAY OF LONGREAL;
GesamtBr : CARDINAL;
FeldBr : CARDINAL;
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt die Mat und den Vektor Vek auf Aus. *)
(* Format = 1 : E-Format. *)
(* Format = 2 : Flie\3kommadarstellung. *)
(* Format = 3 : Flie\3kommadarstellung bei der 0 als 0.0{ } *)
(* statt 0.0{0} dargestellt wird *)
(* M : Anzahl der auszuschreibenden Vektoren *)
(* N : Laenges einses Vektors *)
(* Dimensionen von sind also Mat[0..M-1,0..N-1] *)
(*----------------------------------------------------------------*)
PROCEDURE PMatVekAus(VAR Aus : File;
M,N : CARDINAL;
VAR Vek : ARRAY OF LONGREAL;
VAR Mat : PMATRIX;
GesamtBr : CARDINAL;
FeldBr : CARDINAL;
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt die Mat und den Vektor Vek auf Aus. *)
(* Format = 1 : E-Format. *)
(* Format = 2 : Flie\3kommadarstellung. *)
(* M : Anzahl d. auszugebenden Spaltenvektoren von Mat *)
(*----------------------------------------------------------------*)
PROCEDURE CMatVekAus(VAR Aus : File;
N : CARDINAL;
M : CARDINAL;
VAR CVek : ARRAY OF LONGCOMPLEX;
VAR CMat : ARRAY OF ARRAY OF LONGCOMPLEX;
GesamtBr : CARDINAL;
FeldBr : CARDINAL;
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt die komplexe Matrix CMat und den komplexen Vektor *)
(* CVek auf Aus. *)
(* Format = 1 : E-Format. *)
(* Format = 2 : Flie\3kommadarstellung. *)
(* M : Anzahl d. auszugebenden Spaltenvektoren von CMat *)
(*----------------------------------------------------------------*)
PROCEDURE MVKaus(VAR Aus : File;
N : CARDINAL;
M : CARDINAL;
VAR Komm : ARRAY OF ARRAY OF CHAR;
VAR Vek : ARRAY OF LONGREAL;
VAR Mat : ARRAY OF ARRAY OF LONGREAL;
GesamtBr : CARDINAL;
FeldBr : CARDINAL;
Format : CARDINAL);
(*----------------------------------------------------------------*)
(* Schreibt die Matrix Mat sowie den Vektor Vek auf Aus. *)
(* Dabei wird jeder Zeile von Mat der Kommentar Komm[i] vor- *)
(* angestellt und "uber jeder Zeile von Mat das entsprechende *)
(* Element von Vek. *)
(* Formatanweisungen wie in MATaus. *)
(*----------------------------------------------------------------*)
PROCEDURE SVKaus(VAR Aus : File;
M,N : CARDINAL;
VAR SV : ARRAY OF LONGREAL; (* SUPERVEKTOR *)
VAR Komm : ARRAY OF ARRAY OF CHAR;
GesamtBr : CARDINAL;
FeldBr : CARDINAL;
Format : CARDINAL;
quad : BOOLEAN);
(*----------------------------------------------------------------*)
(* Wie Routine SVaus, allerdings werden die Zeilen und Spalten *)
(* zus"atzlich zu den Nummern durch die Eintr"age in dem Feld *)
(* Komm beschriftet. Dabei wird davon ausgegangen, das die *)
(* Kommentarfelder nicht l"anger als 5 Zeichen sind, anderenfalls *)
(* ist die Ausgabe nicht sauber formatiert. *)
(*----------------------------------------------------------------*)
PROCEDURE WrMatConst( Aus : File;
M,N : CARDINAL;
VAR A : ARRAY OF ARRAY OF LONGREAL);
(*----------------------------------------------------------------*)
(* Schreibe eine kleine Matrix so aus dass sie im Quelltext als *)
(* Konstante eingebunden werden kann. *)
(*----------------------------------------------------------------*)
END FMatEA.