Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Don't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.

Reply
prateekraina
Memorable Member
Memorable Member

Find no of trips using Latitude and Longitude

Hello,

 

I have a scenario wherein I need to find out no of trips made by a driver based on Latitude and Longitude data which I receive.

I have a fixed Source Address, whenever the car leaves that address and comes back, it means one complete trip.

 

Following is the sample data. Assume that my source address coordinates are Latitude - LA1 and Longitude - LO1

 

TimestampLatitudeLongitudeTrips
3/15/18 11:00 AMLA1LO1 
3/15/18 11:15 AMLA1LO11
3/15/18 11:30 AMLA2LO2
3/15/18 11:45 AMLA3LO3
3/15/18 12:00 PMLA1LO1
3/15/18 12:15 PMLA1LO1 
3/15/18 12:30 PMLA1LO12
3/15/18 12:45 PMLA2LO2
3/15/18 1:00 PMLA3LO3
3/15/18 1:15 PMLA4LO4
3/15/18 1:30 PMLA1LO1
3/15/18 1:45 PMLA1LO1 
3/15/18 2:00 PMLA1LO1 
3/15/18 2:15 PMLA1LO1 
3/15/18 2:30 PMLA1LO1 
3/15/18 2:45 PMLA1LO13
3/15/18 3:00 PMLA3LO3
3/15/18 3:15 PMLA3LO3
3/15/18 3:30 PMLA3LO3
3/15/18 3:45 PMLA1LO1
3/15/18 4:00 PMLA1LO1 
3/15/18 4:15 PMLA1LO1 

 

As per above data, no of trips is 3. Can anyone suggest how to achive this calculation?

 

Prateek Raina

1 ACCEPTED SOLUTION

HI @prateekraina

 

Please try this modified calculated column to allow for DriverID

 

Trips = 
VAR SourceLat = "LA1"
VAR SourceLng = "LO1"
VAR DriverID = 'Table1'[DriverID]
VAR NextTimeStamp = 
    MINX(
        FILTER(
            'Table1',
            'Table1'[Timestamp] > EARLIER('Table1'[Timestamp])
            && 'Table1'[DriverID] = DriverID
            ),
        'Table1'[Timestamp]
        )
VAR NextLat = MINX(FILTER('Table1',Table1[Timestamp] = NextTimeStamp && 'Table1'[DriverID] = DriverID),'Table1'[Latitude])
VAR NextLng = MINX(FILTER('Table1',Table1[Timestamp] = NextTimeStamp && 'Table1'[DriverID] = DriverID),'Table1'[Longitude])
VAR Result =  
    IF (
        'Table1'[Latitude] = SourceLat && 
        'Table1'[Longitude] = SourceLng && 
        'Table1'[Latitude] <> NextLat &&
        'Table1'[Longitude] <> NextLng && 
        NOT ISBLANK(NextLat) ,1 , BLANK())
        
RETURN Result

        

 


To learn more about DAX visit : aka.ms/practicalDAX

Proud to be a Datanaut!

View solution in original post

11 REPLIES 11
TomMartens
Super User
Super User

Hey,

 

this is an interesting question, but I have to admit that I'm not able to fully understand the source data.

 

My first understanding was:

if LA/LO from the immediate previous row (ordered by the Timestamp) and grouped by driver id are the same this would count as trip, but looking at the source data, this understanding is not correct.

 

Second guess is whenver, the next LA/LO does not  match with the "home address" a trip counted. This seems valid, but I'm also unsure about the first trip.

 

Can you plesase confirm that this rule is valid (per driver / per day):

A trip is counted when the next position is not the homeposition 

 

 

Regards

Tom



Did I answer your question? Mark my post as a solution, this will help others!

Proud to be a Super User!
I accept Kudos 😉
Hamburg, Germany

Hi @TomMartens,

 

I was not able to properly create grid in this post.

1 trp = No of rows between bold LA1 and LO1 including those rows.

"Can you plesase confirm that this rule is valid (per driver / per day):

A trip is counted when the next position is not the homeposition" - i will be getting data of only one driver at once so i did not group it on driver.

In some scenarios trip would have been completed and still I will be receiving the home coordinates, so that would not come under my trip. So we cannot say for sure that a trip is counted when the next position is not the home position.

 

Prateek Raina

Phil_Seamark
Microsoft Employee
Microsoft Employee

Hi @prateekraina

 

 

This calculated column gets close.  It puts 1's in, instead of a cumulative total.  I'm guessing that running a SUM over this column would be more useful

 

Trips = 
VAR SourceLat = "LA1"
VAR SourceLng = "LO1"
VAR NextTimeStamp = 
    MINX(
        FILTER(
            'Table1',
            'Table1'[Timestamp] > EARLIER('Table1'[Timestamp])
            ),
        'Table1'[Timestamp]
        )
VAR NextLat = MINX(FILTER('Table1',Table1[Timestamp] = NextTimeStamp),'Table1'[Latitude])
VAR NextLng = MINX(FILTER('Table1',Table1[Timestamp] = NextTimeStamp),'Table1'[Longitude])
VAR Result =  
    IF (
        'Table1'[Latitude] = SourceLat && 
        'Table1'[Longitude] = SourceLng && 
        'Table1'[Latitude] <> NextLat &&
        'Table1'[Longitude] <> NextLng && 
        NOT ISBLANK(NextLat) ,1 , BLANK())
        
RETURN Result

        

 

image.png


To learn more about DAX visit : aka.ms/practicalDAX

Proud to be a Datanaut!

Hi @Phil_Seamark,

 

I tried this, it works well.

Can you please tell if it is possible to group this result by another column "DriverID".

I tried to filter the resulting measure (i.e. Sum of Trips) by a specific DriverID but then it shows incorrect no of Trips as the logic is applied on Timestamp,Lat and Long across all the drivers.

 

Kindly let me know if it can be done.

 

Please see the below image for better understanding.
Also it would be great to somehow see trip duration for a driver.
Example: Driver D1's first trip is from 11:15 AM to 12:00 PM

Capture.PNG

 

 

 

Prateek Raina

HI @prateekraina

 

Please try this modified calculated column to allow for DriverID

 

Trips = 
VAR SourceLat = "LA1"
VAR SourceLng = "LO1"
VAR DriverID = 'Table1'[DriverID]
VAR NextTimeStamp = 
    MINX(
        FILTER(
            'Table1',
            'Table1'[Timestamp] > EARLIER('Table1'[Timestamp])
            && 'Table1'[DriverID] = DriverID
            ),
        'Table1'[Timestamp]
        )
VAR NextLat = MINX(FILTER('Table1',Table1[Timestamp] = NextTimeStamp && 'Table1'[DriverID] = DriverID),'Table1'[Latitude])
VAR NextLng = MINX(FILTER('Table1',Table1[Timestamp] = NextTimeStamp && 'Table1'[DriverID] = DriverID),'Table1'[Longitude])
VAR Result =  
    IF (
        'Table1'[Latitude] = SourceLat && 
        'Table1'[Longitude] = SourceLng && 
        'Table1'[Latitude] <> NextLat &&
        'Table1'[Longitude] <> NextLng && 
        NOT ISBLANK(NextLat) ,1 , BLANK())
        
RETURN Result

        

 


To learn more about DAX visit : aka.ms/practicalDAX

Proud to be a Datanaut!

Hi @Phil_Seamark,

 

Thank you very much for the help.

Lastly, can you please tell if there is any way to filter the data by Driver ID and get his/her trip duration?

 

Prateek Raina

 

 

I can look at this tomorrow.  I have to prepare to present a DPG webinar later this evening and I should focus on that.


To learn more about DAX visit : aka.ms/practicalDAX

Proud to be a Datanaut!

Hi @Phil_Seamark,

 

I just integrated this column in my actual development report which has around 36K rows. This calculated column thorows memory error.
March 23.PNG

 

Upon investigating, I found out that It is happening beacuse of following condition written in bold:

VAR NextTimeStamp = 
    MINX(
        FILTER(
            'Table1',
            'Table1'[Timestamp] > EARLIER('Table1'[Timestamp])
            && 'Table1'[DriverID] = DriverID
            ),
        'Table1'[Timestamp]
        )

Removing it creates the column successfully but then gives incosistent result 😞

I suspect EARLIER is causing this error. Is there any other way to do this?

@Phil_Seamark

 

Any luck?

Yes, sure. Thanks a lot.

Hi @Phil_Seamark,

 

Thanks for your suggestion, i will try this out and let you know. Appreciate the help.

 

Prateek Raina

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

December 2024

A Year in Review - December 2024

Find out what content was popular in the Fabric community during 2024.