Check out the latest documentation.

What's Covered

This tutorial illustrates how to access match metrics. The following is covered:

  • How to retrieve device Id.
  • How to retrieve match method.
  • How to retrieve difference.
  • How to retrieve rank.

Code and Explanation

Getting started example of using 51Degrees device detection match metrics information. The example shows how to:

  1. Import settings from the 51Degrees settings file

    												
    dataFile = settings.V3_WRAPPER_DATABASE
    properties = settings.PROPERTIES
    cacheSize = settings.CACHE_SIZE
    poolSize = settings.POOL_SIZE
    
    												

  • Instantiate the 51Degrees device detection provider with these properties

    									
    provider = fiftyone_degrees_mobile_detector_v3_wrapper.Provider(dataFile,
    	properties,
    	cacheSize,
    	poolSize)
    
    									
  • Produce a match for a single HTTP User-Agent header

    									
    match = provider.getMatch(userAgent)
    
    									

  • Obtain device Id: consists of four components separated by a hyphen symbol: Hardware-Platform-Browser-IsCrawler where each Component represents an ID of the corresponding Profile.

    									match.getDeviceId()
    									
  • Obtain match method: provides information about the algorithm that was used to perform detection for a particular User-Agent. For more information on what each method means please see: How device detection works

    									match.getMethod()
    									
  • Obtain difference: used when detection method is not Exact or None. This is an integer value and the larger the value the less confident the detector is in this result.

    									match.getDifference()
    									
  • Obtain signature rank: an integer value that indicates how popular the device is. The lower the rank the more popular the signature.

    									match.getRank()
    									
    This example can be run in any directory, but assumes your settings file contains a valid dataFile location and has the IsMobile property selected.

    Full Source File
    												
    from FiftyOneDegrees import fiftyone_degrees_mobile_detector_v3_wrapper
    from fiftyone_degrees.mobile_detector.conf import settings
    import sys
    
    '''
    Imports settings from the settings file. The Default settings file, and
    details on how to change it can be output by running the command
    <p><pre class="prettyprint lang-py">
    51degrees-mobile-detector settings
    </p></pre>
    '''
    dataFile = settings.V3_WRAPPER_DATABASE
    properties = settings.PROPERTIES
    cacheSize = settings.CACHE_SIZE
    poolSize = settings.POOL_SIZE
    
    '''
    Initialises the device detection provider with settings from the settings
    file. By default this will use the included Lite data file For more info
    see:
    <a href="https://51degrees.com/compare-data-options">compare data options
    </a>
    '''
    provider = fiftyone_degrees_mobile_detector_v3_wrapper.Provider(dataFile,
    properties,
    cacheSize,
    poolSize)
    
    # User-Agent string of an iPhone mobile device.
    mobileUserAgent = ("Mozilla/5.0 (iPhone; CPU iPhone OS 7_1 like Mac OS X) "
    "AppleWebKit/537.51.2 (KHTML, like Gecko) 'Version/7.0 Mobile/11D167 "
    "Safari/9537.53")
    
    # User-Agent string of Firefox Web browser version 41 on desktop.
    desktopUserAgent = ("Mozilla/5.0 (Windows NT 6.3; WOW64; rv:41.0) "
    "Gecko/20100101 Firefox/41.0")
    
    # User-Agent string of a MediaHub device.
    mediaHubUserAgent = ("Mozilla/5.0 (Linux; Android 4.4.2; X7 Quad Core "
    "Build/KOT49H) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 "
    "Chrome/30.0.0.0 Safari/537.36")
    
    '''
    output_metrics function. Takes a match object as an argument and
    prints the match metrics relating to the specific match.
    '''
    def output_metrics(match):
        sys.stdout.write('   Id: %s\n' % match.getDeviceId())
        sys.stdout.write('   Match Method: %s\n' % match.getMethod())
        sys.stdout.write('   Difference: %s\n' % match.getDifference())
        sys.stdout.write('   Rank: %s\n' % match.getRank())
    
    def main():
        sys.stdout.write('Starting Getting Started Match Metrics Example.\n')
    
    # Carries out a match with a mobile User-Agent.
        sys.stdout.write('Mobile User-Agent: %s\n' % mobileUserAgent)
        match = provider.getMatch(mobileUserAgent)
        output_metrics(match)
    # Carries out a match with a desktop User-Agent.
        sys.stdout.write('Desktop User-Agent: %s\n' % desktopUserAgent)
        match = provider.getMatch(desktopUserAgent)
        output_metrics(match)
    # Carries out a match with a MediaHub User-Agent.
        sys.stdout.write('Media Hub User-Agent: %s\n' % mediaHubUserAgent)
        match = provider.getMatch(mediaHubUserAgent)
        output_metrics(match)
    
    if __name__ == '__main__':
        main()
    
    
    												
    Full Source File

  • Summary

    Match metrics is an additional piece of information about each match result. It can help developers spot fake User-Agents and determine the general level of confidence the detector has in the current detection results.

    Device metrics consists of four parts: device Id, detection method, difference and rank.

    Device Id is composed of four components, each represented as a number and separated by the hyphen symbol. Numbers correspond to profile IDs the detector has selected for that particular component. The four components are: hardware, software, browser and crawler. For more information please see the 51Degrees Data Model .

    The detection method provides information on what algorithm was used for this particular detection and difference indicates by how much the provided User-Agent is different to the best signatures found in the data file. The larger the number the less confident the detector is. Difference for the 'exact' method is always zero. Difference for the 'none' detection method is irrelevant. For more information see the How Device Detection Works page.

    Rank value tells you how popular the identified device is. The lower the value the more popular the device. Popularity is derived by 51Degrees based on our observed usage level.

    Other uses for match metrics include:

    • Ranking devices by popularity. Best used in conjunction with other tutorials to rank the results based on the general device popularity.
    • Storing device Id for analytics instead of individual profiles.

    The Lite data file contains 446,634 device combinations, whilst Premium and Enterprise contain 940,018 and 1,407,838 device combinations respectively. A larger set of device combinations leads to the 'exact' detection method being used more frequently and the rank providing a more accurate value.