# Golang : How to calculate the distance between two coordinates using Haversine formula

Tags : golang earth-radius distance haversine coordinates

I need to develop a service that calculate the distances of my current location to several points nearby. Each of the locations are represented by coordinates and my service will pick the 3 nearest points and select one of them. So, how to calculate the distances of my current location to each and every points?

Below is a simple example using the Haversine formula to calculate the distance between 2 coordinates.

Here you go!

```
package main
import (
"fmt"
"math"
)
type Coordinates struct {
Latitude float64
Longitude float64
}
const radius = 6371 // Earth's mean radius in kilometers
func degrees2radians(degrees float64) float64 {
return degrees * math.Pi / 180
}
func (origin Coordinates) Distance(destination Coordinates) float64 {
degreesLat := degrees2radians(destination.Latitude - origin.Latitude)
degreesLong := degrees2radians(destination.Longitude - origin.Longitude)
a := (math.Sin(degreesLat/2)*math.Sin(degreesLat/2) +
math.Cos(degrees2radians(origin.Latitude))*
math.Cos(degrees2radians(destination.Latitude))*math.Sin(degreesLong/2)*
math.Sin(degreesLong/2))
c := 2 * math.Atan2(math.Sqrt(a), math.Sqrt(1-a))
d := radius * c
return d
}
func main() {
pointA := Coordinates{2.990353, 101.533913}
pointB := Coordinates{2.960148, 101.577888}
fmt.Println("Point A : ", pointA)
fmt.Println("Point B : ", pointB)
distance := pointA.Distance(pointB)
fmt.Printf("The distance from point A to point B is %.2f kilometers.\n", distance)
}
```

Sample output:

Point A : {2.990353 101.533913}

Point B : {2.960148 101.577888}

The distance from point A to point B is 5.93 kilometers.

References :

#### See also : Golang : Find location by IP address and display with Google Map

Tags : golang earth-radius distance haversine coordinates

##### By Adam Ng(黃武俊)

IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.

#### Advertisement

#### Tutorials

+4.7k Golang : Convert string slice to struct and access with reflect example

+9.3k Golang : XML to JSON example

+1.9k Fix yum-complete-transaction error

+8.8k Golang : Count number of digits from given integer value

685 Java : Get FX sentiment from website example

+5.2k Golang : Transform comma separated string to slice example

+1.7k Golang : Send data to /dev/null a.k.a blackhole with ioutil.Discard

+8.2k Facebook PHP getUser() returns 0

+2.7k Golang : Not able to grep log.Println() output

+11.7k Golang : How to check if a date is within certain range?

+1.8k Javascript : Put image into Chrome browser's console

+3.1k Golang : Shuffle strings array