Skip to main content

Infer rankings and nature of hierarchies from paired comparisons

Project description

pairwise-ranking

Documentation status PyPI status

Models for ranking competitors and measuring the nature of hierarchies

Maximilian Jerdee, Mark Newman

Paired comparisons may arise from records of sports matches, social interactions, or from any set of preferences between pairs of objects. In these settings we can model the "strengths" of each participant, predict future contests, and infer the "depth-of-competition" and "luck" present in the hierarchies considered.

The models implemented in this package are based on this paper:

M. Jerdee, M. E. J. Newman, Luck, skill, and depth of competition in games and social hierarchies, Preprint arxiv:2312.04711 (2023).

Installation

pairwise-ranking may be installed through pip:

pip install pairwise-ranking

Typical usage

Once installed, the package can be imported as

import ranking

Note that this is not import pairwise-ranking.

Files can be in a .gml network format, or read from a .txt file of a list of matches or one of an adjacency matrix of head-to-head records. See the /data directory for examples of properly formatted data.

Once a match_list has been loaded from a data set, the package may be used to rank participants, make predictions, and compute the depth and luck:

# Load data set
match_list = ranking.read_match_list("data/gml_files/dogs.gml")

# Find scores (requires sampling, which can take a while)
scores = ranking.scores(match_list)
print(scores)

# Get ranks (uses cached samples when possible)
ranks = ranking.ranks(match_list)
print(ranks)

# Find probability (and error) of an outcome betwen a pair
player1 = 'MER'
player2 = 'STE'
probability, probability_error = ranking.probability(match_list,player1,player2)
print(f"Probability {probability:.4f}+/-{probability_error:.4f} that {player1} beats {player2}")

# Infer the depth and luck of the hierarchy
params = ranking.depth_and_luck(match_list)
print(f"Depth: {params['depth']:.3f}, Luck: {params['luck']:.3f}")

See the file example.py for examples of more advanced usage options and our readthedocs page for further documentation and data set sources.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pairwise-ranking-1.0.2.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pairwise_ranking-1.0.2-py3-none-any.whl (15.5 kB view details)

Uploaded Python 3

File details

Details for the file pairwise-ranking-1.0.2.tar.gz.

File metadata

  • Download URL: pairwise-ranking-1.0.2.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for pairwise-ranking-1.0.2.tar.gz
Algorithm Hash digest
SHA256 adc42c94dab6bac499256b3936bd13bfb723ffd412ae3bee4dc88d4ce0ef81c1
MD5 10e56fb7fff7ec22c3cf39d9e25cea39
BLAKE2b-256 f30956ef6957668eca30cd4f87e8670b4de9f9127b3b4afc99e31bc450d8f147

See more details on using hashes here.

File details

Details for the file pairwise_ranking-1.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for pairwise_ranking-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b74e036354bd179ebe44699ea27a459c6666c5bdb8e6d3223f9b97125186b817
MD5 c800cebd7cb41b5c56e449aa5f7b77d6
BLAKE2b-256 c7c75c25e953955297a8ca989294da87c5bf4e9ce8641d91508ab2d2e829c5b0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page