pub trait NposSolutionwhere
Self: Sized + for<'a> TryFrom<&'a [IndexAssignmentOf<Self>], Error = Error>,{
type VoterIndex: UniqueSaturatedInto<usize> + TryInto<usize> + TryFrom<usize> + Debug + Copy + Clone + Bounded + Encode + TypeInfo;
type TargetIndex: UniqueSaturatedInto<usize> + TryInto<usize> + TryFrom<usize> + Debug + Copy + Clone + Bounded + Encode + TypeInfo;
type Accuracy: PerThing128;
const LIMIT: usize;
fn voter_count(&self) -> usize;
fn edge_count(&self) -> usize;
fn unique_targets(&self) -> Vec<Self::TargetIndex> ⓘ;
fn remove_voter(&mut self, to_remove: Self::VoterIndex) -> bool;
fn from_assignment<FV, FT, A>(
assignments: &[Assignment<A, Self::Accuracy>],
voter_index: FV,
target_index: FT
) -> Result<Self, Error>
where
A: IdentifierT,
for<'r> FV: Fn(&'r A) -> Option<Self::VoterIndex>,
for<'r> FT: Fn(&'r A) -> Option<Self::TargetIndex>;
fn into_assignment<A: IdentifierT>(
self,
voter_at: impl Fn(Self::VoterIndex) -> Option<A>,
target_at: impl Fn(Self::TargetIndex) -> Option<A>
) -> Result<Vec<Assignment<A, Self::Accuracy>>, Error>;
fn average_edge_count(&self) -> usize { ... }
fn score<A, FS>(
self,
stake_of: FS,
voter_at: impl Fn(Self::VoterIndex) -> Option<A>,
target_at: impl Fn(Self::TargetIndex) -> Option<A>
) -> Result<ElectionScore, Error>
where
for<'r> FS: Fn(&'r A) -> VoteWeight,
A: IdentifierT,
{ ... }
}
Expand description
An opaque index-based, NPoS solution type.
Required Associated Types§
sourcetype VoterIndex: UniqueSaturatedInto<usize> + TryInto<usize> + TryFrom<usize> + Debug + Copy + Clone + Bounded + Encode + TypeInfo
type VoterIndex: UniqueSaturatedInto<usize> + TryInto<usize> + TryFrom<usize> + Debug + Copy + Clone + Bounded + Encode + TypeInfo
The voter type. Needs to be an index (convert to usize).
sourcetype TargetIndex: UniqueSaturatedInto<usize> + TryInto<usize> + TryFrom<usize> + Debug + Copy + Clone + Bounded + Encode + TypeInfo
type TargetIndex: UniqueSaturatedInto<usize> + TryInto<usize> + TryFrom<usize> + Debug + Copy + Clone + Bounded + Encode + TypeInfo
The target type. Needs to be an index (convert to usize).
sourcetype Accuracy: PerThing128
type Accuracy: PerThing128
The weight/accuracy type of each vote.
Required Associated Constants§
Required Methods§
sourcefn voter_count(&self) -> usize
fn voter_count(&self) -> usize
Get the length of all the voters that this type is encoding.
This is basically the same as the number of assignments, or number of active voters.
sourcefn edge_count(&self) -> usize
fn edge_count(&self) -> usize
Get the total count of edges.
This is effectively in the range of {Self::voter_count
, Self::voter_count
*
Self::LIMIT
}.
sourcefn unique_targets(&self) -> Vec<Self::TargetIndex> ⓘ
fn unique_targets(&self) -> Vec<Self::TargetIndex> ⓘ
Get the number of unique targets in the whole struct.
Once presented with a list of winners, this set and the set of winners must be equal.
sourcefn remove_voter(&mut self, to_remove: Self::VoterIndex) -> bool
fn remove_voter(&mut self, to_remove: Self::VoterIndex) -> bool
Remove a certain voter.
This will only search until the first instance of to_remove
, and return true. If
no instance is found (no-op), then it returns false.
In other words, if this return true, exactly one element must have been removed self.
sourcefn from_assignment<FV, FT, A>(
assignments: &[Assignment<A, Self::Accuracy>],
voter_index: FV,
target_index: FT
) -> Result<Self, Error>where
A: IdentifierT,
for<'r> FV: Fn(&'r A) -> Option<Self::VoterIndex>,
for<'r> FT: Fn(&'r A) -> Option<Self::TargetIndex>,
fn from_assignment<FV, FT, A>(
assignments: &[Assignment<A, Self::Accuracy>],
voter_index: FV,
target_index: FT
) -> Result<Self, Error>where
A: IdentifierT,
for<'r> FV: Fn(&'r A) -> Option<Self::VoterIndex>,
for<'r> FT: Fn(&'r A) -> Option<Self::TargetIndex>,
Build self from a list of assignments.
sourcefn into_assignment<A: IdentifierT>(
self,
voter_at: impl Fn(Self::VoterIndex) -> Option<A>,
target_at: impl Fn(Self::TargetIndex) -> Option<A>
) -> Result<Vec<Assignment<A, Self::Accuracy>>, Error>
fn into_assignment<A: IdentifierT>(
self,
voter_at: impl Fn(Self::VoterIndex) -> Option<A>,
target_at: impl Fn(Self::TargetIndex) -> Option<A>
) -> Result<Vec<Assignment<A, Self::Accuracy>>, Error>
Convert self into a Vec<Assignment<A, Self::Accuracy>>
Provided Methods§
sourcefn average_edge_count(&self) -> usize
fn average_edge_count(&self) -> usize
Get the average edge count.
sourcefn score<A, FS>(
self,
stake_of: FS,
voter_at: impl Fn(Self::VoterIndex) -> Option<A>,
target_at: impl Fn(Self::TargetIndex) -> Option<A>
) -> Result<ElectionScore, Error>where
for<'r> FS: Fn(&'r A) -> VoteWeight,
A: IdentifierT,
fn score<A, FS>(
self,
stake_of: FS,
voter_at: impl Fn(Self::VoterIndex) -> Option<A>,
target_at: impl Fn(Self::TargetIndex) -> Option<A>
) -> Result<ElectionScore, Error>where
for<'r> FS: Fn(&'r A) -> VoteWeight,
A: IdentifierT,
Compute the score of this solution type.