MapInfo Pro

 View Only
  • 1.  MapInfo Monday: Converting DMS to Decimal Degrees

    Employee
    Posted 06-17-2024 11:51
    Edited by Peter Møller 06-18-2024 03:14

    As most of you know, longitude and latitude values can be specified in various ways. They can be given in degrees, minutes, and seconds (DMS) like 9°25'49.5677" N. Or they can be provided as a decimal degree like 9.430435.

    MapInfo Pro works with decimal degrees so you will have to convert DMS values into decimal degrees to use these for creating points, as an example.

    You can convert your DMS values to decimal degrees using this formula: decimal degree = D + (M + (S / 60) / 60).

    Oh, and don't forget to handle the quadrant too. That's the last character in the string: N. That character can be one of two values for longitude values and one of two values for latitude values too. W or E and N or S. If the longitude value specifies W for West, the decimal degrees must be negative, and similar if the latitude value specifies S for South, the decimal degrees must be negative.

    Or you can use the Decimal / DMS Converter tool that comes with MapInfo Pro.
    The Decimal / DMS Converter tool allows you to convert single values or a column of values between DMS and decimal degrees.
    Last week our support team got a call about a different form of longitude/latitude values: Degrees and decimal minutes. They would look like: 53°31.9832' N. Here is a look at some of the values in the columns Lat and Long.
    I have added two additional columns to hold the values converted to decimal degrees; Latitude and Longitude.
    Unfortunately, the Decimal / DMS Converter tool can't handle these values. So how can we handle these values in MapInfo Pro? The solution uses the Update statement, and a bit of string magic.
    Let's jump into the solution, and by the way, happy #MapInfoMonday.

    Converting Degrees and Decimal Minutes to Decimal Degrees

    The formula from above still holds true, but we can simplify it to this: decimal degree = D + (M / 60). As the seconds already have been merged with the minutes to form a decimal minute, we can remove these from the formula.

    To make it easier for me and you to understand, I have split the process into 3 steps:

    1. Extract the degree from the string
    2. Extract and add the decimal minute to the degree
    3. Handle the quadrant

    As the first value in the string is the degree, we can convert the string to a number and end up with the numeric value of the degree. You can use the Val() function to get the numeric value from a string.

    Update Observations
    Set Latitude = Val(Lat)
      , Longitude = Val(Long)

    I use the SQL window to execute the Update statements and that will look like this:

    The results have been written to the Longitude and Latitude columns as you can see below.
    The next step is the tricky one as we need to extract the decimal minute value from within the string. We can see a degree symbol in front of the value and a minute symbol after the value. We can find the position of these two strings, and extract the value in between.
    We will use the InStr() function to find the position of the strings and the Mid$() function to extract the value and just like we did with the degree we will use the Val() function to convert the value to a numeric value that we will add to the existing value in the Latitude and Longitude columns.
    Once extracted, we must divide it by 60 to get a decimal-degree value.
    Here is the expression.
    Update Observations
    Set Latitude = Latitude + (Val(Mid$(Lat, InStr(1, Lat, "°") + 1, InStr(1, Lat, "'") - 1)) / 60)
      , Longitude = Longitude + (Val(Mid$(Long, InStr(1, Long, "°") + 1, InStr(1, Long, "'") - 1)) / 60)

    Here you can see how it looks in the SQL window combined with the first expression

    Here are the results after running the first two Update statements on the data.
    In the final step, we need to ensure that the value will be negative if the last character is S for the latitude values or W for the longitude values.
    We will use the Right$() function to extract the first character from the end of the string. We will use the inline If function IIf() to test the value of that character.
    This is the final expression:
    Update Observations
    Set Latitude = Latitude * IIf(Right$(Lat, 1) = "S", -1, 1)
      , Longitude = Longitude * IIf(Right$(Long, 1) = "W", -1, 1)

    Below you can see it in combination with the first two expressions in the SQL window.

    Here are the final decimal degree values ready for further use in MapInfo Pro.

    You can also do it all in a single statement:

    Update Observations
    Set Latitude = (Val(Lat) + (Val(Mid$(Lat, InStr(1, Lat, "°") + 1, InStr(1, Lat, "'") - 1)) / 60)) * IIf(Right$(Lat, 1) = "S", -1, 1)
      , Longitude = (Val(Long) + (Val(Mid$(Long, InStr(1, Long, "°") + 1, InStr(1, Long, "'") - 1)) / 60)) * IIf(Right$(Long, 1) = "W", -1, 1)

    In the SQL window, it would look like this:

    It was great doing a bit of math on the latitude and longitude values again as it had been a while. Thanks, @Joerg Huebner, for fixing the mistake I made in the expression initially dividing the minutes with 100 instead of 60 to get to a decimal degree.



    ------------------------------
    Peter Horsbøll Møller
    Principal Presales Consultant | Distinguished Engineer
    Precisely | Trust in Data
    ------------------------------



  • 2.  RE: MapInfo Monday: Converting DMS to Decimal Degrees

    Employee
    Posted 06-18-2024 03:11

    Hi

    This expression is the most complex of the three I shared. And it certainly can be a bit tricky to decipher.

    Update Observations
    Set Latitude = Latitude + (Val(Mid$(Lat, InStr(1, Lat, "°") + 1, InStr(1, Lat, "'") - 1)) / 60)
      , Longitude = Longitude + (Val(Mid$(Long, InStr(1, Long, "°") + 1, InStr(1, Long, "'") - 1)) / 60)

    The tricky part is this expression where I extract the decimal minute from the string:

    Mid$(Lat, InStr(1, Lat, "°") + 1, InStr(1, Lat, "'") - 1)
    

    The two InStr() functions look for the position of the two characters, degree (°) and minute ('). The Mid$() function uses this to extract the decimal minute.

    If you have the WindowHelper tool installed, you have access to a custom function that can extract a substring from a string by specifying the characters that the substring is between. This function is called WHExtractValueBetweenChars$(). You can install the WindowHelper tool from the MapInfo Marketplace.

    You can use this function to rewrite the expression above to this:

    Update Observations
    Set Latitude = Latitude + (Val(WHExtractValueBetweenChars$(LAT, "°", "'")) / 60)
      , Longitude = Longitude + (Val(WHExtractValueBetweenChars$(Long, "°", "'")) / 60)

    I think we can agree that this statement is easier to read and understand



    ------------------------------
    Peter Horsbøll Møller
    Principal Presales Consultant | Distinguished Engineer
    Precisely | Trust in Data
    ------------------------------