php-extended / php-vote-object
A library that implements the php-vote-interface package
Requires
- php: >=8.0
- php-extended/php-score-object: ^7
- php-extended/php-vote-interface: ^7
Requires (Dev)
- dev-master
- 7.0.9
- 7.0.8
- 7.0.7
- 7.0.6
- 7.0.5
- 7.0.4
- 7.0.3
- 7.0.2
- 7.0.1
- 7.0.0
- 6.1.4
- 6.1.3
- 6.1.2
- 6.1.1
- 6.1.0
- 6.0.3
- 6.0.2
- 6.0.1
- 6.0.0
- 5.0.1
- 5.0.0
- 4.0.2
- 4.0.1
- 4.0.0
- 3.2.8
- 3.2.7
- 3.2.6
- 3.2.5
- 3.2.4
- 3.2.3
- 3.2.2
- 3.2.1
- 3.2.0
- 3.1.17
- 3.1.16
- 3.1.15
- 3.1.14
- 3.1.13
- 3.1.12
- 3.1.11
- 3.1.10
- 3.1.9
- 3.1.8
- 3.1.7
- 3.1.6
- 3.1.5
- 3.1.4
- 3.1.3
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.1
- 2.0.0
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
This package is auto-updated.
Last update: 2025-01-19 19:25:11 UTC
README
A library that implements the php-vote-object package
Installation
The installation of this library is made via composer and the autoloading of all classes of this library is made through their autoloader.
- Download
composer.phar
from their website. - Then run the following command to install this library as dependency :
php composer.phar php-extended/php-vote-object ^7
Basic Usage :
To run this library, you need at least one other library, which is to provide
a specific voting method implementing the
PhpExtended\Vote\VotingMethodInterface
interface.
Additionnally, an additional library that provides the biases to modify the
votes before the election is runned may be used. The biases must implement the
PhpExtended\Vote\BiasInterface
interface.
Finally, the core of the voting system is to vote for something, so you must
provide a library which creates citizens for the voting process, such citizens
may vote and rank any candidate in the election. All the citizens must implement
the PhpExtended\Vote\CitizenInterface
interface.
Those citizens are very important, they provide the candidates and their
arguments. Their arguments is what will be examined by the different citizens
when they will be choosing for a vote ordering, so the citizen methods must be
coherent!
Once every piece comes together, the engine may be used the following way :
use PhpExtended\Vote\ElectionRunner;
use PhpExtended\Vote\InvalidCandidateException;
use PhpExtended\Vote\InvalidVoteException;
use PhpExtended\Vote\UnsolvableSituationException;
$runner = new ElectionRunner();
$biases = new ArrayIterator(array(
$yourBiasedObjects, // each implement BiasInterface
));
$citizens = new ArrayIterator(array(
$yourCitizenObjects, // each implement CitizenInterface
));
$method = $theChoosenMethod; // implements VotingMethodInterface
try
{
$result = $runner->runElection($method, $biases, $citizens);
}
catch(InvalidCandidateException $ice)
{
// TODO handle the fact that one candidate is refused
}
catch(InvalidVoteException $ive)
{
// TODO handle the fact that one vote is refused
}
catch(UnsolvableSituationException $use)
{
// TODO handle the fact that an ordering between the
// candidates could not be decided by the current voting
// method and the votes that were given.
}
foreach($result->getRankings() as $individualResult)
{
// The rankings are given in order of importance, winner
// first and loser last
/* @var $individualResult \PhpExtended\Vote\ElectionResultInterface */
$candidate = $individualResult->getCandidate();
// here the candidate is one of the candidate object that
// was given by one of your citizens, and you retrieve
// its objects within the arguments of the citizen.
}
This library proposes a list of standard citizens that will vote with a predetermined behavior. They are useful to use in an election the following way :
use PhpExtended\Vote\ElectionRunner;
use PhpExtended\Vote\InvalidCandidateException;
use PhpExtended\Vote\InvalidVoteException;
use PhpExtended\Vote\UnsolvableSituationException;
use PhpExtended\Vote\UniqueStringEqualsCitizen;
$runner = new ElectionRunner();
$citizens = array();
foreach($yourObjectsThatProvideStrings as $yourObject)
{
$id = $yourObject->__toString(); // or anything else that may be useful for an id
$citizens[] = new UniqueStringEqualsCitizen($id, $yourObject->yourMethodThatReturnsString());
}
try
{
$runner->runElection($method, new ArrayIterator(array()), new ArrayIterator($citizens));
}
catch(InvalidCandidateException $ice)
{
// TODO handle the fact that one candidate is refused
}
catch(InvalidVoteException $ive)
{
// TODO handle the fact that one vote is refused
}
catch(UnsolvableSituationException $use)
{
// TODO handle the fact that an ordering between the
// candidates could not be decided by the current voting
// method and the votes that were given.
}
UniqueBooleanEqualsCitizen
This citizen proposes a candidate with only one argument which is a boolean value. This citizen ranks all the candidates with 100% if they have only one argument which is the boolean value, and 0% for anyone else.
UniqueFloatEqualsCitizen
This citizen proposes a candidate with only one argument which is a float value. This citizen ranks all the candidates with 100% if they have only one argument which is the float value, and 0% for anyone else.
UniqueIntegerEqualsCitizen
This citizen proposes a candidate with only one argument which is an integer value. This citizen ranks all the candidates with 100% if they have only one argument which is the integer value, and 0% for anyone else.
UniqueStringEqualsCitizen
This citizen proposes a candidate with only one argument which is a string value. This citizen ranks all the candidates with 100% if they have only one argument which is the string value, and 0% for anyone else.
License
MIT (See license file).