U narednom poglavlju predstavljeni su ključni koncepti kartografskog preslikavanja, praktično ovi koncepti se mogu primeniti na bilo koju konkretnu projekciju. Ovo poglavlje obuhvata sledeće celine:
Razmatranje parametarskih jednačina sfere i parametarskih jednačina elipsoida kako bismo bolje razumeli osnovne geometrijske modele kod funkcija kartografskog preslikavanja.
Gausove fundamentalne veličine koje su ključne za razumevanje neizbežnih deformacija koje prate kartografske projekcije prilikom preslikavanja krivolinijskih koordina u pravougle ravanske koordinate.
Proučavanje opšte teorije kartografskog preslikavanja kako bismo saznali kako se prostorni podaci transformišu sa trodimenzionalnog prostora na dvodimenzionalne karte.
Detaljan opis linijskog elementa u ravni karte, linearne razmere, razmere površina i deformacija uglova.
Koncept i računanja koja se odnose na elipsu deformacija, Tisoovu indikatrisu, pružajući uvid u karakteristike deformacija pri preslikavanju sa sfere ili elipsoida na ravne karte.
Podela projekcija prema karakteru deformacija, klasifikacija projekcija u odnosu na pomoćne projekcione površine i položaj pomoćnih projekcionih površina, kao i klasifikacija projekcija u odnosu na zone.
Kroz ove celine čitaoci će razviti dublje razumevanje osnovnih koncepata kartografskog preslikavanja, što će im omogućiti da se upuste u izvođenje formula i razumevanje bilo koje konkretne kartografske projekcije koja se koristi u radu sa prostornim podacima.
3.1 Parametarske jednačine sfere
U prethodnom poglavlju smo diskutovali o parametrizaciji sfere, ovde ćemo još jednom ponoviti. Meridijani i paralele na sferi predstavljaju parametarske, tj. koordinatne linije, to je jedna od mogućih parametrizacija sfere. Pozicija bilo koje tačke na sferi može se definisati presekom jednog meridijana i jedne paralele. Kod slučaja kada smo imali ravan gde je bilo koja tačka određena presekom samo jedne x i samo jedne y koordinatne linije, to je slučaj regularne parametrizacije površi. Kod sfere imamo slučaj da postoje i singularne tačke, a to su polovi u kojima se sustiče svaki meridijan, a poluprečnik paralele u polovima je 0. Polovi nisu određeni presekom samo jedne paralele i samo jednog meridija, zato su to singularne tačke, pa i parametrizacija sfere meridijanama i paralelama nije u potpunosti regularna parametrizacija površi.
Parametarske jednačine bilo koje površi zadaju se u obliku:
\[
F(X, Y, Z)=0
\]
Kod sfere imamo slučaj da je rastojanje bilo koje tačke od površi do centra sfere jednako poluprečniku sfere:
\[
F(X, Y, Z)=X^2+Y^2+Z^2-R^2=0
\]
Gde su pravougle koordinate definisane u odnosu na krivolinijiske, kao što je definisano u prethodnom poglavlju:
Parametarske linije se mogu definisati u opštem slučaju za sferu. Jednačina paralele definisana je parametarskim koordinatama tako da je parametar \(\varphi\) konstantan, uzmimo da je označen sa \(c1\).
# install.packages("plotly")library(plotly)# Warning: package 'plotly' was built under R version 4.2.3# Warning: package 'ggplot2' was built under R version 4.2.3R=6377# koristimo polarne sferne koordinate u je theta, v je fitheta <-seq(0, 2*pi, length.out =120)phi <-seq(0, pi, length.out =60)u <-outer(theta, phi, FUN =function(t, p) t)v <-outer(theta, phi, FUN =function(t, p) p)# površ sferexs <- R*cos(u) *sin(v)ys <- R*sin(u) *sin(v)zs <- R*cos(v)x <-c() ; y <-c(); z <-c()# kreiranje meridijana gde je jedan parametar konstantanfor (c1 in theta[seq(1, length(theta), by =10)]) { x <-c(x, R*cos(c1) *sin(phi), NA) # NA za kraj meridijana y <-c(y, R*sin(c1) *sin(phi), NA) z <-c(z, R*cos(phi), NA)}# kreiranje paralela gde je jedan parametar konstantanfor (c2 in phi[seq(1, length(phi), by =6)]) { x <-c(x, R*cos(theta) *sin(c2), NA) # NA za kraj paralele y <-c(y, R*sin(theta) *sin(c2), NA) z <-c(z, R*rep(cos(c2), length(theta)), NA)}fig <-plot_ly() %>%add_surface(x = xs, y = ys, z = zs, colorscale =list(c(0, '#ffffff'), c(1, '#ffffff')),showscale =FALSE, opacity =0.5) %>%add_trace(x = x, y = y, z = z, type ='scatter3d', mode ='lines',line =list(width =3, color ='rgb(10,10,10)'))fig <- fig %>%layout(scene =list(aspectratio =list(x =1, y =1, z =1)))fig
Code
import numpy as npimport matplotlib.pyplot as pltfrom mpl_toolkits.mplot3d import Axes3Ddef plot_sfera(radius=1, meridians=12, parallels=6): fig = plt.figure() ax = fig.add_subplot(111, projection='3d')# polarne sferne koordinate u = np.linspace(0, 2* np.pi, meridians) v = np.linspace(0, np.pi, parallels) x = radius * np.outer(np.cos(u), np.sin(v)) y = radius * np.outer(np.sin(u), np.sin(v)) z = radius * np.outer(np.ones(np.size(u)), np.cos(v))# sfere ax.plot_wireframe(x, y, z, color='b')# plot meridijanafor i inrange(meridians): ax.plot(x[i, :], y[i, :], z[i, :])# plot paralelafor j inrange(parallels): ax.plot(x[:, j], y[:, j], z[:, j]) ax.set_xlabel('X') ax.set_ylabel('Y') ax.set_zlabel('Z') ax.set_title('Parametarske linije na sferi')# prikaz plt.show()# plot (# može se napraviti plot i koristeći plotly iz Pythona)plot_sfera(radius=6377, meridians=12, parallels=6)
3.2 Parametarske jednačine elipsoida
Parametarske linije na elipsoidu definisane su kao kod sfere, i to su meridijani i paralele na elipsoidu. Jednačina elipsoida ima oblik:
Jednačina meridijana definisana je parametarskim koordinatama tako da je parametar \(\lambda\) konstantan, uzmimo da je označen sa c2.
\[
\begin{aligned}
& X=X(\varphi, c 2) \\
& Y=Y(\varphi, c 2) \\
& Z=Z(\varphi, c 2)
\end{aligned}
\]
3.3 Gausove fundamentalne veličine
Ako je tačka A definisana koordinatama (X,Y,Z), Slika 3.2. Uočimo tačku C koja je veoma bliska tački A, i definisana je koordinatama X+ΔX, Y+ΔY, Z+ΔZ. Ako smatramo da su A i C vrlo bliske tačke, možemo da zanemarimo zakrivljenost elipsoida i dužinu možemo da sračunamo kao pravu u prostoru.
Onda je dužina AC:
\[
A C^2=(X+\Delta X-X)^2+(Y+\Delta Y-Y)^2+(Z+\Delta Z-Z)^2
\] Odnosno :
\[
A C^2=\Delta X^2+\Delta Y^2+\Delta Z^2
\]
Ako pretpostavimo da su tačke na neizmerno malom rastojanju onda je jasno da veličinu \(ds\) možemo izraziti kao:
\[
d s^2=d X^2+d Y^2+d Z^2
\]
Uzmimo da je u pitanju bilo koja površ koja ima parametarske linije \(\varphi\) i \(\lambda\), Slika 3.3, onda se svaka pravougla koordinata može definisati kao funkcija od parametarskih koordinata:
Za kartografsko preslikavanje između originalne i projekcione površi koriste se neke matematičke funkcije preslikavanja koje preslikavaju tačke, linije i poligone sa elipsoida na ravan. Svakoj tački sa elipsoida odgovara samo jedna tačka u projekciji i obratno. Sa slike, (Slika 3.5), može se uočiti da se tačka A preslikala u tačku A’, tačka B u B’, tačka C u C’ i konačno tačka D u D’. Pored toga, vidimo da u projekciji imamo sliku meridijana i paralela koji su preslikani u opštem slučaju kao krive linije.
Funkcije kartografskog preslikavanja imaju oblik:
\[E= y = f_{1}(\varphi,\lambda)\]
\[N = x = f_{2}(\varphi,\lambda)\]
Ili za inverzni zadatak:
\[\varphi = g_{1}(E,N)\]
\[\lambda= g_{2}(E,N)\]
Funkcije kartografskog preslikavanja moraju da zadovolje sledeće uslove:
Sledeća slika je verovatno najznačajnija kod opšte teorije kartografskog preslikavanja zato što mnoge veličine u pogledu preslikavanja sa elipsoida na ravan zaključujemo polazeći od preslikavanja elementarnog tapeza ABCD na ravan karte. Kao što smo ranije pominjali, tačke ovog trapeza su na infinitezimalnom rastojanju, teži beskonačno malom rastojanju, tako da se ovakav trapez može smatrati ravnim. Na slici (Slika 3.6) su prikazane sledeće veličine koje dosad nisu pominjane. Azimut „α“ na elipsoidu utvrđuje položaj pravaca, a meri se počev od meridijana tačke u pravcu kazaljke na časovniku,odnosno od severa na istok, jug i zapad. A je azimut u projekciji, isprekidane linije su tangente na odgovarajuće krive u ravni. Ugao \(\theta\) je ugao između meridijana i paralele u projekciji. Na elipsoidu se meridijani i paralele seku pod pravim uglom, dok se u projekciji seku pod uglom \(\theta\), a samo kod konformnih projekcija pod pravim uglom. Treba napomenuti da je zakrivljenost meridijana i paralela na beskonačno malom trapezu u ravni projekcije zanimarljiva, ali je ovde istaknuta zbog razumevanja procesa kartografskog preslikavanja.
Vratimo se na opšte jednačine kartografskog preslikavanja:
Dužina dS u ravni može se sračunati koristeći Gausove fundamentalne veličine, već smo napomenuli i ranije da one mogu da važe za bilo koju površ, pa i ravan u kojoj su pravougle koordinate funkcije od krivolinijskih.
možemo sračunati linijski element dS. Još jednom treba napomenuti da je kod konformnih projekcija, gde se meridijani i paralele seku pod pravim uglom, veličina F jednaka nuli.
Linearna razmera
Linearnim razmera je granična vrednost (limes) odnosa beskonačno male duži u projekciji i odgovarajuće duži na površi Zemljinog elipsoida ili lopte. Stoga je, Slika 3.6, formula za linearnu razmeru:
\[
\mathrm{c}=\lim _{A C \rightarrow 0}\left(\frac{A^{\prime} C^{\prime}}{A C}\right)=\frac{d S}{d s}
\] Ako kvadriramo levu i desnu stranu, koristeći Gausove fundamentalne veličine, imamo:
Već odavde je jasno da je linearna razmera funkcija koja zavisi od pozicije tačke i azimuta pravca
\[
c=c(\varphi, \lambda, \alpha)
\]
Dakle, u opštem slučaju na svakoj poziciji na karti linearna razmera ima drugu vrednost. Na samoj poziciji u različitim pravcima ima različite vrednosti.
i sređivanjem izraza došlo bi se do konačne formule za linearnu razmeru u opštem slučaju.
\[
\mathrm{c}^2=\frac{E}{M^2} \cos ^2 \alpha+\frac{F}{M N \cos \varphi} \sin 2 \alpha+\frac{G}{(N \cos \varphi)^2} \sin ^2 \alpha
\] Odstupanje razmere od 1 naziva se linearnom deformacijom ili deformacijom dužina (\(dc\)):
\[
dc=c-1
\]
Linearna razmera u pravcu meridijana i paralele
Uočimo sa slike (Slika 3.6) da je linearna razmera u pravcu meridijana (m):
\[
m=\frac{\sqrt{E}}{M}
\]
Ovo smo mogli dobiti i računajući preko opšte formule, azimut se meri od meridijana, jasno je da je od tačke A u pravcu meridijana azimut 0, Slika 3.6.
Ako uočimo sliku trapeza na elipsoidu koji teži da bude beskonačno mali, njegova slika na karti je beskonačno mali paralelogram, gde za tako mali element slike meridijana i paralele možemo smatrati pravim linijama u okviru paralelograma, Slika 3.8.
Tada linijski element možemo sračunati koristeći kosinusnu teoremu i onda imamo:
Možemo videti da su kvadratni članovi isti, tako da mora biti isti i mešoviti član, pa dalje imamo da je kosinus ugla između meridijana i paralele u projekciji:
\[
\cos (\theta)=\frac{\mathrm{F}}{\sqrt{E G}}
\]
Odavde dalje možemo sračunati i F kao:
\[
F=\sqrt{E G} \cos (\theta)
\]
Zamenimo F u opštoj formuli za linearnu razmeru \(\mathrm{c}^2=\frac{E}{M^2} \cos ^2 \alpha+\frac{F}{M N \cos \varphi} \sin 2 \alpha+\frac{G}{(N \cos \varphi)^2} \sin ^2 \alpha\) i dobijamo:
Pošto je period tangensa jednak \(180^o\) , jednačina ima 2 rešenja: jedno će biti \(\alpha_0\), a drugo \(\alpha_0+90\). Prema tome, glavni pravci se na originalnoj površi seku pod uglom od \(90^o\).
Rešenja su oblika: \[
\alpha_0 \text { i } \alpha_0+90^o
\]
Glavni pravci su upravni jedan na drugi, seku se pod pravim uglom, i u projekciji (ravni karte) i na površi (elipsoidu ili lopti) su ortogonalni (upravni). Zaključak je da: uvek postoje samo dva upravna pravca na elipsoidu koji će se preslikati na karti kao ortogonalni (upravni) i imaće ekstremnu vrednost linearne razmere. Pravac u kom je linearna razmera najveća naziva se prvi glavni pravac i obično se obeležava slovom a. Pravac u kom je linearna razmera najmanja naziva se drugi glavni pravac i obično se obeležava slovom b.
Razmer površina
Odnos površina odgovarajućih elementarnih figura na slici i originalnoj površi naziva se razmer površina, Slika 3.8. Površina beskonačno malog trapeza na elipsoidu je:
Ranije smo videli da je \(m=\frac{\sqrt{E}}{M}\) i \(n=\frac{\sqrt{G}}{N \cos \varphi}\).
Deformacija površina je definisana izrazom koji pokazuje koliko se one deformišu u odnosu na preslikavanje koje nema deformacija površina, tj. gde je p=1:
\[
d p=p-1
\]
Deformacije uglova
U procesu kartografskog preslikavanja ne deformišu se samo dužine i površine nego i uglovi. Da bi izvođenje bilo jednostavnije, pretpostavićemo da se koordinatne ose poklapaju sa glavnim pravcima (izvođenje se može primeniti i u opštem slučaju). Uočimo beskonačno mali krug na elipsoidu, Slika 3.11, postavimo pravougli koordinatni sistem X,Y čija je slika pravougli koordinatni sistem u ravni koji se poklapa sa glavnim pravcima a i b, a koordinatne ose su označene kao \(x,y\). Imamo da je slika beskonačno malog kruga elipsa (elipsa deformacija ili Tisoova idikatrisa). Videli smo da je u opštem slučaja linearna razmera različita u različitim pravcima, imaju dva upravna glavna pravca u kojim ona dostiže ekstremne vrednosti a i b, razmera u pravcu paralele je n i u pravcu meridijana je m. Azimut glavnog pravca na elipsoidu je označen sa \(\alpha\), dok je ugao \(\beta\) direkcioni ugao tačke T sa elementarnog kruga u odnosu na koordinatni sistem postavljen na elipsoidu (\(X,Y\)). Tačka T se preslikava u tačku T’ koja ima direkcioni ugao B, a azimut glavnog pravca je označen sa A u ravni projekcije.
Deformacija ugla predstavlja razliku ugla na elipsoidu i ugla u ravni (projekciji), obeležava se sa \(du\) ili \(\omega/2\)
\[
\omega / 2=\beta-B
\]
Sa slike možemo odrediti glavne pravce kao:
\[
a=\frac{x}{X}, b=\frac{y}{Y}
\]
Zato što su koordinate tačke T u pravcu \(x\) i \(y\) infinitezimalne dužine u pravcu glavnih pravaca, koje su slika odgovarajućih \(X\) i \(Y\) dužina sa elipsoida. Dalje imamo:
\[
\frac{y}{x}=\frac{b Y}{a X}
\]
Pošto je \(\frac{y}{x}\) u stvari nagib pravca tačke T’, a \(\frac{Y}{X}\) nagib pravca tačke T, imamo:
Nas zanima maksimalna deformacija uglova u okolini posmatrane tačke. Pošto a i b imaju konstantne vrednosti u zadatoj tački karte, očigledno je da će razlika \((\beta-B)=du=\omega/2\) dostići maksimalan iznos kada je \(sin (\beta+B)=1\), odnosno kada je zbir uglova \((\beta+B)=90^o\).
\[
\sin (\beta-B)=\frac{a-b}{a+b}
\]
\[
\sin \frac{\omega}{2}=\frac{a-b}{a+b}
\]
U litaraturi, npr. Jovanović (1984), mogu se naći i sledeći izrazi za maksimalnu deformaciju uglova:
\[
\sin \frac{\omega}{2}=\frac{a-b}{a+b}=\sqrt{\frac{m^2+n^2-2 m n \sin \theta}{m^2+n^2+2 m n \sin \theta}}=\sqrt{\frac{m^2+n^2-2 m n \cos \varepsilon}{m^2+n^2+2 m n \cos \varepsilon}}
\]
\[
\operatorname{tan} \frac{\omega}{2}=\frac{1}{2} \sqrt{\frac{m^2+n^2-2 m n \sin \theta}{m n \sin \theta}}=\frac{1}{2} \sqrt{\frac{m^2+n^2-2 m n \cos \varepsilon}{m n \cos \varepsilon}}
\]
Gde je \(\varepsilon = \theta -90\), odstupanje ugla između meridijana i paralele u projekciji od pravog ugla.
3.5 Elipsa deformacija (Tisoova indikatrisa)
Francuski geograf i matematičar Tiso, razmatrajući deformacije koje nastaju pri preslikavanju dvostruko zakrivljene površi Zemlje na ravan, došao je do veoma značajnih zaključaka za matematičku kartografiju.
Teorija deformacija po Tisou, u osnovi, objašnjava da se elementarni krug sa površi elipsoida, načelno uzimajući, preslikava na ravan kao elipsa, osim u specijalnom slučaju ako su obe površi (ili njihovi delovi) međusobno paralelne, u kom slučaju će krug ostati krug željenog razmera.
Razmotrimo slučaj da se postavi dvodimenzionalni koordinatni sistem na elipsoidu tako da se poklapa sa pravcima meridijana i paralele, i da se iz ishodišta kreira infinitezimalni krug, Slika 3.12.
Uočavamo da navedena formula predstavlja formulu elipse, pri čemu su \(m ds\) i \(n ds\) tzv. spregnuti (konjugovani) dijametri elipse. Svaki par međusobno upravnih dijametara kruga preslikava kao par konjugovanih dijametara elipse. U opštem slučaju vidimo da se elemantarni krug se preslikava u elipsu, Tisoovu indikatrisu. Tisoova indikatrisa nam pokazuje karakteristike deformacija u okolini posmatrane tačke, sa nje uočavamo veličine deformacija i to: deformacije uglova (oblika), dužina i površina.
Uzmimo da je ds=1, neka jedinična vrednost, tada imamo:
Ako su koordinate (postavljene kroz centar elementarnog kruga, Slika 3.13) na elipsoidu ujedno i glavni pravci, drugim rečima, ako mreža meridijana i paralela ostaje ortogonalna i u projekciji, onda će, uz uslov da se prvi glavni pravac poklapa sa meridijanom, biti: m=a i n=b, i tada sledi da je:
Apolonijeve teoreme nam mogu pomoći pri određivanju vrednosti prvog i drugog glavnog pravca (\(a\) i \(b\)) i konstruisanju elipse deformacija. Prema prvoj teoremi, suma kvadrata spregnutih dijametara elipse jednaka je sumi kvadrata njenih poluosa:
\[
a^2+b^2=m^2+n^2
\]
Druga Apolonijeva teorema glasi: površina tangentnog paralelograma elipse nad njenim dijametrima jednaka je konstanti, odnosno površini tangentnog paralelograma nad poluosama elipse, tj.:
\[
a \cdot b=m \cdot n \cdot \sin \theta
\]
Na osnovu Apolonijevih teorema imamo:
\[
\begin{aligned}
& a^2+b^2=m^2+n^2 \\
& a \cdot b=m \cdot n \cdot \sin \theta
\end{aligned}
\]
Ako drugi izraz pomnožimo sa minus dva i saberemo sa prvim dobićemo:
\[
\begin{aligned}
&(a+b)^2=m^2+n^2+2 m n \sin \theta\\
\end{aligned}
\]
Ako drugi izraz pomonožimo sa minus dva i saberemo sa prvim dobićemo:
\[
\begin{aligned}
&(a-b)^2=m^2+n^2-2 m n \sin \theta
\end{aligned}
\]
Jasno je da onda imamo:
\[
\begin{aligned}
&A=(a+b)=\sqrt{m^2+n^2+2 m n \sin \theta}\\
&B=(a-b)=\sqrt{m^2+n^2-2 m n \sin \theta}
\end{aligned}
\]
Dakle veličine A i B možemo sračunati ako znamo linearnu razmeru u pravcu paralele, u pravcu meridijana i ugao između meridijana i paralele, sve ove veličine, tj. njihove formule, ranije smo izveli. Dalje, ako znamo vrednost za A i B, možemo sračunati vrednosti za prvi i drugi glavni pravac:
Kod konformnih projekcija mreža meridijana i paralela je ortogonalna, jer je ortogonalna i na origanalnoj površi kod sfere ili elipsoida (nema deformacija uglova). Kod konformnih projekcija elipsa deformacija je krug jer nema deformacija oblika. Uslov konformnosti možemo formulisati tako da je u okolini posmatrane tačke linearna razmera u svim pravcima ista.
Elipsa deformacija konstrukcija
Slika 3.14 prikazuje postupak konstrukcije elipse deformacija, slika je podeljena na 5 koraka da bi se lakše pratio tok konstrukcije. Ako znamo linearnu razmeru u pravcu meridijana (\(m\)) i paralele (\(n\)), kao i ugao između meridijana i paralele (\(\theta\)), možemo konstruisati elipsu deformacija.
Dokaz za postupak za grafičku konstrukciju elipse deformacija započinjemo kosinusnom teoremom za trougao CON, Slika 3.15.
Kosinusna teorema za trougao CON
\[
C N^2=m^2+n^2-2 m n \cos (90-\theta)
\]
\[
C N^2=m^2+n^2-2 m n \sin (\theta)
\]
Kosinusna teorema za trougao DON
\[
D N^2=m^2+n^2-2 m n \cos (90+\theta)
\]
\[
D N^2=m^2+n^2+2 m n \sin (\theta)
\]
Ako se vratimo na Apolonijevu teoremu i uporedimo sa dobijenim
\[
A=(a+b)=\mathrm{DN}=\sqrt{m^2+n^2+2 m n \sin \theta}
\]
\[
B=(a-b)=\mathrm{CN}=\sqrt{m^2+n^2-2 m n \sin \theta}
\]
Uočimo da je trougao DCN sličan trouglu DOE, paralelni kraci i pripadajući uglovi, očigledno da je OD = DC/2, tako da važi:
Treba zapaziti da je \(EK = EL = EO\) jer je to poluprečnik malog kruga sa centrom u E, poluprečnik kruga je \(EO\). Tačke \(L\) i \(K\) su dobijene presekom tog kruga sa pravom \(DN\). Pravac velikih poluosa je definisan pravcima \(OL\) i \(OK\). Grafički se mogu preuzeti i vrednosti za veliku i malu poluosu elipse:
\[
\mathrm{DK}=\mathrm{DE}+\mathrm{EL}(\text { isto je kao OE) }=(\mathrm{a}+\mathrm{b}) / 2+(\mathrm{a}-\mathrm{b}) / 2=\mathrm{a}
\]
\[
D L=D E-E L(\text { isto je kao OE })=(a+b) / 2-(a-b) / 2=b
\]
Pošto elipse deformacija pokazuju prostiranje deformacija u bilo kojoj tački od interesa vrlo se često koriste da sagledamo prostiranje deformacija kod neke projekcije. Besplatan softver flexprojector može se koristiti za pregled rasporeda deformacija kod raznih projekcija koje se koriste za globalno kartiranje planete Zemlje, Slika 3.16.
Elipsa deformacija alternativni način
Kao što smo videli u predhodnom poglavlju R softversko okruženje u okviru paketa s2 i sf ima implementirane algoritme za računanja na elipsoidu ili sferi, isto tako u okviru implementacije PROJ biblioteke moguće je izvršavati direktni i inverzni zadatak, kao i koordinatne transformacije.
Dakle, ako kreiramo konačne krugove na elipsoidu (Slika 3.17) i onda ih transformišemo u neku projekciju, dobićemo elipse deformacija. Ovde treba napomenuti da strogo gledano postupak nije ispravan jer ne koristimo krugove čiji poluprečnik teži nuli, ali suštinski dobijamo prostiranje deformacija na skoro isti način kao da kostruišemo elipse deformacija na gore opisan način (Gimond 2022).
library(sf)sf_use_s2(TRUE) # koristi sferna racunanja# kreiramo tačke u kojima cemo prikazati elipse deformacijalonlat =rbind(c(19,42), c(19,44), c(19,46),c(20,42), c(20,44), c(20,46),c(21,42), c(21,44), c(21,46),c(22,42), c(22,44), c(22,46) )tissot.pt <-st_sfc( st_multipoint(lonlat), crs =4326) # WGS84 koordinatni ref. sis.tissot.pt <-st_cast(tissot.pt, "POINT") # konvertujemo u single point geometriju# plot(tissot.pt)# koristi se s2 paket za elipsodna računanja# Pravimo tacke po krugu udaljene 30 km od centra elipsetissot.sf =st_buffer(tissot.pt, dist =30000, max_cells =1000)# max_cells# The maximum number of cells to approximate a buffer.# nrow(st_coordinates(tissot.sf[1]))# [1] 646# Ako koristimo opciju max_cell = 1000 imamo 646 prelomnih tačaka poligona# konvertujemo kolekciju poligona u sf objekattissot.sf <-st_sf(tissot.sf)# Sračunajmo površinu svakog kruga na elipsoidutissot.sf$a <-st_area(tissot.sf)# plotKML::plotKML(tissot.sf)
Ako transformišemo krugove u Merkatorovu projekciju, dobićemo elipse deformacija u Merkatorovoj projekciji, za svaku elipsu izrazićemo i razmer površina. Uz pomenuti prikaz ćemo kartirati i granice opština u Srbiji.
tissot.merc <-st_transform(tissot.sf, "+proj=merc +ellps=WGS84")# površine u projekcijitissot.merc$a_proj <-st_area(tissot.merc)# odnos površina u projekciji i na elipsoidutissot.merc$p <- tissot.merc$a_proj/tissot.merc$a# granice opština u Srbif (file.exists('data/pop.gml') ){ pop =st_read('data/pop.gml') }else{ url=paste('http://osgl.grf.bg.ac.rs/geoserver/osgl_4/wfs','?service=WFS&version=1.0.0&','request=GetFeature&typeName=osgl_4:POP_age',sep='')download.file(url, 'pop.gml') pop =st_read('pop.gml')}# Reading layer `POP_age' from data source `C:\mk_knjiga\data\pop.gml' using driver `GML'# Simple feature collection with 197 features and 14 fields# Geometry type: MULTIPOLYGON# Dimension: XY# Bounding box: xmin: 18.8 ymin: 41.9 xmax: 23 ymax: 46.2# CRS: NA# podaci su u WGS84st_crs(pop) =4326pop =st_transform(pop, "+proj=merc +ellps=WGS84")ll =st_centroid(tissot.merc)ll =st_coordinates(ll)# Karta sa elipsama deformacija i razmerom površinaplot(st_geometry(pop), graticule =TRUE, border ='grey', axes =TRUE)plot(st_geometry(tissot.merc), border ='red', add =TRUE)text(ll[, 1], ll[, 2], paste("p=",round(tissot.merc$p,3)) , cex =0.8)
Kao što vidimo sa slike (Slika 3.18) u Merkatorovoj projekciji površine na severu Srbije deformišu se duplo. U UTM projekciji koja je takođe konformna, površine se znatno manje deformišu, Slika 3.19, to je i razlog zašto se koristi kao državna projekcija u skoro svim zemljama Evrope. Još jednom treba napomenuti da je razmer površina sračunat približno koristeći odnose površina konačnih figura. Razmere površina su sračunate po formulama koje ćemo razraditi u poglavlju koje se odnosi na UTM projekciju.
tissot.utm <-st_transform(tissot.sf, "+proj=utm +zone=34 +ellps=GRS80")# površine u projekcijitissot.utm$a_proj <-st_area(tissot.utm)# računanje linearne razmere u UTMlr <-function(lonlatmatrica){ l= (lonlatmatrica[,1] -21)*pi/180 fi= (lonlatmatrica[,2])*pi/180# GRS80 a=6378137.0 rf=298.257222101 GRS 1980(IUGG, 1980) a=6378137.0 rf=298.257222101 f =1/rf e =sqrt(2*f - f^2) e1 =sqrt( (2*f - f^2)*(1- f)^-2 ) t=tan(fi) eta=e1*cos(fi) C1=1/2*(1+eta^2)*(cos(fi))^2 C2=1/24*(5-4*t^2)*(cos(fi))^4# linerarna razmera (u R-u se uglavnom ne koristi c kao promenljiva) cc=0.9996*(1+C1*l^2+C2*l^4) return(cc)}# linerarna deformacija u dm/kmtissot.utm$p <- (lr(lonlat)) ^2# tissot.utm$p <- tissot.utm$a_proj/tissot.utm$apop =st_transform(pop, "+proj=utm +zone=34 +ellps=GRS80")ll =st_centroid(tissot.utm)ll =st_coordinates(ll)# Karta sa elipsama deformacija i razmerom površinaplot(st_geometry(pop), graticule =TRUE, border ='grey', axes =TRUE)plot(st_geometry(tissot.utm), border ='red', add =TRUE)text(ll[, 1], ll[, 2], paste("p=",round(tissot.utm$p,4)) , cex =0.8)
Kod Sinusoidne projekcije površine se ne deformišu jer je ona ekvivalentna, ali se deformišu oblici, Slika 9.4. Još jednom treba napomenuti da je razmer površina sračunat približno koristeći odnose površina konačnih figura, pa kod ove projekcije nije 1 jer nije sračunat po formuli za razmer površina. Kao što možemo primetiti, kod Sinusoidne projekcije imamo slučaj da presek između meridijana i paralela nije prav ugao.
tissot.sin <-st_transform(tissot.sf,"+proj=sinu +ellps=WGS84")# površine u projekcijitissot.sin$a_proj <-st_area(tissot.sin)# odnos površina u projekciji i na elipsoidutissot.sin$p <- tissot.sin$a_proj/tissot.sin$apop =st_transform(pop, "+proj=sinu +ellps=WGS84")ll =st_centroid(tissot.sin)ll =st_coordinates(ll)# Karta sa elipsama deformacija i razmerom površinaplot(st_geometry(pop), graticule =TRUE, border ='grey', axes =TRUE)plot(st_geometry(tissot.sin), border ='red', add =TRUE)text(ll[, 1], ll[, 2], paste("p=",round(tissot.sin$p,1)) , cex =0.8)
3.6 Podela projekcija prema karakteru deformacija
Kao što smo videli, u opštem slučaju prilikom kartografskog preslikavanja deformišu se:
DUŽINE,
POVRŠINE,
UGLOVI.
U pogledu deformacija projekcije se dele na:
konformne (istougle, lokalno nema deformacije uglova, tj oblika),
ekvivalente (istopovršinske) i
uslovne (proizvoljne).
U grupu uslovnih spadaju i ekvidistantne, gde u jednom pravcu nema deformacije dužina. Najčešće u jednom glavnom pravcu; ili u pravcu meridijana; ili u pravcu paralele.
Projekcija uvek može pripadati samo jednoj grupi.
Konformne projekcije
Osim naziva konformne (istougle) projekcije, često se sreće i naziv ortomorfne projekcije, što znači da se ovim preslikavanjem obezbeđuje sličnost beskonačno malih figura ‒ tzv. lokalna sličnost.
U bilo kojoj tački istouglog preslikavanja indikatrisa je krug, tj. linearna razmera ostaje ista u svim pravcima oko zadate tačke, što se može izraziti odnosom:
\[
a=b=m=n=c
\]
Ako se vratimo na formulu za deformaciju površina:
Kod konformnih projekcija ugao između meridijana i parale je ={90}^o, linearna ramera je ista u svim pravcima pa imamo:
\[
p=a^2=b^2=m^2=n^2=c^2
\]
Istopovršinske (ekvivalentne projekcije)
Ekvivalentne (homalografske) projekcije očuvavaju površine figura i zadovoljavaju uslov:
\[
p=a b=m n \sin \theta=m n \cos \varepsilon=1
\]
Ako je razmer površine jednak jedinici u svakoj tački u ravni projekcije, onda i konačne površine ostaju očuvane i nema deformacije površina konačnih geometrijskih entiteta.
Uslovne projekcije
Kod ovih projekcija postoje istovremeno i deformacije uglova i deformacije površina. Ipak, iz veoma velike grupe uslovnih (proizvoljnih) projekcija izdvaja se grupa tzv. ekvidistantnih (istodužinskih) projekcija, kod kojih je linearan razmer uzduž jednog od glavnih pravaca konstantan i jednak jedinici, tj. ili a=1, ili b=1, kod ovih projekcija vrlo često se taj glavni pravac poklapa sa pravcem meridijana ili paralele.
3.7 Klasifikacija projekcija u odnosu na pomoćne projekcione površi
Zemljin elipsoid (ili lopta) ne samo da se preslikava direktno na ravan već se, ponekad, zamišljeno preslikava na bočne površi konusa ili cilindra, koje se zatim razvijaju u ravan, Slika 3.21.
Cilindrične,
Konusne i
Azimutne.
3.8 Klasifikacija projekcija u odnosu na položaj pomoćne projekcione površi
Položaj projekcionih površi iskazuje se, najočiglednije, položajem koji obrtne ose (cilindra ili konusa) zauzimaju u odnosu na obrtnu osu Zemlje, Slika 3.22. Kod azimutnih projekcija normala, na ravan projekcije i elipsoid (loptu) u dodirnoj tački. Prema tome, projekcije se dele na:
Normalne (prave),
Poprečne (transferzalne) i
Kose
3.9 Klasifikacija projekcija u odnosu na zone
Jedinstvene projekcije
U ovom slučaju izrada karata za neko područje provodi se u jednom istom koordinatnom sistemu u ravni (npr. Merkatorova projekcija koju smo pominjali ranije (konformna), Sinusoidna (ekvivalentna), ili Robinsonova projekcija (ekvivalenta), Slika 3.23).
library(sf)library(spData)data(world)granicaSRKS =st_union(world[173, 'geom' ], world[175,'geom'] )world[173, ]$geom = granicaSRKS$geomworld = world[-175,]world_r =st_transform(world, crs ="+proj=robin +lon_0=0 +x_0=0 +y_0=0 +ellps=WGS84 +datum=WGS84")plot(world_r["lifeExp"], graticule =TRUE, main ="Očekivani životni vek za rođene 2014.")
Višezone (višepojasne ) projekcije
Kod krupnorazmernih karata da bismo održali zadani nivo tačnosti, područje preslikavanja delimo na zone (duž meridijana), ili pojaseve (duž paralela). (Npr. UTM projekcija, prikaz 60 UTM zona, Slika 3.24.)
Višegrane projekcije
U ovom slučaju celokupno područje preslikavanja deli se linijama meridijana i paralela na odgovarajući broj sferoidnih ili sfernih trapeza. Svaki takav trapez preslikava se odvojeno u projekciji usvojenoj za celokupno područje preslikavanja. Svaki list karte je zaseban koordinatni sistem. (Modifikovana američka polikonusna projekcija, primer takve projekcije je i Nikolozi globular projekcija, koja je višegrana i deli ceo svet na 2 dela, Slika 3.25)
Prekinute projekcije
Ove se projekcije primenjuju za kartografisanje odvojenih delova Zemljine površi ‒ na primer, karte kontinenata ili vodenih površina, koje se spajaju po pravilu duž Ekvatora. Kartografska mreža prekinuta je duž odgovarajućih, unapred izabranih meridijana. Ponekad, štaviše, postoji ne samo jedan već nekoliko prekida mreže. (Gudeova (Goode homolosine) projekcija, Slika 3.26)
3.10 Primeri računaja za Sinusoidnu projekciju preslikavanja sfere na ravan
Data je Sinusoidna projekcija formulama koja preslikava sferne koordina na ravan:
\[
\begin{gathered}
E(\lambda, \phi)=y(\lambda, \phi)=R\left(\lambda-\lambda_0\right) \cos \phi \\
N(\lambda, \phi)=x(\lambda, \phi)=R \phi
\end{gathered}
\] Srednji meridijan usvajamo da je Grinički \(\lambda_0 = 0\) i \(R=6377000\) m.
Primer 1: Računanje koordinata jedne tačke, direktni zadatak
Sferne koordinate \(\varphi=45\) i \(\lambda=21\) sa sfere (\(R=6377000\) m) transformisati u Sinusoidnu projekciju, Slika 3.27.
# KonstanteR <-6377000# mlambda_0 <-0# Izabrani centralni meridijan# Koordinate na sferifi <-45# Latitudalambda <-21# Longituda# Stepeni u radijanefi_rad <- fi * pi /180lambda_rad <- lambda * pi /180lambda_0_rad <- lambda_0 * pi /180# Formule za sinusoidnu projekcijuEasting <- R * (lambda_rad - lambda_0_rad) *cos(fi_rad)Northing <- R * fi_rad# Ispis rezultataoptions(digits =12)cat("Easting:", round(Easting ,2) , " m , Northing:", round(Northing ,2), " m") # Easting: 1652715.43 m , Northing: 5008484.09 m
import math# KonstanteR =6377000# Poluprečnik u metrimalambda_0 =0# Izabrani centralni meridijan u stepenima# Koordinate na sferifi =45# Latituda u stepenimalambda_ =21# Longituda u stepenima# Stepeni u radijanefi_rad = math.radians(fi)lambda_rad = math.radians(lambda_)lambda_0_rad = math.radians(lambda_0)# Formule za sinusoidnu projekcijuEasting = R * (lambda_rad - lambda_0_rad) * math.cos(fi_rad)Northing = R * fi_rad# Ispis rezultataprint(f"Easting: {round(Easting, 2)} m, Northing: {round(Northing, 2)} m")# Easting: 1652715.43 m, Northing: 5008484.09 m
Primer 2: Izračunati Gausove fundamentalne veličine za tačku (45,21) u Sinusoidnoj projekciji
Finkcije preslikavanja su definisane izrazima:
\[
y = R (\lambda - \lambda_0) cos(\phi)
\]\[
x = R \phi
\]
teta =acos(F/sqrt(E*G))# Ispis rezultata u stepenimaoptions(digits =12)cat("Meridijan i paralela na tački (45,21) u Sin. prj se seku pod uglom :", round(teta*180/pi,6) )# Meridijan i paralela na tački (45,21) u Sin. prj se seku pod uglom : 104.529565
import math# Izračunavanje ugla između meridijana i paraleleteta = math.acos(F / math.sqrt(E * G))# Ispis rezultata u stepenimaprint(f"Meridijan i paralela na tački (45,21) u Sin. prj se seku pod uglom: {round(teta *180/ math.pi, 6)}")# Meridijan i paralela na tački (45,21) u Sin. prj se seku pod uglom: 104.529565
Primer 5: Izračunati linearnu razmeru u pravcu azimuta od \(30^o\) za tačku (45,21)
Konačna formula za linearnu razmeru u opštem slučaju je:
alfa =30*pi/180c_30_sq <- m^2*cos(alfa)^2+ m * n *cos(teta) *sin(2*alfa) + n^2*sin(alfa)^2c_30 =sqrt(c_30_sq)# Ispis rezultataoptions(digits =12)cat("Linearna razmera u pravcu azimuta od 30 st. za tačku (45,21):", c_30, "\n")# Linearna razmera u pravcu azimuta od 30 st. za tačku (45,21): 0.908806847201
import math# Azimut alfa u radijanimaalfa =30* math.pi /180# 30 stepeni u radijanima# Izračunavanje c_30c_30_sq = m**2* math.cos(alfa)**2+ m * n * math.cos(teta) * math.sin(2* alfa) + n**2* math.sin(alfa)**2c_30 = math.sqrt(c_30_sq)# Ispis rezultataprint(f"Linearna razmera u pravcu azimuta od 30 stepeni za tačku (45,21): {round(c_30, 6)}")# Linearna razmera u pravcu azimuta od 30 stepeni za tačku (45,21): 0.908807
Primer 6: Izračunati linearnu razmeru u pravcu svih azimuta od 1 do 360 stepeni za tačku (45,21) i napraviti grafik
Konačna formula za linearnu razmeru u opštem slučaju je:
\[
\mathrm{c}^2=m^2 \cos ^2 \alpha+m n \cos (\theta) \sin 2 \alpha+n^2 \sin ^2 \alpha
\] Treba izračunati linearnu razmeru za svako \(\alpha\), savaki azimut pravca, od 1 do 360 stepeni i dobiti 360 vrednosti linearne razmere.
# Kreiranje azimuta od 1 do 360 stepeniazimuti <-seq(1, 360, by =1)alfa_radians <- azimuti * pi /180# U radijane# Izračunavanje linearne razmere za svaki azimutc_values <-sqrt(m^2*cos(alfa_radians)^2+ m * n *cos(teta) *sin(2*alfa_radians) + n^2*sin(alfa_radians)^2)# Ispis rezultataoptions(digits =12)head(data.frame(Alfa=azimuti,c=round(c_values,6) ) )# Alfa c# 1 1 1.028641# 2 2 1.024211# 3 3 1.019752# 4 4 1.015269# 5 5 1.010769# 6 6 1.006256
import numpy as npimport pandas as pd# Kreiranje azimuta od 1 do 360 stepeniazimuti = np.arange(1, 361, 1)alfa_radians = np.radians(azimuti) # Azimuti u radijanima# Izračunavanje linearne razmere za svaki azimutc_values = np.sqrt(m**2* np.cos(alfa_radians)**2+ m * n * np.cos(teta) * np.sin(2* alfa_radians) + n**2* np.sin(alfa_radians)**2)# Kreiranje DataFrame-a sa rezultatimadf = pd.DataFrame({'Alfa': azimuti, 'c': np.round(c_values, 6)})# Ispis prvih nekoliko vrednostiprint(df.head())# Alfa c# 0 1 1.028641# 1 2 1.024211# 2 3 1.019752# 3 4 1.015269# 4 5 1.010769
Za svako \(\alpha\) od 1 do 360 praktično imamo polarne koordinate, \(\mathrm{c}_\alpha \mathrm{i} \alpha\). Da bi napravili plot, lakše je baratati sa pravouglim koordinatama, Slika 3.28.
# Kreiranje koordinata za crtanje pravih iz centralne tačkex <- c_values *sin(alfa_radians)y <- c_values *cos(alfa_radians)# Plotovanjeplot( x, y, type ="n", xlab ="21", ylab ="45", main ="Linearne razmere za različite azimute", axes =FALSE, asp =1)segments(0, 0, x, y, col ="blue")points(0, 0, pch =19, col ="red")
import numpy as npimport pandas as pd# Kreiranje koordinata za crtanje pravih iz centralne tačkex = c_values * np.sin(alfa_radians)y = c_values * np.cos(alfa_radians)# Plotovanjeplt.figure(figsize=(6, 6))plt.plot(x, y, 'bo', label='Tačke')plt.plot(0, 0, 'ro', label='Centralna tačka') # Centralna tačka (0, 0)plt.title('Linearne razmere za različite azimute')plt.xlabel('21')plt.ylabel('45')plt.gca().set_aspect('equal', adjustable='box') # Jednaka razmera po osamaplt.grid(True)plt.show()
Primer 7: Razmer i deformacija površina za Sinusoidnu projekciju za tačku 45,21
A=sqrt( (m^2+n^2+2*m*n*sin(teta) ) ) B =sqrt( (m^2+n^2-2*m*n*sin(teta) ) ) a=(A+B)/2b=(A-B)/2# Ispis rezultata options(digits =12)cat("Prvi glavni pravac a :", round(a,6) ,"Drugi glavni pravac b :", round(b,6))# Prvi glavni pravac a : 1.137945 Drugi glavni pravac b : 0.878777
Učiti (Slika 3.29) pod kojim uglom se seku glavni pravci.
import numpy as np# Izračunavanje vrednostiA = np.sqrt(m**2+ n**2+2* m * n * np.sin(teta))B = np.sqrt(m**2+ n**2-2* m * n * np.sin(teta))a = (A + B) /2b = (A - B) /2# Ispis rezultataprint(f"Prvi glavni pravac a: {a:.6f}")# Prvi glavni pravac a: 1.137945print(f"Drugi glavni pravac b: {b:.6f}")# Drugi glavni pravac b: 0.878777
Primer 9: Sračunati maksimalnu deformaciju uglova za Sinusoidnu projekciju za tačku 45,21
Maksimalna deformacija ugla je definisana formulom:
\[
\sin \frac{\omega}{2}=\frac{a-b}{a+b}=\sqrt{\frac{m^2+n^2-2 m n \sin \theta}{m^2+n^2+2 m n \sin \theta}}
\]
# Opšte jednačine kartografskih projekcija {#sec-proj}U narednom poglavlju predstavljeni su ključni koncepti kartografskog preslikavanja, praktično ovi koncepti se mogu primeniti na bilo koju konkretnu projekciju. Ovo poglavlje obuhvata sledeće celine:- Razmatranje parametarskih jednačina sfere i parametarskih jednačina elipsoida kako bismo bolje razumeli osnovne geometrijske modele kod funkcija kartografskog preslikavanja.- Gausove fundamentalne veličine koje su ključne za razumevanje neizbežnih deformacija koje prate kartografske projekcije prilikom preslikavanja krivolinijskih koordina u pravougle ravanske koordinate.- Proučavanje opšte teorije kartografskog preslikavanja kako bismo saznali kako se prostorni podaci transformišu sa trodimenzionalnog prostora na dvodimenzionalne karte.- Detaljan opis linijskog elementa u ravni karte, linearne razmere, razmere površina i deformacija uglova.- Koncept i računanja koja se odnose na elipsu deformacija, Tisoovu indikatrisu, pružajući uvid u karakteristike deformacija pri preslikavanju sa sfere ili elipsoida na ravne karte.- Podela projekcija prema karakteru deformacija, klasifikacija projekcija u odnosu na pomoćne projekcione površine i položaj pomoćnih projekcionih površina, kao i klasifikacija projekcija u odnosu na zone.Kroz ove celine čitaoci će razviti dublje razumevanje osnovnih koncepata kartografskog preslikavanja, što će im omogućiti da se upuste u izvođenje formula i razumevanje bilo koje konkretne kartografske projekcije koja se koristi u radu sa prostornim podacima.\index{parametrizacija sfere}## Parametarske jednačine sfereU prethodnom poglavlju smo diskutovali o parametrizaciji sfere, ovde ćemo još jednom ponoviti. Meridijani i paralele na sferi predstavljaju parametarske, tj. **koordinatne linije**, to je jedna od mogućih parametrizacija sfere. Pozicija bilo koje tačke na sferi može se definisati presekom **jednog meridijana i jedne paralele**. Kod slučaja kada smo imali ravan gde je bilo koja tačka određena presekom samo jedne *x* i samo jedne *y* koordinatne linije, to je slučaj regularne parametrizacije površi. Kod sfere imamo slučaj da postoje i **singularne tačke**, a to su polovi u kojima se sustiče svaki meridijan, a poluprečnik paralele u polovima je 0. Polovi nisu određeni presekom samo jedne paralele i samo jednog meridija, zato su to singularne tačke, pa i **parametrizacija sfere meridijanama i paralelama nije u potpunosti regularna parametrizacija površi**.Parametarske jednačine bilo koje površi zadaju se u obliku:$$F(X, Y, Z)=0$$Kod sfere imamo slučaj da je rastojanje bilo koje tačke od površi do centra sfere jednako poluprečniku sfere:$$F(X, Y, Z)=X^2+Y^2+Z^2-R^2=0$$Gde su pravougle koordinate definisane u odnosu na krivolinijiske, kao što je definisano u prethodnom poglavlju:$$\begin{aligned}& \mathrm{X}=\mathrm{R} \cos \varphi \cos \lambda \\& \mathrm{Y}=\mathrm{R} \cos \varphi \sin \lambda \\& \mathrm{Z}=\mathrm{R} \sin \varphi .\end{aligned}$$Parametarske linije se mogu definisati u opštem slučaju za sferu. Jednačina paralele definisana je parametarskim koordinatama tako da je parametar $\varphi$ konstantan, uzmimo da je označen sa $c1$.$$\begin{aligned}& X=X(c 1, \lambda) \\& Y=Y(c 1, \lambda) \\& Z=Z(c 1, \lambda)\end{aligned}$$Jednačina meridijana definisana je parametarskim koordinatama tako da je parametar $\lambda$ konstantan, uzmimo da je označen sa c2.$$\begin{aligned}& X=X(\varphi, c 2) \\& Y=Y(\varphi, c 2) \\& Z=Z(\varphi, c 2)\end{aligned}$$::: panel-tabset#### R```{r fig-pls, cache = FALSE, message = FALSE, echo=!knitr::is_latex_output()}#| fig.cap: "Parametarske linije na sferi."#| code-fold: true#| fig.height: 4# install.packages("plotly")library(plotly)R=6377# koristimo polarne sferne koordinate u je theta, v je fitheta <-seq(0, 2*pi, length.out =120)phi <-seq(0, pi, length.out =60)u <-outer(theta, phi, FUN =function(t, p) t)v <-outer(theta, phi, FUN =function(t, p) p)# površ sferexs <- R*cos(u) *sin(v)ys <- R*sin(u) *sin(v)zs <- R*cos(v)x <-c() ; y <-c(); z <-c()# kreiranje meridijana gde je jedan parametar konstantanfor (c1 in theta[seq(1, length(theta), by =10)]) { x <-c(x, R*cos(c1) *sin(phi), NA) # NA za kraj meridijana y <-c(y, R*sin(c1) *sin(phi), NA) z <-c(z, R*cos(phi), NA)}# kreiranje paralela gde je jedan parametar konstantanfor (c2 in phi[seq(1, length(phi), by =6)]) { x <-c(x, R*cos(theta) *sin(c2), NA) # NA za kraj paralele y <-c(y, R*sin(theta) *sin(c2), NA) z <-c(z, R*rep(cos(c2), length(theta)), NA)}fig <-plot_ly() %>%add_surface(x = xs, y = ys, z = zs, colorscale =list(c(0, '#ffffff'), c(1, '#ffffff')),showscale =FALSE, opacity =0.5) %>%add_trace(x = x, y = y, z = z, type ='scatter3d', mode ='lines',line =list(width =3, color ='rgb(10,10,10)'))fig <- fig %>%layout(scene =list(aspectratio =list(x =1, y =1, z =1)))fig```#### Python```{python}#| fig.cap: "Parametarske linije na sferi."#| code-fold: trueimport numpy as npimport matplotlib.pyplot as pltfrom mpl_toolkits.mplot3d import Axes3Ddef plot_sfera(radius=1, meridians=12, parallels=6): fig = plt.figure() ax = fig.add_subplot(111, projection='3d')# polarne sferne koordinate u = np.linspace(0, 2* np.pi, meridians) v = np.linspace(0, np.pi, parallels) x = radius * np.outer(np.cos(u), np.sin(v)) y = radius * np.outer(np.sin(u), np.sin(v)) z = radius * np.outer(np.ones(np.size(u)), np.cos(v))# sfere ax.plot_wireframe(x, y, z, color='b')# plot meridijanafor i inrange(meridians): ax.plot(x[i, :], y[i, :], z[i, :])# plot paralelafor j inrange(parallels): ax.plot(x[:, j], y[:, j], z[:, j]) ax.set_xlabel('X') ax.set_ylabel('Y') ax.set_zlabel('Z') ax.set_title('Parametarske linije na sferi')# prikaz plt.show()# plot (# može se napraviti plot i koristeći plotly iz Pythona)plot_sfera(radius=6377, meridians=12, parallels=6)```:::## Parametarske jednačine elipsoidaParametarske linije na elipsoidu definisane su kao kod sfere, i to su meridijani i paralele na elipsoidu. Jednačina elipsoida ima oblik:$$F(X, Y, Z)=X^2+Y^2+Z^2-N^2=0$$Gde su:$$\begin{aligned}& X=(N+h) \cos \varphi \cos \lambda \\& Y=(N+h) \cos \varphi \sin \lambda \\& Z=\left(N\left(1-e^2\right)+h\right) \sin \varphi\end{aligned}$$Poluprečnik krivine prvog vertikala:$$N(\varphi)=\frac{a}{\sqrt{1-e^2 \sin ^2 \varphi}}$$Prvi numerički ekscentricitet:$$e^2=\left(a^2-b^2\right) / a^2$$Jednačina paralele definisana je parametarskim koordinatama tako da je parametar $\varphi$ konstantan, uzmimo da je označen sa $c1$.$$\begin{aligned}& X=X(c 1, \lambda) \\& Y=Y(c 1, \lambda) \\& Z=Z(c 1, \lambda)\end{aligned}$$Jednačina meridijana definisana je parametarskim koordinatama tako da je parametar $\lambda$ konstantan, uzmimo da je označen sa c2.$$\begin{aligned}& X=X(\varphi, c 2) \\& Y=Y(\varphi, c 2) \\& Z=Z(\varphi, c 2)\end{aligned}$$## Gausove fundamentalne veličine {#sec-gfv}Ako je tačka A definisana koordinatama (X,Y,Z), @fig-elgfv. Uočimo tačku C koja je veoma bliska tački A, i definisana je koordinatama X+ΔX, Y+ΔY, Z+ΔZ. Ako smatramo da su A i C vrlo bliske tačke, možemo da zanemarimo zakrivljenost elipsoida i dužinu možemo da sračunamo kao pravu u prostoru.```{r fig-elgfv, out.width='70%', , fig.align = "center", out.extra = '', fig.cap='Elementarni (beskonačno mali) elipsoidni trapez..', echo=FALSE}knitr::include_graphics('images/ds.png')```Onda je dužina AC:$$A C^2=(X+\Delta X-X)^2+(Y+\Delta Y-Y)^2+(Z+\Delta Z-Z)^2$$ Odnosno :$$A C^2=\Delta X^2+\Delta Y^2+\Delta Z^2$$Ako pretpostavimo da su tačke na neizmerno malom rastojanju onda je jasno da veličinu $ds$ možemo izraziti kao:$$d s^2=d X^2+d Y^2+d Z^2$$ Uzmimo da je u pitanju bilo koja površ koja ima parametarske linije $\varphi$ i $\lambda$, @fig-povrsgfv, onda se svaka pravougla koordinata može definisati kao funkcija od parametarskih koordinata:```{r fig-povrsgfv, out.width='70%', , fig.align = "center", out.extra = '', fig.cap='Bilo koja površ paramerizovana krivolinijskim koordinatama, recimo longitutom i latitudom.', echo=FALSE}knitr::include_graphics('images/BiloKojaPovrs.png')```$$\begin{aligned}& X=x(\varphi, \lambda) \\& Y=y(\varphi, \lambda) \\& Z=z(\varphi, \lambda)\end{aligned}$$Diferencijali su onda:$$\mathrm{dX}=\frac{\partial(x(\varphi, \lambda))}{\partial \varphi} \mathrm{d} \varphi+\frac{\partial(x(\varphi, \lambda))}{\partial \lambda} \mathrm{d} \lambda$$$$d Y=\frac{\partial(y(\varphi, \lambda))}{\partial \varphi} d \varphi+\frac{\partial(y(\varphi, \lambda))}{\partial \lambda} d \lambda$$$$\mathrm{dZ}=\frac{\partial(z(\varphi, \lambda))}{\partial \varphi} \mathrm{d} \varphi+\frac{\partial(z(\varphi, \lambda))}{\partial \lambda} \mathrm{d} \lambda$$ Ako bi se dX, dY i dZ uvrstile u izraz $d s^2=d X^2+d Y^2+d Z^2$, dobijamo dugačak izraz koji se skraćeno može zapisati:$$d s^2=e d \varphi^2+2 f d \varphi d \lambda+g d \lambda^2$$ Veličine e, f i g se nazivaju Gausove fundamentalne veličine$$\mathrm{e}=\left(\frac{\partial(x(\varphi, \lambda))}{\partial \varphi}\right)^2+\left(\frac{\partial(y(\varphi, \lambda))}{\partial \varphi}\right)^2+\left(\frac{\partial(z(\varphi, \lambda))}{\partial \varphi}\right)^2$$$$f=\frac{\partial(x(\varphi, \lambda))}{\partial \varphi} \frac{\partial(x(\varphi, \lambda))}{\partial \lambda}+\frac{\partial(y(\varphi, \lambda))}{\partial \varphi} \frac{\partial(y(\varphi, \lambda))}{\partial \lambda}+\frac{\partial(z(\varphi, \lambda))}{\partial \varphi} \frac{\partial(z(\varphi, \lambda))}{\partial \lambda}$$$$g=\left(\frac{\partial(x(\varphi, \lambda))}{\partial \lambda}\right)^2+\left(\frac{\partial(y(\varphi, \lambda))}{\partial \lambda}\right)^2+\left(\frac{\partial(z(\varphi, \lambda))}{\partial \lambda}\right)^2$$### Gausove fundamentalne veličine za elipsoidZa nemerljivo mala rastojanja (rastojanja teže nuli) trougao ADC, @fig-GFVel, možemo smatrati ravnim.```{r fig-GFVel, out.width='60%', , fig.align = "center", out.extra = '', fig.cap='Beskonačno mali elipsoidni trapez.', echo=FALSE}knitr::include_graphics('images/GFVel.png')```Meridijani i paralele se seku pod pravim uglom, tako da je:$$\mathrm{ds}^2=(\mathrm{Md} \varphi)^2+(N \cos \varphi \mathrm{d} \lambda)^2$$$$\begin{aligned}& \mathrm{e}=\mathrm{M}^2 \\& \mathrm{f}=0 \\& \mathrm{g}=(N \cos \varphi)^2\end{aligned}$$## Opšta teorija kartografskog preslikavanjaZa kartografsko preslikavanje između originalne i projekcione površi koriste se neke matematičke funkcije preslikavanja koje preslikavaju tačke, linije i poligone sa elipsoida na ravan. Svakoj tački sa elipsoida odgovara samo jedna tačka u projekciji i obratno. Sa slike, (@fig-presl), može se uočiti da se tačka A preslikala u tačku A', tačka B u B', tačka C u C' i konačno tačka D u D'. Pored toga, vidimo da u projekciji imamo sliku meridijana i paralela koji su preslikani u opštem slučaju kao krive linije.```{r fig-presl, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Ilustracija kartografskog preslikavanja sa elipsoida na ravan karte, sa elipsoidnih krivolinijskih u pravougle koordinate u ravni.', echo=FALSE}knitr::include_graphics('images/Preslikavanje.png')```Funkcije kartografskog preslikavanja imaju oblik:$$E= y = f_{1}(\varphi,\lambda)$$$$N = x = f_{2}(\varphi,\lambda)$$Ili za inverzni zadatak:$$\varphi = g_{1}(E,N)$$$$\lambda= g_{2}(E,N)$$Funkcije kartografskog preslikavanja moraju da zadovolje sledeće uslove:- funkcije preslikavanja su obostrano jednoznačne,- da su neprekidne sa izvodima 1. i 2. reda,- Jakobijan različit od nule u svakoj tački.Formula za Jakobijan u opštem slučaju je:$$J_F(M)=\left(\begin{array}{ccc}\frac{\partial f_1}{\partial x_1} & \cdots & \frac{\partial f_1}{\partial x_n} \\\vdots & \ddots & \vdots \\\frac{\partial f_m}{\partial x_1} & \cdots & \frac{\partial f_m}{\partial x_n}\end{array}\right)$$### Linijski element u ravni karteSledeća slika je verovatno najznačajnija kod opšte teorije kartografskog preslikavanja zato što mnoge veličine u pogledu preslikavanja sa elipsoida na ravan zaključujemo polazeći od preslikavanja elementarnog tapeza ABCD na ravan karte. Kao što smo ranije pominjali, tačke ovog trapeza su na infinitezimalnom rastojanju, teži beskonačno malom rastojanju, tako da se ovakav trapez može smatrati ravnim. Na slici (@fig-prER) su prikazane sledeće veličine koje dosad nisu pominjane. Azimut „α“ na elipsoidu utvrđuje položaj pravaca, a meri se počev od meridijana tačke u pravcu kazaljke na časovniku,odnosno od severa na istok, jug i zapad. *A* je azimut u projekciji, isprekidane linije su tangente na odgovarajuće krive u ravni. Ugao $\theta$ je ugao između meridijana i paralele u projekciji. Na elipsoidu se meridijani i paralele seku pod pravim uglom, dok se u projekciji seku pod uglom $\theta$, a samo kod konformnih projekcija pod pravim uglom. Treba napomenuti da je zakrivljenost meridijana i paralela na beskonačno malom trapezu u ravni projekcije zanimarljiva, ali je ovde istaknuta zbog razumevanja procesa kartografskog preslikavanja.```{r fig-prER, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Preslikavanje infinitezimalnog trapeza sa elipsoida na ravan karte.', echo=FALSE}knitr::include_graphics('images/prTR.png')```Vratimo se na opšte jednačine kartografskog preslikavanja:$$\begin{aligned}& y=\text { Eeasting }=f_1(\varphi, \lambda)=y(\varphi, \lambda) \\& x=\text { Northing }=f_2(\varphi, \lambda)=x(\varphi, \lambda)\end{aligned}$$Dužina dS u ravni može se sračunati koristeći Gausove fundamentalne veličine, već smo napomenuli i ranije da one mogu da važe za bilo koju površ, pa i ravan u kojoj su pravougle koordinate funkcije od krivolinijskih.$$d\mathrm{S}^2=\mathrm{Ed} \varphi^2+2 \mathrm{Fd} \varphi \mathrm{d} \lambda+\mathrm{Gd} \lambda^2$$Gde su E, F i G Gausove fundamentalne veličine za ravan, a pravougle koordinate su funkcije od krivolinijskih elipsoidnih koordinata.$$\mathrm{E}=\left(\frac{\partial(x(\varphi, \lambda))}{\partial \varphi}\right)^2+\left(\frac{\partial(y(\varphi, \lambda))}{\partial \varphi}\right)^2$$$$\mathrm{F}=\frac{\partial(x(\varphi, \lambda))}{\partial \varphi} \frac{\partial(x(\varphi, \lambda))}{\partial \lambda}+\frac{\partial(y(\varphi, \lambda))}{\partial \varphi} \frac{\partial(y(\varphi, \lambda))}{\partial \lambda}$$$$\mathrm{G}=\left(\frac{\partial(x(\varphi, \lambda))}{\partial \lambda}\right)^2+\left(\frac{\partial(y(\varphi, \lambda))}{\partial \lambda}\right)^2$$Znači da sada za bilo koju kartografsku projekciju koja je zadata u obliku:$$ y=\text { Easting }=f_1(\varphi, \lambda)=y(\varphi, \lambda)$$ ,\$$ x=\text { Northing }=f_2(\varphi, \lambda)=x(\varphi, \lambda) $$možemo sračunati linijski element dS. Još jednom treba napomenuti da je kod konformnih projekcija, gde se meridijani i paralele seku pod pravim uglom, veličina F jednaka nuli.### Linearna razmera**Linearnim razmera** je granična vrednost (limes) odnosa beskonačno male duži u projekciji i odgovarajuće duži na površi Zemljinog elipsoida ili lopte. Stoga je, @fig-prER, formula za linearnu razmeru:$$\mathrm{c}=\lim _{A C \rightarrow 0}\left(\frac{A^{\prime} C^{\prime}}{A C}\right)=\frac{d S}{d s}$$ Ako kvadriramo levu i desnu stranu, koristeći Gausove fundamentalne veličine, imamo:$$c^2=\frac{E d \varphi^2+2 \mathrm{Fd} \varphi \mathrm{d} \lambda+\mathrm{Gd} \lambda^2}{(\mathrm{Md} \varphi)^2+(N \cos \varphi \mathrm{d} \lambda)^2}$$Uočimo sa slike (@fig-cl) da azimut pravca $ds$ možemo izraziti koristeći dužinu luka meridijana i paralele kod infinitezimalnog trapeza.```{r fig-cl, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Infinitezimalni trapez na elipsoidu.', echo=FALSE}knitr::include_graphics('images/calfa.png')```Tako da je:$$\tan \alpha=\frac{N \cos \varphi \mathrm{d} \lambda}{\operatorname{Md} \varphi}$$Odatle sledi da je:$$\frac{\mathrm{d} \lambda}{\mathrm{d} \varphi}=\frac{\mathrm{M} \tan \alpha}{N \cos \varphi}$$Dalje, ako jednačinu za kvadrat linearne razmere pomnožimo i podelimo sa $1/\mathrm{d}\varphi^2$ tada imamo:$$\mathrm{c}^2=\frac{\mathrm{Ed} \varphi^2+2 \mathrm{Fd} \varphi \mathrm{d} \lambda+\mathrm{Gd} \lambda^2}{(\mathrm{Md} \varphi)^2+(N \cos \varphi \mathrm{d} \lambda)^2} \frac{\frac{1}{\mathrm{~d} \varphi^2}}{\frac{1}{\mathrm{~d} \varphi^2}}=\frac{\mathrm{E}+2 \mathrm{~F} \frac{\mathrm{d} \lambda}{\mathrm{d} \varphi}+\mathrm{G}\left(\frac{\mathrm{d} \lambda}{\mathrm{d} \varphi}\right)^2}{\mathrm{M}^2+(N \cos \varphi)^2\left(\frac{\mathrm{d} \lambda}{\mathrm{d} \varphi}\right)^2}$$Zamenimo $\frac{\mathrm{d} \lambda}{\mathrm{d} \varphi}$ i dobijamo:$$\mathrm{c}^2=\frac{\mathrm{E}+2 \mathrm{~F} \frac{\mathrm{M} \tan \alpha}{N \cos \varphi}+\mathrm{G}\left(\frac{\mathrm{M} \tan \alpha}{N \cos \varphi}\right)^2}{\mathrm{M}^2+(N \cos \varphi)^2\left(\frac{\mathrm{M} \tan \alpha}{N \cos \varphi}\right)^2}$$ili:$$\mathrm{c}^2=\frac{\mathrm{E}+2 \mathrm{~F} \frac{\mathrm{M} \tan \alpha}{N \operatorname{cos} \varphi}+\mathrm{G}\left(\frac{\mathrm{M} \tan \alpha}{N \cos \varphi}\right)^2}{\mathrm{M}^2\left(1+\tan ^2 \alpha\right)}$$Već odavde je jasno da je linearna razmera funkcija koja zavisi od **pozicije tačke i azimuta pravca**$$c=c(\varphi, \lambda, \alpha)$$**Dakle, u opštem slučaju na svakoj poziciji na karti linearna razmera ima drugu vrednost. Na samoj poziciji u različitim pravcima ima različite vrednosti.**Primenom trigonometrijske formule:$$\sin (2 \alpha)=2 \sin \alpha \cos \alpha= (\sin \alpha +\cos \alpha)^2 - 1 =\frac{2 \tan \alpha}{1+\tan ^2 \alpha}$$i sređivanjem izraza došlo bi se do konačne formule za linearnu razmeru u opštem slučaju.$$\mathrm{c}^2=\frac{E}{M^2} \cos ^2 \alpha+\frac{F}{M N \cos \varphi} \sin 2 \alpha+\frac{G}{(N \cos \varphi)^2} \sin ^2 \alpha$$Odstupanje razmere od 1 naziva se linearnom deformacijom ili deformacijom dužina ($dc$):$$dc=c-1$$#### Linearna razmera u pravcu meridijana i paralele {#sec-mn}Uočimo sa slike (@fig-prER) da je linearna razmera u pravcu meridijana (m):$$m=\frac{\sqrt{E}}{M}$$ Ovo smo mogli dobiti i računajući preko opšte formule, azimut se meri od meridijana, jasno je da je od tačke A u pravcu meridijana azimut 0, @fig-prER.$$\mathrm{c}_{\mathrm{m}}^2=m^2=\frac{E}{M^2} \cos ^2 0+\frac{F}{M N \cos \varphi} \sin 0+\frac{G}{(N \cos \varphi)^2} \sin ^2 0$$Slično sa slike (@fig-prER) jasno je da je linearna razmera u pravcu paralele:$$n=\frac{\sqrt{G}}{N \cos \varphi}$$ Ili, ako bismo zamenili u formuli za azimut 90 stepeni imali bismo izvođenje za linearnu razmeru u pravcu paralele:$$\mathrm{c}_{\mathrm{n}}{ }^2=n^2=\frac{E}{M^2} \cos ^2 90+\frac{F}{M N \cos \varphi} \sin 180+\frac{G}{(N \cos \varphi)^2} \sin ^2 90$$#### Linearna razmera kao funkcija m i nAko uočimo sliku trapeza na elipsoidu koji teži da bude beskonačno mali, njegova slika na karti je beskonačno mali paralelogram, gde za tako mali element slike meridijana i paralele možemo smatrati pravim linijama u okviru paralelograma, @fig-cmn.```{r fig-cmn, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Infinitezimalni trapez na elipsoidu i njegova slika u ravni za izvođenje formule za linearnu razmeru u funkciji m i n.', echo=FALSE}knitr::include_graphics('images/cmnkos.png')```Tada linijski element možemo sračunati koristeći kosinusnu teoremu i onda imamo:$$\mathrm{d} \mathrm{S}^2=\mathrm{Ed} \varphi^2-2 \sqrt{E G} \cos (180-\theta)+\mathrm{G} \mathrm{d} \lambda^2$$dalje je:$$\mathrm{dS}{ }^2=\mathrm{Ed} \varphi^2+2 \sqrt{E G} \cos (\theta)+\mathrm{G} \mathrm{d} \lambda^2$$Ako se vratimo na isti element izražen koristeći Gausove fundamentalne veličine:$$\mathrm{d} \mathrm{S}^2=\mathrm{Ed} \varphi^2+2 \mathrm{Fd} \varphi \mathrm{d} \lambda+\mathrm{Gd} \lambda^2$$ Možemo videti da su kvadratni članovi isti, tako da mora biti isti i mešoviti član, pa dalje imamo da je kosinus ugla između meridijana i paralele u projekciji:$$\cos (\theta)=\frac{\mathrm{F}}{\sqrt{E G}}$$Odavde dalje možemo sračunati i F kao:$$F=\sqrt{E G} \cos (\theta)$$ Zamenimo F u opštoj formuli za linearnu razmeru $\mathrm{c}^2=\frac{E}{M^2} \cos ^2 \alpha+\frac{F}{M N \cos \varphi} \sin 2 \alpha+\frac{G}{(N \cos \varphi)^2} \sin ^2 \alpha$ i dobijamo:$$\mathrm{c}^2=\frac{E}{M^2} \cos ^2 \alpha+\frac{\sqrt{E G} \cos (\theta)}{M N \cos \varphi} \sin 2 \alpha+\frac{G}{(N \cos \varphi)^2} \sin ^2 \alpha$$Ako se vratimo na formulu za linearnu razmeru u pravcu meridijana:$$m=\frac{\sqrt{E}}{M}$$i paralele:$$n=\frac{\sqrt{G}}{N \cos \varphi}$$Tada dobijamo konačnu formulu za linearnu razmeru u finkciji linearne razmere u pravcu meridijana i paralele:$$\mathrm{c}^2=m^2 \cos ^2 \alpha+m n \cos (\theta) \sin 2 \alpha+n^2 \sin ^2 \alpha$$#### Glavni pravciPravci u kojima linearna razmera dostiže ekstremnu vrednost nazivaju se glavni pravci$$\mathrm{c}^2=\frac{E}{M^2} \cos ^2 \alpha+\frac{F}{M N \cos \varphi} \sin 2 \alpha+\frac{G}{(N \cos \varphi)^2} \sin ^2 \alpha$$Ako uvedemo zamenu (R,P,Q) za elemente koji ne zavise od azimuta, formula je:$$c^2=R \cos ^2 \alpha+P \sin 2 \alpha+Q \sin ^2 \alpha$$$$\frac{\partial c}{\partial \alpha}=-2 \mathrm{R} \cos \alpha \sin \alpha+2 \mathrm{P} \cos 2 \alpha+2 \mathrm{Q} \sin \alpha \cos \alpha$$$$\frac{\partial c}{\partial \alpha}=2 \mathrm{P} \cos 2 \alpha+2(\mathrm{Q}-\mathrm{R}) \sin \alpha \cos \alpha$$$$\frac{\partial c}{\partial \alpha}=2 \mathrm{P} \cos 2 \alpha+(\mathrm{Q}-\mathrm{R}) \sin 2 \alpha$$Ekstremne vrednosti linearne razmere su u pravcima u kojim je prvi izvod 0.$$\frac{\partial c}{\partial \alpha}=2 \mathrm{P} \cos 2 \alpha_0+(\mathrm{Q}-\mathrm{R}) \sin 2 \alpha_0=0$$Ako izraz podelimo sa $\cos 2 \alpha_0$$$\begin{aligned}& 2 \mathrm{P}+(\mathrm{Q}-\mathrm{R}) \tan 2 \alpha_0=0 \\& \tan 2 \alpha_0=\frac{2 P}{R-Q}\end{aligned}$$::: callout-tip#### Funkcija tangensa```{r fig-kombr, out.width='60%' , fig.align = "center", out.extra = '', fig.cap='Tangensna funkcija, (<https://sh.wikipedia.org/wiki/Tangens#/media/Datoteka:Tan.svg>).', echo=FALSE}knitr::include_graphics('images/tan.png')```:::Pošto je period tangensa jednak $180^o$ , jednačina ima 2 rešenja: jedno će biti $\alpha_0$, a drugo $\alpha_0+90$. Prema tome, glavni pravci se na originalnoj površi seku pod uglom od $90^o$.Rešenja su oblika: $$\alpha_0 \text { i } \alpha_0+90^o$$Glavni pravci su upravni jedan na drugi, seku se pod pravim uglom, i u projekciji (ravni karte) i na površi (elipsoidu ili lopti) su ortogonalni (upravni). Zaključak je da: uvek postoje samo dva upravna pravca na elipsoidu koji će se preslikati na karti kao ortogonalni (upravni) i imaće ekstremnu vrednost linearne razmere. Pravac u kom je linearna razmera najveća naziva se **prvi glavni pravac i obično se obeležava slovom a**. Pravac u kom je linearna razmera najmanja naziva se **drugi glavni pravac i obično se obeležava slovom b**.### Razmer površina {#sec-razpov}Odnos površina odgovarajućih elementarnih figura na slici i originalnoj površi naziva se razmer površina, @fig-cmn. Površina beskonačno malog trapeza na elipsoidu je:$$\mathrm{dp}=\mathrm{MN} \cos \varphi \mathrm{d} \lambda \mathrm{d} \varphi$$ U ravni karte ako posmatramo slike: @fig-cmn, @fig-p,```{r fig-p, out.width='50%', , fig.align = "center", out.extra = '', fig.cap='Površina elemantarnog paralelograma u ravni karte.', echo=FALSE}knitr::include_graphics('images/p.png')```možemo zaključiti da je površina odgovarajućeg paralelograma:$$\mathrm{dP}=\sqrt{G} \mathrm{~d} \lambda \sqrt{E} \mathrm{~d} \varphi \sin (\theta)$$ U delu kod računanja linerane razmere u funkciji m i n smo videli da je:$$\cos (\theta)=\frac{\mathrm{F}}{\sqrt{E G}}$$Koristeći trigonometrijske osobine sinusa i kosinusa imamo:$$\begin{aligned}& \sin ^2(\theta)=1-\cos ^2(\theta) \\& \sin ^2(\theta)=1-\frac{F^2}{E G}=\frac{E G-F^2}{E G} \\& \sin (\theta)=\sqrt{\frac{E G-F^2}{E G}}=\frac{H}{\sqrt{E G}} \\&\end{aligned}$$Tako da imamo dalje, ako sa H ozačimo $H= \sqrt{E G-F^2}$, da je:$$\mathrm{dP}=\sqrt{G} \mathrm{~d} \lambda \sqrt{E} \mathrm{~d} \varphi \sin (\theta)=\sqrt{E G} \frac{H}{\sqrt{E G}} \mathrm{~d} \lambda \mathrm{d} \varphi$$I konačno imamo:$$\mathrm{dP}=H \mathrm{~d} \lambda \mathrm{d} \varphi$$Formula za razmer površina je:$$p=\frac{\mathrm{dP}}{\mathrm{dp}}=\frac{\mathrm{Hd} \lambda \mathrm{d} \varphi}{\mathrm{MN} \cos \varphi \mathrm{d} \lambda \mathrm{d} \varphi}=\frac{\mathrm{H}}{\mathrm{MN} \cos \varphi}$$Pošto je $\sin (\theta)=\frac{H}{\sqrt{E G}}$, onda je i $\mathrm{H}=\sqrt{E G} \sin (\theta)$ tada formula ima oblik:$$p=\frac{\sqrt{E G} \sin (\theta) \mathrm{d} \lambda \mathrm{d} \varphi}{\mathrm{MN} \cos \varphi \mathrm{d} \lambda \mathrm{d} \varphi}=\mathrm{mn} \sin (\theta)$$Ranije smo videli da je $m=\frac{\sqrt{E}}{M}$ i $n=\frac{\sqrt{G}}{N \cos \varphi}$.Deformacija površina je definisana izrazom koji pokazuje koliko se one deformišu u odnosu na preslikavanje koje nema deformacija površina, tj. gde je *p*=1:$$d p=p-1$$### Deformacije uglovaU procesu kartografskog preslikavanja ne deformišu se samo dužine i površine nego i uglovi. Da bi izvođenje bilo jednostavnije, pretpostavićemo da se koordinatne ose poklapaju sa glavnim pravcima (izvođenje se može primeniti i u opštem slučaju). Uočimo beskonačno mali krug na elipsoidu, @fig-defu, postavimo pravougli koordinatni sistem X,Y čija je slika pravougli koordinatni sistem u ravni koji se poklapa sa glavnim pravcima a i b, a koordinatne ose su označene kao $x,y$. Imamo da je slika beskonačno malog kruga **elipsa (elipsa deformacija ili Tisoova idikatrisa)**. Videli smo da je u opštem slučaja linearna razmera različita u različitim pravcima, imaju dva upravna glavna pravca u kojim ona dostiže ekstremne vrednosti a i b, razmera u pravcu paralele je n i u pravcu meridijana je m. Azimut glavnog pravca na elipsoidu je označen sa $\alpha$, dok je ugao $\beta$ direkcioni ugao tačke T sa elementarnog kruga u odnosu na koordinatni sistem postavljen na elipsoidu ($X,Y$). Tačka T se preslikava u tačku T' koja ima direkcioni ugao B, a azimut glavnog pravca je označen sa A u ravni projekcije.```{r fig-defu, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Deformacija uglova.', echo=FALSE}knitr::include_graphics('images/defu.png')```Deformacija ugla predstavlja razliku ugla na elipsoidu i ugla u ravni (projekciji), obeležava se sa $du$ ili $\omega/2$$$\omega / 2=\beta-B$$Sa slike možemo odrediti glavne pravce kao:$$a=\frac{x}{X}, b=\frac{y}{Y}$$Zato što su koordinate tačke T u pravcu $x$ i $y$ infinitezimalne dužine u pravcu glavnih pravaca, koje su slika odgovarajućih $X$ i $Y$ dužina sa elipsoida. Dalje imamo:$$\frac{y}{x}=\frac{b Y}{a X}$$ Pošto je $\frac{y}{x}$ u stvari nagib pravca tačke T', a $\frac{Y}{X}$ nagib pravca tačke T, imamo:$$\tan B =\frac{b}{a} \tan \beta$$Uočimo izraz$$\frac{\sin (\beta-B)}{\sin (\beta+B)}=\frac{\sin \beta \cos B-\cos \beta \sin B}{\sin \beta \cos B+\cos \beta \sin B}$$Podelimo brojilac i imenilac sa desne strane izraza sa $cos \beta cos B$:$$\frac{\sin (\beta-B)}{\sin (\beta+B)}=\frac{\operatorname{tan} \beta-\frac{b}{a} \operatorname{tan} \beta}{\operatorname{tan} \beta+\frac{b}{a} \operatorname{tan} \beta}=\frac{a-b}{a+b}$$Odakle konačno dobijamo:$$\sin (\beta-B)=\frac{a-b}{a+b} \sin (B+\beta)$$ Nas zanima maksimalna deformacija uglova u okolini posmatrane tačke. Pošto a i b imaju konstantne vrednosti u zadatoj tački karte, očigledno je da će razlika $(\beta-B)=du=\omega/2$ dostići maksimalan iznos kada je $sin (\beta+B)=1$, odnosno kada je zbir uglova $(\beta+B)=90^o$.$$\sin (\beta-B)=\frac{a-b}{a+b}$$$$\sin \frac{\omega}{2}=\frac{a-b}{a+b}$$U litaraturi, npr. @jovanovic84, mogu se naći i sledeći izrazi za maksimalnu deformaciju uglova:$$\cos \frac{\omega}{2}=\sqrt{1-\sin ^2 \frac{\omega}{2}}=\frac{2 \sqrt{a b}}{a+b}$$ $$\operatorname{tan} \frac{\omega}{2}=\frac{\sin \frac{\omega}{2}}{\cos \frac{\omega}{2}}=\frac{a-b}{2 \sqrt{a b}}$$$$\operatorname{tan} \frac{\omega}{4}=\sqrt{\frac{1-\cos \frac{\omega}{2}}{1+\cos \frac{\omega}{2}}}=\frac{\sqrt{a}-\sqrt{b}}{\sqrt{a}-\sqrt{b}}$$$$\operatorname{tan}\left(45^0+\frac{\omega}{4}\right)=\frac{1+\operatorname{tan} \frac{\omega}{4}}{1-\operatorname{tan} \frac{\omega}{4}}=\sqrt{\frac{a}{b}}$$$$\operatorname{tan}\left(45^{\circ}-\frac{\omega}{4}\right)=\frac{1-\operatorname{tan} \frac{\omega}{4}}{1+\operatorname{tan} \frac{\omega}{4}}=\sqrt{\frac{a}{b}}$$$$\sin \frac{\omega}{2}=\frac{a-b}{a+b}=\sqrt{\frac{m^2+n^2-2 m n \sin \theta}{m^2+n^2+2 m n \sin \theta}}=\sqrt{\frac{m^2+n^2-2 m n \cos \varepsilon}{m^2+n^2+2 m n \cos \varepsilon}}$$$$\operatorname{tan} \frac{\omega}{2}=\frac{a-b}{2 \sqrt{a b}}=\frac{a-b}{2 \sqrt{p}}$$$$\operatorname{tan} \frac{\omega}{2}=\frac{1}{2} \sqrt{\frac{m^2+n^2-2 m n \sin \theta}{m n \sin \theta}}=\frac{1}{2} \sqrt{\frac{m^2+n^2-2 m n \cos \varepsilon}{m n \cos \varepsilon}}$$Gde je $\varepsilon = \theta -90$, odstupanje ugla između meridijana i paralele u projekciji od pravog ugla.## Elipsa deformacija (Tisoova indikatrisa)Francuski geograf i matematičar Tiso, razmatrajući deformacije koje nastaju pri preslikavanju dvostruko zakrivljene površi Zemlje na ravan, došao je do veoma značajnih zaključaka za matematičku kartografiju.Teorija deformacija po Tisou, u osnovi, objašnjava da se elementarni krug sa površi elipsoida, načelno uzimajući, preslikava na ravan kao elipsa, osim u specijalnom slučaju ako su obe površi (ili njihovi delovi) međusobno paralelne, u kom slučaju će krug ostati krug željenog razmera.Razmotrimo slučaj da se postavi dvodimenzionalni koordinatni sistem na elipsoidu tako da se poklapa sa pravcima meridijana i paralele, i da se iz ishodišta kreira infinitezimalni krug, @fig-eldef1.```{r fig-eldef1, out.width='80%', , fig.align = "center", out.extra = '', fig.cap=' Infinitezimalni krug na elipsoidu i odgovarajuće preslikavanje u ravni pravca OT.', echo=FALSE}knitr::include_graphics('images/eldef1.png')```Možemo uočiti element $ds$:$$\mathrm{d} X^2+\mathrm{d} Y^2=\mathrm{d} s^2$$ Linearna razmera u pravcu meridijana:$$\frac{O^{\prime} \cdot P^{\prime}}{O P}=\frac{\mathrm{d} x}{\mathrm{~d} X}=m$$Linearna razmera u pravcu paralele:$$\frac{O^{\prime} \cdot Q^{\prime}}{O Q}=\frac{\mathrm{d} y}{\mathrm{~d} Y}=n$$ Ako linijski element na elipsoidu izrazimo koristeći koordinate iz ravni projekcije imamo:$$\frac{\mathrm{d} x^2}{m^2}+\frac{\mathrm{d} y^2}{n^2}=\mathrm{d} s^2$$Potom izraz možemo podeliti sa $\mathrm{d} s^2$ i dobijammo:$$\frac{\mathrm{d} x^2}{m^2 \mathrm{~d} s^2}+\frac{\mathrm{d} y^2}{n^2 \mathrm{~d} s^2}=1$$ Uočavamo da navedena formula predstavlja formulu elipse, pri čemu su $m ds$ i $n ds$ tzv. spregnuti (konjugovani) dijametri elipse. Svaki par međusobno upravnih dijametara kruga preslikava kao par konjugovanih dijametara elipse. U opštem slučaju vidimo da se elemantarni krug se preslikava u elipsu, Tisoovu indikatrisu. **Tisoova indikatrisa nam pokazuje karakteristike deformacija u okolini posmatrane tačke, sa nje uočavamo veličine deformacija i to: deformacije uglova (oblika), dužina i površina.**Uzmimo da je ds=1, neka jedinična vrednost, tada imamo:$$\frac{\mathrm{d} x^2}{m^2}+\frac{\mathrm{d} y^2}{n^2}=1$$Ako su koordinate (postavljene kroz centar elementarnog kruga, @fig-eldef2) na elipsoidu ujedno i glavni pravci, drugim rečima, ako mreža meridijana i paralela ostaje ortogonalna i u projekciji, onda će, uz uslov da se prvi glavni pravac poklapa sa meridijanom, biti: m=a i n=b, i tada sledi da je:$$\frac{\mathrm{d} x^2}{a^2}+\frac{\mathrm{d} y^2}{b^2}=1$$```{r fig-eldef2, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Elipsa deformacija kada se glavni pravci poklapaju sa koordinatnim sistemom definisanim u centru infinitezimalnog kruga.', echo=FALSE}knitr::include_graphics('images/eldef2.png')```Apolonijeve teoreme nam mogu pomoći pri određivanju vrednosti prvog i drugog glavnog pravca ($a$ i $b$) i konstruisanju elipse deformacija. Prema prvoj teoremi, suma kvadrata spregnutih dijametara elipse jednaka je sumi kvadrata njenih poluosa:$$a^2+b^2=m^2+n^2$$Druga Apolonijeva teorema glasi: površina tangentnog paralelograma elipse nad njenim dijametrima jednaka je konstanti, odnosno površini tangentnog paralelograma nad poluosama elipse, tj.:$$a \cdot b=m \cdot n \cdot \sin \theta$$Na osnovu Apolonijevih teorema imamo:$$\begin{aligned}& a^2+b^2=m^2+n^2 \\& a \cdot b=m \cdot n \cdot \sin \theta\end{aligned}$$Ako drugi izraz pomnožimo sa minus dva i saberemo sa prvim dobićemo:$$\begin{aligned}&(a+b)^2=m^2+n^2+2 m n \sin \theta\\\end{aligned}$$ Ako drugi izraz pomonožimo sa minus dva i saberemo sa prvim dobićemo:$$\begin{aligned}&(a-b)^2=m^2+n^2-2 m n \sin \theta\end{aligned}$$Jasno je da onda imamo:$$\begin{aligned}&A=(a+b)=\sqrt{m^2+n^2+2 m n \sin \theta}\\&B=(a-b)=\sqrt{m^2+n^2-2 m n \sin \theta}\end{aligned}$$Dakle veličine A i B možemo sračunati ako znamo linearnu razmeru u pravcu paralele, u pravcu meridijana i ugao između meridijana i paralele, sve ove veličine, tj. njihove formule, ranije smo izveli. Dalje, ako znamo vrednost za A i B, možemo sračunati vrednosti za prvi i drugi glavni pravac:$$\begin{aligned}&a=\frac{A+B}{2}\\&b=\frac{A-B}{2}\end{aligned}$$Ako je mreža meridijana i paralela u projekciji ortogonalna, onda je $\theta= 90^o$, tada je:$$\begin{aligned}&a+\mathrm{b}=\mathrm{m}+\mathrm{n}\\&a-\mathrm{b}=\mathrm{m}-\mathrm{n}\end{aligned}$$Imamo da je $a=m$, $b= n$, ili obrnuto.Kod konformnih projekcija mreža meridijana i paralela je ortogonalna, jer je ortogonalna i na origanalnoj površi kod sfere ili elipsoida (nema deformacija uglova). Kod konformnih projekcija elipsa deformacija je krug jer nema deformacija oblika. Uslov konformnosti možemo formulisati tako da je u okolini posmatrane tačke linearna razmera u svim pravcima ista.### Elipsa deformacija konstrukcija@fig-eldefk prikazuje postupak konstrukcije elipse deformacija, slika je podeljena na 5 koraka da bi se lakše pratio tok konstrukcije. Ako znamo linearnu razmeru u pravcu meridijana ($m$) i paralele ($n$), kao i ugao između meridijana i paralele ($\theta$), možemo konstruisati elipsu deformacija.```{r fig-eldefk, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Konstrukcija elipse deformacija.', echo=FALSE}knitr::include_graphics('images/eldefk.png')```Dokaz za postupak za grafičku konstrukciju elipse deformacija započinjemo kosinusnom teoremom za trougao CON, @fig-eldefcon.```{r fig-eldefcon, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Konstrukcija elipse deformacija, trougao CON.', echo=FALSE}knitr::include_graphics('images/eldefk2.png')```Kosinusna teorema za trougao CON$$C N^2=m^2+n^2-2 m n \cos (90-\theta)$$$$C N^2=m^2+n^2-2 m n \sin (\theta)$$Kosinusna teorema za trougao DON$$D N^2=m^2+n^2-2 m n \cos (90+\theta)$$$$D N^2=m^2+n^2+2 m n \sin (\theta)$$Ako se vratimo na Apolonijevu teoremu i uporedimo sa dobijenim$$A=(a+b)=\mathrm{DN}=\sqrt{m^2+n^2+2 m n \sin \theta}$$$$B=(a-b)=\mathrm{CN}=\sqrt{m^2+n^2-2 m n \sin \theta}$$Uočimo da je trougao DCN sličan trouglu DOE, paralelni kraci i pripadajući uglovi, očigledno da je OD = DC/2, tako da važi:$$\begin{aligned}& \mathrm{OE}=\mathrm{CN} / 2=(a-b) / 2 \\& \mathrm{DE}=\mathrm{DN} / 2=(a+b) / 2\end{aligned}$$Treba zapaziti da je $EK = EL = EO$ jer je to poluprečnik malog kruga sa centrom u E, poluprečnik kruga je $EO$. Tačke $L$ i $K$ su dobijene presekom tog kruga sa pravom $DN$. Pravac velikih poluosa je definisan pravcima $OL$ i $OK$. Grafički se mogu preuzeti i vrednosti za veliku i malu poluosu elipse:$$\mathrm{DK}=\mathrm{DE}+\mathrm{EL}(\text { isto je kao OE) }=(\mathrm{a}+\mathrm{b}) / 2+(\mathrm{a}-\mathrm{b}) / 2=\mathrm{a}$$$$D L=D E-E L(\text { isto je kao OE })=(a+b) / 2-(a-b) / 2=b$$Pošto elipse deformacija pokazuju prostiranje deformacija u bilo kojoj tački od interesa vrlo se često koriste da sagledamo prostiranje deformacija kod neke projekcije. Besplatan softver [flexprojector](https://www.flexprojector.com/) može se koristiti za pregled rasporeda deformacija kod raznih projekcija koje se koriste za globalno kartiranje planete Zemlje, @fig-flex.```{r fig-flex, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Sinusoidna ekvivalenta projekcija sa Tisoovim indikatrisama.', echo=FALSE}knitr::include_graphics('images/sinflex.png')```### Elipsa deformacija alternativni načinKao što smo videli u predhodnom poglavlju R softversko okruženje u okviru paketa `s2` i `sf` ima implementirane algoritme za računanja na elipsoidu ili sferi, isto tako u okviru implementacije `PROJ` biblioteke moguće je izvršavati direktni i inverzni zadatak, kao i koordinatne transformacije.Dakle, ako kreiramo konačne krugove na elipsoidu (@fig-geel) i onda ih transformišemo u neku projekciju, dobićemo elipse deformacija. Ovde treba napomenuti da strogo gledano postupak nije ispravan jer ne koristimo krugove čiji poluprečnik teži nuli, ali suštinski dobijamo prostiranje deformacija na skoro isti način kao da kostruišemo elipse deformacija na gore opisan način [@gimond2019intro].```{r echo=!knitr::is_latex_output(), message = FALSE, warning = FALSE}library(sf)sf_use_s2(TRUE) # koristi sferna racunanja# kreiramo tačke u kojima cemo prikazati elipse deformacijalonlat =rbind(c(19,42), c(19,44), c(19,46),c(20,42), c(20,44), c(20,46),c(21,42), c(21,44), c(21,46),c(22,42), c(22,44), c(22,46) )tissot.pt <-st_sfc( st_multipoint(lonlat), crs =4326) # WGS84 koordinatni ref. sis.tissot.pt <-st_cast(tissot.pt, "POINT") # konvertujemo u single point geometriju# plot(tissot.pt)# koristi se s2 paket za elipsodna računanja# Pravimo tacke po krugu udaljene 30 km od centra elipsetissot.sf =st_buffer(tissot.pt, dist =30000, max_cells =1000)# max_cells# The maximum number of cells to approximate a buffer.# nrow(st_coordinates(tissot.sf[1]))# [1] 646# Ako koristimo opciju max_cell = 1000 imamo 646 prelomnih tačaka poligona# konvertujemo kolekciju poligona u sf objekattissot.sf <-st_sf(tissot.sf)# Sračunajmo površinu svakog kruga na elipsoidutissot.sf$a <-st_area(tissot.sf)# plotKML::plotKML(tissot.sf)``````{r fig-geel, out.width='80%', , fig.align = "center", out.extra = '', fig.cap='Krugovi poluprečnika 30 km na WGS84.', echo=FALSE}knitr::include_graphics('images/geel.jpg')```Ako transformišemo krugove u Merkatorovu projekciju, dobićemo elipse deformacija u Merkatorovoj projekciji, za svaku elipsu izrazićemo i razmer površina. Uz pomenuti prikaz ćemo kartirati i granice opština u Srbiji.```{r fig-merel, cache = TRUE, message = FALSE, warning = FALSE, echo=!knitr::is_latex_output(), dev='ragg_png'}#| fig.cap: "Elipse deformacija Merkatorova projekcija."#| code-fold: false#| fig.height: 8tissot.merc <-st_transform(tissot.sf, "+proj=merc +ellps=WGS84")# površine u projekcijitissot.merc$a_proj <-st_area(tissot.merc)# odnos površina u projekciji i na elipsoidutissot.merc$p <- tissot.merc$a_proj/tissot.merc$a# granice opština u Srbif (file.exists('data/pop.gml') ){ pop =st_read('data/pop.gml') }else{ url=paste('http://osgl.grf.bg.ac.rs/geoserver/osgl_4/wfs','?service=WFS&version=1.0.0&','request=GetFeature&typeName=osgl_4:POP_age',sep='')download.file(url, 'pop.gml') pop =st_read('pop.gml')}# podaci su u WGS84st_crs(pop) =4326pop =st_transform(pop, "+proj=merc +ellps=WGS84")ll =st_centroid(tissot.merc)ll =st_coordinates(ll)# Karta sa elipsama deformacija i razmerom površinaplot(st_geometry(pop), graticule =TRUE, border ='grey', axes =TRUE)plot(st_geometry(tissot.merc), border ='red', add =TRUE)text(ll[, 1], ll[, 2], paste("p=",round(tissot.merc$p,3)) , cex =0.8)```Kao što vidimo sa slike (@fig-merel) u Merkatorovoj projekciji površine na severu Srbije deformišu se duplo. U UTM projekciji koja je takođe konformna, površine se znatno manje deformišu, @fig-utmel, to je i razlog zašto se koristi kao državna projekcija u skoro svim zemljama Evrope. Još jednom treba napomenuti da je razmer površina sračunat približno koristeći odnose površina konačnih figura. Razmere površina su sračunate po formulama koje ćemo razraditi u poglavlju koje se odnosi na UTM projekciju.```{r fig-utmel, cache = TRUE, message = FALSE, warning = FALSE, echo=!knitr::is_latex_output(), dev='ragg_png'}#| fig.cap: "Elipse deformacija UTM projekcija."#| code-fold: false#| fig.height: 8tissot.utm <-st_transform(tissot.sf, "+proj=utm +zone=34 +ellps=GRS80")# površine u projekcijitissot.utm$a_proj <-st_area(tissot.utm)# računanje linearne razmere u UTMlr <-function(lonlatmatrica){ l= (lonlatmatrica[,1] -21)*pi/180 fi= (lonlatmatrica[,2])*pi/180# GRS80 a=6378137.0 rf=298.257222101 GRS 1980(IUGG, 1980) a=6378137.0 rf=298.257222101 f =1/rf e =sqrt(2*f - f^2) e1 =sqrt( (2*f - f^2)*(1- f)^-2 ) t=tan(fi) eta=e1*cos(fi) C1=1/2*(1+eta^2)*(cos(fi))^2 C2=1/24*(5-4*t^2)*(cos(fi))^4# linerarna razmera (u R-u se uglavnom ne koristi c kao promenljiva) cc=0.9996*(1+C1*l^2+C2*l^4) return(cc)}# linerarna deformacija u dm/kmtissot.utm$p <- (lr(lonlat)) ^2# tissot.utm$p <- tissot.utm$a_proj/tissot.utm$apop =st_transform(pop, "+proj=utm +zone=34 +ellps=GRS80")ll =st_centroid(tissot.utm)ll =st_coordinates(ll)# Karta sa elipsama deformacija i razmerom površinaplot(st_geometry(pop), graticule =TRUE, border ='grey', axes =TRUE)plot(st_geometry(tissot.utm), border ='red', add =TRUE)text(ll[, 1], ll[, 2], paste("p=",round(tissot.utm$p,4)) , cex =0.8)```Kod Sinusoidne projekcije površine se ne deformišu jer je ona ekvivalentna, ali se deformišu oblici, @fig-sinel. Još jednom treba napomenuti da je razmer površina sračunat približno koristeći odnose površina konačnih figura, pa kod ove projekcije nije 1 jer nije sračunat po formuli za razmer površina. Kao što možemo primetiti, kod Sinusoidne projekcije imamo slučaj da presek između meridijana i paralela nije prav ugao.```{r fig-sinel, cache = TRUE, message = FALSE, warning = FALSE, echo=!knitr::is_latex_output(), dev='ragg_png'}#| fig.cap: "Elipse deformacija Sinusoidna projekcija."#| code-fold: false#| fig.height: 8tissot.sin <-st_transform(tissot.sf,"+proj=sinu +ellps=WGS84")# površine u projekcijitissot.sin$a_proj <-st_area(tissot.sin)# odnos površina u projekciji i na elipsoidutissot.sin$p <- tissot.sin$a_proj/tissot.sin$apop =st_transform(pop, "+proj=sinu +ellps=WGS84")ll =st_centroid(tissot.sin)ll =st_coordinates(ll)# Karta sa elipsama deformacija i razmerom površinaplot(st_geometry(pop), graticule =TRUE, border ='grey', axes =TRUE)plot(st_geometry(tissot.sin), border ='red', add =TRUE)text(ll[, 1], ll[, 2], paste("p=",round(tissot.sin$p,1)) , cex =0.8)```## Podela projekcija prema karakteru deformacijaKao što smo videli, u opštem slučaju prilikom kartografskog preslikavanja deformišu se:- **DUŽINE,**- **POVRŠINE,**- **UGLOVI.**::: callout-tip#### U pogledu deformacija projekcije se dele na:- **konformne (istougle, lokalno nema deformacije uglova, tj oblika),**- **ekvivalente (istopovršinske) i**- **uslovne (proizvoljne).**:::U grupu uslovnih spadaju i **ekvidistantne**, gde u jednom pravcu nema deformacije dužina. Najčešće u jednom glavnom pravcu; ili u pravcu meridijana; ili u pravcu paralele.Projekcija uvek može pripadati samo jednoj grupi.### Konformne projekcijeOsim naziva konformne (istougle) projekcije, često se sreće i naziv ortomorfne projekcije, što znači da se ovim preslikavanjem obezbeđuje sličnost beskonačno malih figura ‒ tzv. lokalna sličnost.U bilo kojoj tački istouglog preslikavanja indikatrisa je krug, tj. linearna razmera ostaje ista u svim pravcima oko zadate tačke, što se može izraziti odnosom:$$a=b=m=n=c$$Ako se vratimo na formulu za deformaciju površina:$$p=\frac{\sqrt{E G} \sin (\theta) \mathrm{d} \lambda \mathrm{d} \varphi}{\mathrm{MN} \cos \varphi \mathrm{d} \lambda \mathrm{d} \varphi}=m n \sin (\theta)$$Kod konformnih projekcija ugao između meridijana i parale je \theta={90}^o, linearna ramera je ista u svim pravcima pa imamo:$$p=a^2=b^2=m^2=n^2=c^2$$### Istopovršinske (ekvivalentne projekcije)Ekvivalentne (homalografske) projekcije očuvavaju površine figura i zadovoljavaju uslov:$$p=a b=m n \sin \theta=m n \cos \varepsilon=1$$ Ako je razmer površine jednak jedinici u svakoj tački u ravni projekcije, onda i konačne površine ostaju očuvane i nema deformacije površina konačnih geometrijskih entiteta.### Uslovne projekcijeKod ovih projekcija postoje istovremeno i deformacije uglova i deformacije površina. Ipak, iz veoma velike grupe uslovnih (proizvoljnih) projekcija izdvaja se grupa tzv. ekvidistantnih (istodužinskih) projekcija, kod kojih je linearan razmer uzduž jednog od glavnih pravaca konstantan i jednak jedinici, tj. ili a=1, ili b=1, kod ovih projekcija vrlo često se taj glavni pravac poklapa sa pravcem meridijana ili paralele.## Klasifikacija projekcija u odnosu na pomoćne projekcione površiZemljin elipsoid (ili lopta) ne samo da se preslikava direktno na ravan već se, ponekad, zamišljeno preslikava na bočne površi konusa ili cilindra, koje se zatim razvijaju u ravan, @fig-pompov.a. Cilindrične,b. Konusne ic. Azimutne.```{r fig-pompov, out.width='80%' , fig.align = "center", out.extra = '', fig.cap='Klasifikacija projekcija u odnosu na pomoćne projekcione površi. Izvor: <https://docs.qgis.org/3.28/en/_images/projection_families.png/>', echo=FALSE}knitr::include_graphics('images/projection_families.png')```## Klasifikacija projekcija u odnosu na položaj pomoćne projekcione površiPoložaj projekcionih površi iskazuje se, najočiglednije, položajem koji obrtne ose (cilindra ili konusa) zauzimaju u odnosu na obrtnu osu Zemlje, @fig-pompov2. Kod azimutnih projekcija normala, na ravan projekcije i elipsoid (loptu) u dodirnoj tački. Prema tome, projekcije se dele na:a. Normalne (prave),b. Poprečne (transferzalne) ic. Kose```{r fig-pompov2, out.width='40%' , fig.align = "center", out.extra = '', fig.cap='Klasifikacija projekcija u odnosu na položaj (orijentaciju) pomoćne projekcione površi.', echo=FALSE}knitr::include_graphics('images/polprpov.png')```## Klasifikacija projekcija u odnosu na zone**Jedinstvene projekcije**U ovom slučaju izrada karata za neko područje provodi se u jednom istom koordinatnom sistemu u ravni (npr. Merkatorova projekcija koju smo pominjali ranije (konformna), Sinusoidna (ekvivalentna), ili Robinsonova projekcija (ekvivalenta), @fig-merj).```{r fig-merj, cache = TRUE, message = FALSE, warning = FALSE, echo=!knitr::is_latex_output(), dev='ragg_png'}#| fig.cap: "Robinsonova projekcija, jedinstvena globalna projekcija."#| code-fold: false#| fig.height: 6library(sf)library(spData)data(world)granicaSRKS =st_union(world[173, 'geom' ], world[175,'geom'] )world[173, ]$geom = granicaSRKS$geomworld = world[-175,]world_r =st_transform(world, crs ="+proj=robin +lon_0=0 +x_0=0 +y_0=0 +ellps=WGS84 +datum=WGS84")plot(world_r["lifeExp"], graticule =TRUE, main ="Očekivani životni vek za rođene 2014.")```**Višezone (višepojasne ) projekcije**Kod krupnorazmernih karata da bismo održali zadani nivo tačnosti, područje preslikavanja delimo na zone (duž meridijana), ili pojaseve (duž paralela). (Npr. UTM projekcija, prikaz 60 UTM zona, @fig-utmzones.)```{r fig-utmzones, out.width='80%' , fig.align = "center", out.extra = '', fig.cap='UTM zone. Izvor: <https://snl.no/UTM>', echo=FALSE}knitr::include_graphics('images/utmZones.png')```**Višegrane projekcije**U ovom slučaju celokupno područje preslikavanja deli se linijama meridijana i paralela na odgovarajući broj sferoidnih ili sfernih trapeza. Svaki takav trapez preslikava se odvojeno u projekciji usvojenoj za celokupno područje preslikavanja. Svaki list karte je zaseban koordinatni sistem. (Modifikovana američka polikonusna projekcija, primer takve projekcije je i Nikolozi globular projekcija, koja je višegrana i deli ceo svet na 2 dela, @fig-NG)```{r fig-NG, out.width='80%' , fig.align = "center", out.extra = '', fig.cap='Nikolozi globular, višegrana projekcija sa dva prekida. Izvor: <https://w.wiki/6$qZ>', echo=FALSE}knitr::include_graphics('images/Nicolosi_globular_projections_SW.jpg')```**Prekinute projekcije**Ove se projekcije primenjuju za kartografisanje odvojenih delova Zemljine površi ‒ na primer, karte kontinenata ili vodenih površina, koje se spajaju po pravilu duž Ekvatora. Kartografska mreža prekinuta je duž odgovarajućih, unapred izabranih meridijana. Ponekad, štaviše, postoji ne samo jedan već nekoliko prekida mreže. (Gudeova (*Goode homolosine*) projekcija, @fig-Goode)```{r fig-Goode, out.width='80%' , fig.align = "center", out.extra = '', fig.cap='Gudeova projekcija sa prekidima. Izvor: <https://en.wikipedia.org/wiki/Goode_homolosine_projection>', echo=FALSE}knitr::include_graphics('images/Goode.jpg')```## Primeri računaja za Sinusoidnu projekciju preslikavanja sfere na ravanData je Sinusoidna projekcija formulama koja preslikava sferne koordina na ravan:$$\begin{gathered}E(\lambda, \phi)=y(\lambda, \phi)=R\left(\lambda-\lambda_0\right) \cos \phi \\N(\lambda, \phi)=x(\lambda, \phi)=R \phi\end{gathered}$$Srednji meridijan usvajamo da je Grinički $\lambda_0 = 0$ i $R=6377000$ m. ### Primer 1: Računanje koordinata jedne tačke, direktni zadatakSferne koordinate $\varphi=45$ i $\lambda=21$ sa sfere ($R=6377000$ m) transformisati u Sinusoidnu projekciju, @fig-SinPr.```{r fig-SinPr, out.width='80%' , fig.align = "center", out.extra = '', fig.cap='Direktni zadatak, Sinusoidna projekcija.', echo=FALSE}knitr::include_graphics('images/SinPr.png')```::: panel-tabset#### R```{r SinDZ, message=FALSE, warning=FALSE}# KonstanteR <-6377000# mlambda_0 <-0# Izabrani centralni meridijan# Koordinate na sferifi <-45# Latitudalambda <-21# Longituda# Stepeni u radijanefi_rad <- fi * pi /180lambda_rad <- lambda * pi /180lambda_0_rad <- lambda_0 * pi /180# Formule za sinusoidnu projekcijuEasting <- R * (lambda_rad - lambda_0_rad) *cos(fi_rad)Northing <- R * fi_rad# Ispis rezultataoptions(digits =12)cat("Easting:", round(Easting ,2) , " m , Northing:", round(Northing ,2), " m") ```#### Python```{python pSinDZ}import math# KonstanteR =6377000# Poluprečnik u metrimalambda_0 =0# Izabrani centralni meridijan u stepenima# Koordinate na sferifi =45# Latituda u stepenimalambda_ =21# Longituda u stepenima# Stepeni u radijanefi_rad = math.radians(fi)lambda_rad = math.radians(lambda_)lambda_0_rad = math.radians(lambda_0)# Formule za sinusoidnu projekcijuEasting = R * (lambda_rad - lambda_0_rad) * math.cos(fi_rad)Northing = R * fi_rad# Ispis rezultataprint(f"Easting: {round(Easting, 2)} m, Northing: {round(Northing, 2)} m")```:::### Primer 2: Izračunati Gausove fundamentalne veličine za tačku (45,21) u Sinusoidnoj projekcijiFinkcije preslikavanja su definisane izrazima:$$y = R (\lambda - \lambda_0) cos(\phi) $$$$x = R \phi $$Parcijalni izvodi su:$$\frac{\partial y}{\partial \phi} = -R (\lambda - \lambda_0) \sin(\phi) $$$$\frac{\partial x}{\partial \phi} = R$$$$\frac{\partial y}{\partial \lambda} = R \cos(\phi) $$$$ \frac{\partial x}{\partial \lambda} = 0 $$Gaussove fundamentalne veličine 1. reda: $$ E = \left(\frac{\partial x}{\partial \phi}\right)^2 + \left(\frac{\partial y}{\partial \phi}\right)^2 $$ $$ F = \left(\frac{\partial x}{\partial \phi}\right) \left(\frac{\partial x}{\partial \lambda}\right) + \left(\frac{\partial y}{\partial \phi}\right) \left(\frac{\partial y}{\partial \lambda}\right) $$ $$ G = \left(\frac{\partial x}{\partial \lambda}\right)^2 + \left(\frac{\partial y}{\partial \lambda}\right)^2 $$::: panel-tabset#### R```{r SinGF, message=FALSE, warning=FALSE}# Izvodi Sinusoidne projekcijedy_dphi <--R * (lambda_rad - lambda_0_rad) *sin(fi_rad)dx_dphi <- Rdy_dlambda <- R *cos(fi_rad)dx_dlambda <-0# Prva Gaussova fundamentalna veličina EE <- dx_dphi^2+ dy_dphi^2# Mešovita fundamentalna veličina FF <- dx_dphi * dx_dlambda + dy_dphi * dy_dlambda# Druga Gaussova fundamentalna veličina GG <- dx_dlambda^2+ dy_dlambda^2# Ispis rezultataoptions(digits =16)cat("Prve Gaussove fundamentalne veličine (E, F, G): \n")cat("E: ", E, " , ", "F: ", F , " , " , "G: ", G, "\n") ```#### Python```{python pSinGF}import math# KonstanteR =6377000# Poluprečnik Zemlje u metrimalambda_0_rad =0# Centralni meridijan u radijanimafi_rad = math.radians(45) # Latituda u radijanima (45 stepeni)lambda_rad = math.radians(21) # Longituda u radijanima (21 stepen)# Izvodi sinusoidne projekcijedy_dphi =-R * (lambda_rad - lambda_0_rad) * math.sin(fi_rad)dx_dphi = Rdy_dlambda = R * math.cos(fi_rad)dx_dlambda =0# Prva Gaussova fundamentalna veličina EE = dx_dphi**2+ dy_dphi**2# Mešovita fundamentalna veličina FF = dx_dphi * dx_dlambda + dy_dphi * dy_dlambda# Druga Gaussova fundamentalna veličina GG = dx_dlambda**2+ dy_dlambda**2# Ispis rezultataprint("Prve Gaussove fundamentalne veličine (E, F, G):")print(f"E: {E}, F: {F}, G: {G}")```:::### Primer 3: Izračunati linearnu razmeru u pravcu meridijana i paralele za tačku (45,21)Linearna razmera u pravcu meridijana (m) na elipsoidu je definisana izrazom:$$m=\frac{\sqrt{E}}{M}$$ Na sferi poluprečnik krivine meridijana je R, meridijani su veliki krugovi istog poluprečnika kao sfera, tako da je formula na sferi:$$m=\frac{\sqrt{E}}{R}$$ Linearna razmera u pravcu paralele na elipsoidu je:$$n=\frac{\sqrt{G}}{N \cos \varphi}$$ Na sferi poluprečnik krivine paralele je $R \cos \varphi$, tako da je formula na sferi:$$n=\frac{\sqrt{G}}{R \cos \varphi}$$ ::: panel-tabset#### R```{r Sinmn, message=FALSE, warning=FALSE}# Linerna razmera u meridijana za tačku (45,21)m =sqrt(E)/R# Linearna razmera u pravcu paralele za tačku (45,21) n =sqrt(G)/ (R*cos(fi_rad))# Ispis rezultataoptions(digits =12)cat("m:", round(m,6) , ", n:", round(n,6) )```#### Python```{python pSinmn}import math# Definisanje konstanti i prethodnih izračunaR =6377000# Poluprečnik Zemlje u metrimafi_rad =45* math.pi /180# Latituda u radijanima# Gaussove fundamentalne veličine E i GE = (-R * (lambda_rad - lambda_0_rad) * math.sin(fi_rad))**2+ R**2G = (R * math.cos(fi_rad))**2# Linearna razmera u meridijanu (m)m = math.sqrt(E) / R# Linearna razmera u pravcu paralele (n)n = math.sqrt(G) / (R * math.cos(fi_rad))# Ispis rezultataprint(f"m: {round(m, 6)}, n: {round(n, 6)}")```:::### Primer 4: Pod kojim uglom se seku meridijan i paralela na tački (45,21)?U delu kod računanja linerane razmere u funkciji m i n smo videli da je:$$\cos (\theta)=\frac{\mathrm{F}}{\sqrt{E G}}$$::: panel-tabset#### R```{r SinTeta, message=FALSE, warning=FALSE}teta =acos(F/sqrt(E*G))# Ispis rezultata u stepenimaoptions(digits =12)cat("Meridijan i paralela na tački (45,21) u Sin. prj se seku pod uglom :", round(teta*180/pi,6) )```#### Python```{python pSinTeta}import math# Izračunavanje ugla između meridijana i paraleleteta = math.acos(F / math.sqrt(E * G))# Ispis rezultata u stepenimaprint(f"Meridijan i paralela na tački (45,21) u Sin. prj se seku pod uglom: {round(teta *180/ math.pi, 6)}")```:::### Primer 5: Izračunati linearnu razmeru u pravcu azimuta od $30^o$ za tačku (45,21)Konačna formula za linearnu razmeru u opštem slučaju je:$$\mathrm{c}^2=m^2 \cos ^2 \alpha+m n \cos (\theta) \sin 2 \alpha+n^2 \sin ^2 \alpha$$::: panel-tabset#### R```{r Sin30, message=FALSE, warning=FALSE}alfa =30*pi/180c_30_sq <- m^2*cos(alfa)^2+ m * n *cos(teta) *sin(2*alfa) + n^2*sin(alfa)^2c_30 =sqrt(c_30_sq)# Ispis rezultataoptions(digits =12)cat("Linearna razmera u pravcu azimuta od 30 st. za tačku (45,21):", c_30, "\n")```#### Python```{python pSin30}import math# Azimut alfa u radijanimaalfa =30* math.pi /180# 30 stepeni u radijanima# Izračunavanje c_30c_30_sq = m**2* math.cos(alfa)**2+ m * n * math.cos(teta) * math.sin(2* alfa) + n**2* math.sin(alfa)**2c_30 = math.sqrt(c_30_sq)# Ispis rezultataprint(f"Linearna razmera u pravcu azimuta od 30 stepeni za tačku (45,21): {round(c_30, 6)}")```:::### Primer 6: Izračunati linearnu razmeru u pravcu svih azimuta od 1 do 360 stepeni za tačku (45,21) i napraviti grafikKonačna formula za linearnu razmeru u opštem slučaju je:$$\mathrm{c}^2=m^2 \cos ^2 \alpha+m n \cos (\theta) \sin 2 \alpha+n^2 \sin ^2 \alpha$$Treba izračunati linearnu razmeru za svako $\alpha$, savaki azimut pravca, od 1 do 360 stepeni i dobiti 360 vrednosti linearne razmere.::: panel-tabset#### R```{r Sin360, message=FALSE, warning=FALSE}# Kreiranje azimuta od 1 do 360 stepeniazimuti <-seq(1, 360, by =1)alfa_radians <- azimuti * pi /180# U radijane# Izračunavanje linearne razmere za svaki azimutc_values <-sqrt(m^2*cos(alfa_radians)^2+ m * n *cos(teta) *sin(2*alfa_radians) + n^2*sin(alfa_radians)^2)# Ispis rezultataoptions(digits =12)head(data.frame(Alfa=azimuti,c=round(c_values,6) ) )```#### Python```{python pSin360}import numpy as npimport pandas as pd# Kreiranje azimuta od 1 do 360 stepeniazimuti = np.arange(1, 361, 1)alfa_radians = np.radians(azimuti) # Azimuti u radijanima# Izračunavanje linearne razmere za svaki azimutc_values = np.sqrt(m**2* np.cos(alfa_radians)**2+ m * n * np.cos(teta) * np.sin(2* alfa_radians) + n**2* np.sin(alfa_radians)**2)# Kreiranje DataFrame-a sa rezultatimadf = pd.DataFrame({'Alfa': azimuti, 'c': np.round(c_values, 6)})# Ispis prvih nekoliko vrednostiprint(df.head())```:::Za svako $\alpha$ od 1 do 360 praktično imamo polarne koordinate, $\mathrm{c}_\alpha \mathrm{i} \alpha$. Da bi napravili plot, lakše je baratati sa pravouglim koordinatama, @fig-SinELPOL.```{r fig-SinELPOL, out.width='60%' , fig.align = "center", out.extra = '', fig.cap='Polarne i pravougle koordinate koordinate za numeričko kreiranje elipse deformacija.', echo=FALSE}knitr::include_graphics('images/ELPOL.png')```::: panel-tabset#### R```{r Sin360g, message=FALSE, warning=FALSE}# Kreiranje koordinata za crtanje pravih iz centralne tačkex <- c_values *sin(alfa_radians)y <- c_values *cos(alfa_radians)# Plotovanjeplot( x, y, type ="n", xlab ="21", ylab ="45", main ="Linearne razmere za različite azimute", axes =FALSE, asp =1)segments(0, 0, x, y, col ="blue")points(0, 0, pch =19, col ="red")```#### Python```{python pSin360g}import numpy as npimport pandas as pd# Kreiranje koordinata za crtanje pravih iz centralne tačkex = c_values * np.sin(alfa_radians)y = c_values * np.cos(alfa_radians)# Plotovanjeplt.figure(figsize=(6, 6))plt.plot(x, y, 'bo', label='Tačke')plt.plot(0, 0, 'ro', label='Centralna tačka') # Centralna tačka (0, 0)plt.title('Linearne razmere za različite azimute')plt.xlabel('21')plt.ylabel('45')plt.gca().set_aspect('equal', adjustable='box') # Jednaka razmera po osamaplt.grid(True)plt.show()```:::### Primer 7: Razmer i deformacija površina za Sinusoidnu projekciju za tačku 45,21Razmer površina je definisan izrazom:$$p=m n \sin (\theta)$$::: panel-tabset#### R```{r Sinp, message=FALSE, warning=FALSE}p = m* n *sin(teta)cat("p:", p)# Deformacija površinadp = p -1# 0```#### Python```{python pSinp}import numpy as np# Izračunavanje pp = m * n * np.sin(teta)print("p:", p)# Deformacija površinadp = p -1# 0```:::### Primer 8: Glavni parvi za Sinusoidnu projekciju za tačku 45,21Glavni pravci su definisani izrazima:$$A=\sqrt{m^2+n^2+2 m n \sin \theta}, $$$$B=\sqrt{m^2+n^2-2 m n \sin \theta}$$$$a=\frac{A+B}{2}$$$$b=\frac{A-B}{2}$$::: panel-tabset#### R```{r SinGP, message=FALSE, warning=FALSE}A=sqrt( (m^2+n^2+2*m*n*sin(teta) ) ) B =sqrt( (m^2+n^2-2*m*n*sin(teta) ) ) a=(A+B)/2b=(A-B)/2# Ispis rezultata options(digits =12)cat("Prvi glavni pravac a :", round(a,6) ,"Drugi glavni pravac b :", round(b,6))```Učiti (@fig-ElGlPR) pod kojim uglom se seku glavni pravci.```{r fig-ElGlPR, out.width='90%' , fig.align = "center", out.extra = '', fig.cap='Glavni pravci i elipsa deformacija, Sinusoidna projekcija za poziciju 45,21.', echo=FALSE}knitr::include_graphics('images/GLPELIPSA.png')```#### Python```{python pSinGP}import numpy as np# Izračunavanje vrednostiA = np.sqrt(m**2+ n**2+2* m * n * np.sin(teta))B = np.sqrt(m**2+ n**2-2* m * n * np.sin(teta))a = (A + B) /2b = (A - B) /2# Ispis rezultataprint(f"Prvi glavni pravac a: {a:.6f}")print(f"Drugi glavni pravac b: {b:.6f}")```:::### Primer 9: Sračunati maksimalnu deformaciju uglova za Sinusoidnu projekciju za tačku 45,21Maksimalna deformacija ugla je definisana formulom:$$\sin \frac{\omega}{2}=\frac{a-b}{a+b}=\sqrt{\frac{m^2+n^2-2 m n \sin \theta}{m^2+n^2+2 m n \sin \theta}}$$::: panel-tabset#### R```{r SinOM, message=FALSE, warning=FALSE}## Max. deformacija uglova na 45,21sin_OmegaPola =sqrt( (m^2+n^2-2*m*n*sin(teta) ) / (m^2+n^2+2*m*n*sin(teta) ) )OmegaPola =asin(sin_OmegaPola)# Ispis rezultata options(digits =12)cat("Maksimalna deformacija ugla je :", round(2*OmegaPola *180/pi,6) , "stepeni" )```#### Python```{python pSinOM}import numpy as np# Izračunavanje maksimalne deformacije uglasin_OmegaPola = np.sqrt((m**2+ n**2-2* m * n * np.sin(teta)) / (m**2+ n**2+2* m * n * np.sin(teta)))OmegaPola = np.arcsin(sin_OmegaPola)# Ispis rezultataprint(f"Maksimalna deformacija ugla je: {2* OmegaPola *180/ np.pi:.6f} stepeni")```:::<!-- Dodati slike za parametarske linije kod sfere ili elipsoida, ako treba jos koja slika --><!-- https://mgimond.github.io/Spatial/coordinate-systems-in-r.html#creating-tissot-indicatrix-circles --><!-- https://mgimond.github.io/tissot/ --><!-- test --><!-- quarto render document.qmd --to html --><!-- quarto render document.qmd --to pdf --><!-- quarto render index.qmd --to docx --><!-- library(quarto) --><!-- quarto_render("document.qmd") # defaults to html --><!-- quarto_render("document.qmd", output_format = "pdf") -->