Skip to main content

pref_voting is a Python packaging that contains tools to reason about election profiles and margin graphs, and implementations of a variety of preferential voting methods.

Project description

pref_voting

Installation

With pip package manager:

pip install pref_voting

Documentation

Online documentation is available at https://pref_voting.readthedocs.io.

Profiles and Voting Methods

A profile (of linear orders over the candidates) is created by initializing a Profile class object. This needs a list of rankings (each ranking is a tuple of numbers), the number of candidates, and a list giving the number of each ranking in the profile:

from pref_voting.profiles import Profile

rankings = [(0, 1, 2, 3), (2, 3, 1, 0), (3, 1, 2, 0), (1, 2, 0, 3), (1, 3, 2, 0)]
rcounts = [5, 3, 2, 4, 3]

prof = Profile(rankings, rcounts=rcounts)

The function generate_profile is used to generate a profile for a given number of candidates and voters:

from pref_voting.generate_profiles import generate_profile

# generate a profile using the Impartial Culture probability model
prof = generate_profile(3, 4) # prof is a Profile object

# generate a profile using the Impartial Anonymous Culture probability model
prof = generate_profile(3, 4, probmod = "IAC") # prof is a Profile object 
from pref_voting.profiles import Profile
from pref_voting.voting_methods import *

prof = Profile(rankings, num_cands, rcounts=rcounts)
print(f"{split_cycle.name} winners:  {split_cycle(prof)}")
split_cycle.display(prof)

Versions

  • v0.1.10 (2022-08-09): Initial release
  • v0.1.13 (2022-11-05): Minor updates and bug fixes
  • v0.1.14 (2022-12-19): Add plurality_scores to ProfileWithTies; add generate ceots function; bug fixes
  • v0.1.17r1 (2022-12-27): Add instant_runoff_for_truncated_linear_orders and functions to truncate overvotes in a ProfileWithTies

Questions?

Feel free to send me an email if you have questions about the project.

License

MIT

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

pref_voting-0.1.17.post1.tar.gz (75.3 kB view details)

Uploaded Source

Built Distribution

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

pref_voting-0.1.17.post1-py3-none-any.whl (81.0 kB view details)

Uploaded Python 3

File details

Details for the file pref_voting-0.1.17.post1.tar.gz.

File metadata

  • Download URL: pref_voting-0.1.17.post1.tar.gz
  • Upload date:
  • Size: 75.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.14 CPython/3.9.15 Darwin/19.6.0

File hashes

Hashes for pref_voting-0.1.17.post1.tar.gz
Algorithm Hash digest
SHA256 26faa693fd4ffc8675d7d76d90a707647e95b15d68a314514ec4187b7d0a0aec
MD5 24000f3559662a7f3bcee3023826a06f
BLAKE2b-256 20c82212bcb36780ed5700e43c5e6a9c01a1ea348700a59567d15a4746062721

See more details on using hashes here.

File details

Details for the file pref_voting-0.1.17.post1-py3-none-any.whl.

File metadata

  • Download URL: pref_voting-0.1.17.post1-py3-none-any.whl
  • Upload date:
  • Size: 81.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.14 CPython/3.9.15 Darwin/19.6.0

File hashes

Hashes for pref_voting-0.1.17.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 6cd0c69cd3ca5729d3e9ed1a27c25029296703277c43038ecddc0ab423b41ed7
MD5 c82a6c6c68ed0df78ba15106a0370708
BLAKE2b-256 4d57ea0df0a8cea77b84114912a23304105469174297c2ea6fe27be834c0b1f3

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