A Python package for calculating the winner of a poll using rank choice voting (Instant-runoff voting).
Project description
rank-choicer
A Python package for calculating the winner of a poll using rank choice voting (Instant-runoff voting).
Requirements
Python 3.10 or higher.
Install
Use pip to install:
pip install rank-choicer
Usage
First, set up the counter with the available options:
from rank_choicer import RankChoiceCounter
counter = RankChoiceCounter(["A", "B", "C"])
Then, you can pass in the votes to its count_votes method which returns the winner:
votes = {
"voter1": ["A", "B", "C"],
"voter2": ["B", "A", "C"],
"voter3": ["C", "A", "B"],
"voter4": ["A", "C", "B"],
"voter5": ["B", "C", "A"],
}
winner = counter.count_votes(votes)
print(f"Winner is: {winner}")
Winner is A
Viewing Specific Rounds
Sometimes, you may want to review the different rounds of elimination for either analysis or visualization. You can do so by calling the get_round_results method:
results = counter.get_round_results()
print(f"Round number: {results[0].round_number}")
print(f"Eliminated in the first round: {results[0].eliminated_options}")
print(f"Vote counts: {results[0].vote_counts}")
print(f"Winner (final round only): {results[-1].winner}")
Round number: 1
Eliminated in the first round: ['C']
Vote counts: {'A': 2, 'B': 2, 'C': 1}
Winner (final round only): A
Each RoundResult has four fields: round_number, vote_counts, eliminated_options, and winner. Only the final round will have a winner set; only non-final rounds will have eliminated_options set.
You can also serialize a round result to a dictionary, which is useful for JSON responses or storage:
import json
rounds = json.dumps([result.to_dict() for result in counter.get_round_results()])
Handling Ties In Elimination
In rare cases, you may have more than one option with the lowest votes. In those cases, you can handle what to eliminate in two ways:
- Randomly eliminate one of the options with lowest votes
- Eliminate all options tied for lowest votes
The RankChoiceCounter defaults to random but you can change the strategy used using the elimination_strategy parameter:
from rank_choicer import EliminationStrategy
counter = RankChoiceCounter(
["A", "B", "C", "D"], elimination_strategy=EliminationStrategy.BATCH
)
Note that when using EliminationStrategy.BATCH, if all remaining options are tied, count_votes will raise a ValueError. You can catch this and inspect the round results to determine how the tie occurred:
try:
winner = counter.count_votes(votes)
except ValueError:
rounds = counter.get_round_results()
Contributing
Community made feature requests, patches, bug reports, and contributions are always welcome.
Please review our contributing guidelines if you decide to make a contribution.
License
This project is licensed under the MIT License. See LICENSE for more details.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file rank_choicer-1.1.0.tar.gz.
File metadata
- Download URL: rank_choicer-1.1.0.tar.gz
- Upload date:
- Size: 5.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c0e2cb00639e63bccf82f06b0cf030eda5e0ae74e306445fc2022eb797ae8e1c
|
|
| MD5 |
c7a2f607781fddbdef070656bf280ac2
|
|
| BLAKE2b-256 |
7d69fbfc387d2020c882a51b6261dab5014ab1bda64221b0c6820e41310f9bb3
|
File details
Details for the file rank_choicer-1.1.0-py3-none-any.whl.
File metadata
- Download URL: rank_choicer-1.1.0-py3-none-any.whl
- Upload date:
- Size: 6.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b5c65e7156d4c749921b39d8cbc8e2538045c440ed78ab0d346f7fd677f10296
|
|
| MD5 |
e2831c718742e9e4c6717eedb664a495
|
|
| BLAKE2b-256 |
148970026cc98d3310aebfde7c9863beb3b2febc50cf04c03bdd67a8bb2bb71a
|