; ; ABSTANDSTREUER KEGELENTWURF IN NORMALER (POLARER) LAGE MIT SÜDPOL ALS PUNKT ; =========================================================================== ; ; Nr. bei Wagner: 1a ; Name: Abstandstreuer Kegelentwurf mit dem Südpol als Punkt ; Variante: Polversetzend ; Autor: ; Quelle: Karlheinz Wagner, Kartographische Netzentwürfe, Leipzig 1949, S. 34ff. ; Richtung: Inverse Transformation ; Hemisphäre: Das Programm bildet immer, auch bei nördlichem Berührungspunkt, den Südpol als Punkt ab. ; Die Codeunterschiede zur Nordpolversion sind mit **) gekennzeichnet. ; ; Literatur: ; Wagner: Kartographische Netzentwürfe, Leipzig: Bibliographisches Institut 1949 ; Fiala: Mathematische Kartographie, Berlin: Verlag Technik 1957 ; (C) Rolf Böhm Bad Schandau 2004 ; Polversetzend/Zentrierend: Bei Kegelentwürfen ist das Rechenzentrum (der Pol) meist ; nicht der Kartenmittelpunkt. Dies ist ein polversetzendes Programm, d. h. man kann/muss eine ; Distanz angeben, um die der Pol nach N versetzt wird. Das Gegenstück bilden die zentrierenden ; Kegelentwurfsprogramme, die Pol so versetzen, dass der Mitte der Quellkarte zur Mitte der Zielkarte wird. ; Benutzte Variablen ; ================== ; ; Die Variablennamen entsprechen weitgehend denen von Karlheinz Wagner, ; ; Laufende Koordinaten ; _name Abstandstreuer~Kegelentwurf~mit~Südpol~als~Punkt~(polversetzend) _var phi ; Geographische Breite _var lambda ; Geographische Länge _var alpha ; Azimut ebene Polarkoord., auch Schiefazimut _var delta ; Poldistanz/geographisch, auch Schiefdistanz _var m ; Radius ebene Polarkoordinaten _var n ; Winkelreduktionsfaktor (Cos(Delta0)) ; ; Konstanten der Transformation ; _var phi0 ; Geogr. Breite des Berührungsparallels _var delta0 ; Poldistanz des Berührungsparallels _var tand0 ; dessen Tangens _var pi-co ; Konstante Pi/4-Delta0 + Tan(Delta0) _var lambda0 ; Geogr. Breite des Mittelmeridians _var scale ; Kartenmaßstabszahl (also 1000000, nicht 1/1000000) _var pol-y ; Polversatz nach Nord _var 2pi ; 360 Grad ; ; x, y, x', y', Cx', Cy', Rx', Ry', °(, (°, pi, pi/2 etc. sind vordefinierte globale Konstanten ; ; Initialisierung ; =============== ; tstne initial $077 ; Dialog input scale Maßstabszahl input phi0 Berührungspunktbreite~in~Grad input lambda0 Berührungspunktlänge~in~Grad input pol-y Pollage~nördlich~vom~Bildmittelpunkt~in~Geokoordinaten ; Eingegebene Werte auf Min/Max bringen clip scale 1 1E12 clip phi0 -90 90 clip lambda0 -180 180 clip pol-y -1E6 1E6 ; Konstanten berechnen neg phi0 ; Südpol mul phi0 °( mov delta0 pi/2 sub delta0 phi0 ; Delta0 fertig mov tand0 delta0 mov n delta0 sin n div n delta0 ; n fertig mov 2pi pi mul 2pi 2 ; 2*Pi ; Programm ist initialisiert mov initial 1 $077: ; ; SIMD-Laufbereich ; ================ ; ; Maßstab, Kartenmittelpunkt etc. einrechnen ; ------------------------------------------ sub x Cx' ; Bildmittelpunkt div x Rx' ; Erdradius mul x scale ; Kartenmaßstab sub y Cy' ; sub y pol-y add y pol-y ; Südhalbkugel! div y Ry' mul y scale neg x neg y ; ; Kartesische Koordinaten x/y in Polarkoordinaten m/alpha umwandeln ; ----------------------------------------------------------------- mov alpha x ; kartesische Koord. x y in Polarkoordinaten m alpha div alpha y atan alpha tstgt y $151 ; Der atan ist doppeldeutig!: Wenn y negativ dann ... add alpha pi ; 180° addieren $151: neg alpha ; Jetzt ist alpha berechnet, liegt aber noch falsch add alpha pi cmplt alpha pi $153 sub alpha 2pi $153: power x 2 power y 2 clr m add m x add m y root m 2 ; ; Eigentlicher abstandstreuer Entwurf, dieser invers ; -------------------------------------------------- mov lambda alpha ; Geographische Länge div lambda n mov phi pi/2 ; Geographische Breite sub phi m ; ; Kontern, in Gradmaß umrechnen und Ausserhalbtest ; ------------------------------------------------ ; neg lambda ; Südhemisphäre! neg phi mul lambda (° mul phi (° cmplt lambda -180 out cmpgt lambda 180 out cmplt phi -90 out cmpgt phi 90 out ; ; Schlussarbeiten ; --------------- ; mov x' lambda mov y' phi ; Lambda kreisen lassen add x' lambda0 cmod x' -180 180 exit out: mov x' -9999 mov y' -9999 exit _end