j2000-w84
This commit is contained in:
31
calculator/wgs84.go
Normal file
31
calculator/wgs84.go
Normal file
@@ -0,0 +1,31 @@
|
||||
package calculator
|
||||
|
||||
import "math"
|
||||
|
||||
func WGS84XYZtoLatLngH(X, Y, Z float64) (float64, float64, float64) {
|
||||
return ECEFToGeodetic(X, Y, Z)
|
||||
}
|
||||
|
||||
// Function to convert ECEF (ITRS) coordinates to geodetic coordinates (latitude, longitude, height)
|
||||
func ECEFToGeodetic(X, Y, Z float64) (float64, float64, float64) {
|
||||
b := a * (1 - f)
|
||||
e2Prime := e2 * (a * a) / (b * b)
|
||||
p := math.Sqrt(X*X + Y*Y)
|
||||
theta := math.Atan2(Z*a, p*b)
|
||||
|
||||
// Calculate Longitude
|
||||
longitude := math.Atan2(Y, X)
|
||||
|
||||
// Calculate Latitude
|
||||
latitude := math.Atan2(Z+e2Prime*b*math.Pow(math.Sin(theta), 3), p-e2*a*math.Pow(math.Cos(theta), 3))
|
||||
|
||||
// Calculate Height
|
||||
N := a / math.Sqrt(1-e2*math.Pow(math.Sin(latitude), 2))
|
||||
height := p/math.Cos(latitude) - N
|
||||
|
||||
// Convert radians to degrees for latitude and longitude
|
||||
latitudeDeg := latitude * 180 / math.Pi
|
||||
longitudeDeg := longitude * 180 / math.Pi
|
||||
|
||||
return latitudeDeg, longitudeDeg, height
|
||||
}
|
||||
Reference in New Issue
Block a user