turn on suggestions

Auto-suggest helps you quickly narrow down your search results by suggesting possible matches as you type.

Showing results for

- JMP User Community
- :
- Discussions
- :
- Distance Calculation using Latitude and Longitude

Topic Options

- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jun 27, 2016 6:05 AM
(2567 views)

Does anyone has idea how to calculate the distance between states in the US using either zip code or latitude and longitude?

Jenkins Macedo

6 ACCEPTED SOLUTIONS

Accepted Solutions

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Solution

why not start here?

and here

or just check my attached script for another option using a formula.

ron

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jun 27, 2016 7:21 AM
(2823 views)

Solution

Great! Thanks ron_horne. I initially started using tjhe Geocoder-Map. But I also see that I had SDA. I also downloaded the Distance Tool. All pretty cool. What I am trying to do is pretty simple and straight forward. Using the location by City and State- (zip code/ geographic coordinates) of our programs and the zip code of households in our databases. I am developing a simple file which shows programs that are under 50 miles of their residence compare to those that are 100 miles and proposed to the campaign team 2 to 3 programs that are either within an hour or two drive for a routine email marketing campaign based on their previous interests.

Jenkins Macedo

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jun 30, 2016 11:56 AM
(2824 views)

Solution

Hi ron_horne I tried using you "Distance to next" script to calculate the distance between two pairs of Lat and Long coordinates, but the script isn't working or maybe I am not doing something right. Attached is the first 20 rows of the table table. I would like to know the distance (in miles) between HH Lat and HH Long to PS Lat and PS long. I think once I can get the formula fitted to my data, it can be faster. I am not so sure how the Distance Tool would work here as I am wondering if I have to draw a line for each coordinate as that would take too much time as my table has over 2 million rows or can that be automated. I used the Mapping: JMP Geocoder to generate the coordinates below. How would you ron_horne or some else customize these in Distance to next script posted previously? Any help would be appreciated. Thanks

Some information of the below variables:

Zip Code: is the matched household (HH) to the Progra Start Zip Code (PS).

Program Number: these numbers reflect programs we offer for which we would like to promote to those households within the same program-to-household zip code.

HH Latitude: Latitude associated with the Household zip code

HH Longitude: Longitude associated with the Household Zip Code

PS Latitude: Latitude associated with program start zip code. That is the location where the program started.

PS Longitude: Longitude associated with the program start zip code. That is the location where the program started.

Jenkins Macedo

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jun 30, 2016 1:02 PM
(2822 views)

Solution

hi jenkins.macedo,

my original script calculated the distance between two consecutive rows in kilometers.

i have now amended it to produce the miles distance for each row.

try this on your table

Clear Globals**()**;

Names Default To Here**(** **1** **)**;

// reference the data table

dt = current data table**()**;

// introduce the column with the distance to be updated in the dots table

dt << **add multiple columns(** "Distance", **1**, after**(** **6** **)**, numeric **)**;

// extract the longitude and the latitude values from the table - as radians

HHx = **(**Column**(** dt, "HH Longitude" **)** << **getValues)** * Pi**()** / **180** ;

HHy = **(**Column**(** dt, "HH Latitude" **)** << **getValues)** * Pi**()** / **180** ;

PSx = **(**Column**(** dt, "PS Longitude" **)** << **getValues)** * Pi**()** / **180** ;

PSy = **(**Column**(** dt, "PS Latitude" **)** << **getValues)** * Pi**()** / **180** ;

// declare the calculation function in Miles

haversine = Function**(** **{**long1, lat1, long2, lat2, R = **6371}**,

**{**Default Local**}**,

a = Sin**(** **(**lat1 - lat2**)** / **2** **)** ^ **2** + Cos**(** lat1 **)** * Cos**(** lat2 **)** * Sin**(** **(**long1 - long2**)** / **2** **)** ^ **2**;

c = **2** * ATan**(** a ^ **0.5**, **(****1** - a**)** ^ **0.5** **)**;

d = **(**R * c**)*****0.6213712**;// miles

**)**;

wait **(****0.01)**;

// run the function along the rows of the table

For**(** i = **1**, i <= N Row**(** dt **)** - **1**, i++,

dt:distance**[**i**]** = haversine**(** HHx**[**i**]**, HHy**[**i**]**, PSx**[**i**]**, PSy**[**i**]** **)**

**)**;

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jul 1, 2016 4:51 AM
(2821 views)

Solution

Thanks ron_horne. I will let you know the outcome once I tried it. But I think it looks great! Big tx

Jenkins Macedo

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Aug 24, 2017 2:05 PM
(1301 views)

Solution

Hi ron_horne and I hope you are doing well. I know this has taken some time since we last chatted on this thread. The project was put on hold and it is now up and running and in about few weeks, the resulting table will be deployed in production by our campaign team.

I did apply the script and it worked perfectly as expected!! Great job!!

As you know the script calculates the distance between pairs of (HH Lat. and HH Long.) to (PS Lat and PS Long.), which is what was originally what the project was designed to capture. I have used the resulting distance to calculate the time that it will take for each household to attend one of our program that is 1, 3, or 5 hours away from their homes.

Now, the issue is that I would like to script to calculate the distance between each pair of Lat. and Long.

For example:

In the table below, I have computed the distance and time between row 1 pairs of Lat. & Long. Which is perfect!! that will do for all 20 rows giving 20 unique distances between household location to the destination of the program.

So, in row 1 the program # 15896 with PS Lat. 56.47 N & PS Long. 132.38 S is certain distance away from the Household whose HH Lat. & HH Long.

Since we want to know the distance of each household from each program #, how can I calculate, such that, JMP captures the distance between each household Lat and Long acrosss each Program Lat and Long and not just the first program? In this table, I have 20 rows, using what I have described we should have 400 difference distance calculation instead of just 20. Do you know a way to go around this?

My original HH Data Table has 156,737 Unique households records with their respective HH Lat. & HH Long. The Household file has 15,655 unique HH Lat. & HH Long.

The Program Data Table with 2,747 Unique Program #s with 329 unique PS Lat. & PS Long. I want to calculate the distance from each unique household Lat. & Long to each unique Program Lat. & Long., such that, the distance is calculated across each program. That will be 15,655 *329 and the resulting table or the total distance should be about 5,150,495 records.

Jenkins Macedo

6 REPLIES

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

why not start here?

and here

or just check my attached script for another option using a formula.

ron

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jun 27, 2016 7:21 AM
(2824 views)

Great! Thanks ron_horne. I initially started using tjhe Geocoder-Map. But I also see that I had SDA. I also downloaded the Distance Tool. All pretty cool. What I am trying to do is pretty simple and straight forward. Using the location by City and State- (zip code/ geographic coordinates) of our programs and the zip code of households in our databases. I am developing a simple file which shows programs that are under 50 miles of their residence compare to those that are 100 miles and proposed to the campaign team 2 to 3 programs that are either within an hour or two drive for a routine email marketing campaign based on their previous interests.

Jenkins Macedo

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jun 30, 2016 11:56 AM
(2825 views)

Hi ron_horne I tried using you "Distance to next" script to calculate the distance between two pairs of Lat and Long coordinates, but the script isn't working or maybe I am not doing something right. Attached is the first 20 rows of the table table. I would like to know the distance (in miles) between HH Lat and HH Long to PS Lat and PS long. I think once I can get the formula fitted to my data, it can be faster. I am not so sure how the Distance Tool would work here as I am wondering if I have to draw a line for each coordinate as that would take too much time as my table has over 2 million rows or can that be automated. I used the Mapping: JMP Geocoder to generate the coordinates below. How would you ron_horne or some else customize these in Distance to next script posted previously? Any help would be appreciated. Thanks

Some information of the below variables:

Zip Code: is the matched household (HH) to the Progra Start Zip Code (PS).

Program Number: these numbers reflect programs we offer for which we would like to promote to those households within the same program-to-household zip code.

HH Latitude: Latitude associated with the Household zip code

HH Longitude: Longitude associated with the Household Zip Code

PS Latitude: Latitude associated with program start zip code. That is the location where the program started.

PS Longitude: Longitude associated with the program start zip code. That is the location where the program started.

Jenkins Macedo

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jun 30, 2016 1:02 PM
(2823 views)

hi jenkins.macedo,

my original script calculated the distance between two consecutive rows in kilometers.

i have now amended it to produce the miles distance for each row.

try this on your table

Clear Globals**()**;

Names Default To Here**(** **1** **)**;

// reference the data table

dt = current data table**()**;

// introduce the column with the distance to be updated in the dots table

dt << **add multiple columns(** "Distance", **1**, after**(** **6** **)**, numeric **)**;

// extract the longitude and the latitude values from the table - as radians

HHx = **(**Column**(** dt, "HH Longitude" **)** << **getValues)** * Pi**()** / **180** ;

HHy = **(**Column**(** dt, "HH Latitude" **)** << **getValues)** * Pi**()** / **180** ;

PSx = **(**Column**(** dt, "PS Longitude" **)** << **getValues)** * Pi**()** / **180** ;

PSy = **(**Column**(** dt, "PS Latitude" **)** << **getValues)** * Pi**()** / **180** ;

// declare the calculation function in Miles

haversine = Function**(** **{**long1, lat1, long2, lat2, R = **6371}**,

**{**Default Local**}**,

a = Sin**(** **(**lat1 - lat2**)** / **2** **)** ^ **2** + Cos**(** lat1 **)** * Cos**(** lat2 **)** * Sin**(** **(**long1 - long2**)** / **2** **)** ^ **2**;

c = **2** * ATan**(** a ^ **0.5**, **(****1** - a**)** ^ **0.5** **)**;

d = **(**R * c**)*****0.6213712**;// miles

**)**;

wait **(****0.01)**;

// run the function along the rows of the table

For**(** i = **1**, i <= N Row**(** dt **)** - **1**, i++,

dt:distance**[**i**]** = haversine**(** HHx**[**i**]**, HHy**[**i**]**, PSx**[**i**]**, PSy**[**i**]** **)**

**)**;

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Jul 1, 2016 4:51 AM
(2822 views)

Thanks ron_horne. I will let you know the outcome once I tried it. But I think it looks great! Big tx

Jenkins Macedo

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Get Direct Link
- Email to a Friend
- Report Inappropriate Content

Aug 24, 2017 2:05 PM
(1302 views)

Hi ron_horne and I hope you are doing well. I know this has taken some time since we last chatted on this thread. The project was put on hold and it is now up and running and in about few weeks, the resulting table will be deployed in production by our campaign team.

I did apply the script and it worked perfectly as expected!! Great job!!

As you know the script calculates the distance between pairs of (HH Lat. and HH Long.) to (PS Lat and PS Long.), which is what was originally what the project was designed to capture. I have used the resulting distance to calculate the time that it will take for each household to attend one of our program that is 1, 3, or 5 hours away from their homes.

Now, the issue is that I would like to script to calculate the distance between each pair of Lat. and Long.

For example:

In the table below, I have computed the distance and time between row 1 pairs of Lat. & Long. Which is perfect!! that will do for all 20 rows giving 20 unique distances between household location to the destination of the program.

So, in row 1 the program # 15896 with PS Lat. 56.47 N & PS Long. 132.38 S is certain distance away from the Household whose HH Lat. & HH Long.

Since we want to know the distance of each household from each program #, how can I calculate, such that, JMP captures the distance between each household Lat and Long acrosss each Program Lat and Long and not just the first program? In this table, I have 20 rows, using what I have described we should have 400 difference distance calculation instead of just 20. Do you know a way to go around this?

My original HH Data Table has 156,737 Unique households records with their respective HH Lat. & HH Long. The Household file has 15,655 unique HH Lat. & HH Long.

The Program Data Table with 2,747 Unique Program #s with 329 unique PS Lat. & PS Long. I want to calculate the distance from each unique household Lat. & Long to each unique Program Lat. & Long., such that, the distance is calculated across each program. That will be 15,655 *329 and the resulting table or the total distance should be about 5,150,495 records.

Jenkins Macedo

This widget could not be displayed.