himanshu chauhanand vijay k. gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfhimanshu...

86
Democratic Elections in Faulty Distributed Systems Himanshu Chauhan and Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical and Computer Engineering, PDSL, UT Austin Democratic Elections - ICDCN’13 1 / 31

Upload: others

Post on 20-Sep-2020

5 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Democratic Elections in Faulty Distributed Systems

Himanshu Chauhan and Vijay K. Garg

Parallel and Distributed Systems Lab,Department of Electrical and Computer Engineering,

PDSL, UT Austin Democratic Elections - ICDCN’13 1 / 31

Page 2: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Motivation – Leader Election

Conventional Problem

Node with the highest id should be the leader. All the nodes in thesystem should agree on the leader.

Philosophers of Ancient Athens would protest!

PDSL, UT Austin Democratic Elections - ICDCN’13 2 / 31

Page 3: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Motivation – Leader Election

Conventional Problem

Node with the highest id should be the leader. All the nodes in thesystem should agree on the leader.

Philosophers of Ancient Athens would protest!

PDSL, UT Austin Democratic Elections - ICDCN’13 2 / 31

Page 4: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Motivation – Leader Election

Conventional Problem

Node with the highest id should be the leader. All the nodes in thesystem should agree on the leader.

Philosophers of Ancient Athens would protest!

PDSL, UT Austin Democratic Elections - ICDCN’13 2 / 31

Page 5: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Democratic Leader Election

Elect a leader

Each node has individual preferencesConduct an election where every node votes

Use Case:

Job processing system

Leader distributes work in the system

Worker nodes vote, based upon:

Latency of communication with prospective leaderIndividual work load

Enter ‘Byzantine’ Voters!

PDSL, UT Austin Democratic Elections - ICDCN’13 3 / 31

Page 6: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Democratic Leader Election

Elect a leader

Each node has individual preferencesConduct an election where every node votes

Use Case:

Job processing system

Leader distributes work in the system

Worker nodes vote, based upon:

Latency of communication with prospective leaderIndividual work load

Enter ‘Byzantine’ Voters!

PDSL, UT Austin Democratic Elections - ICDCN’13 3 / 31

Page 7: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Democratic Leader Election

Elect a leader

Each node has individual preferencesConduct an election where every node votes

Use Case:

Job processing system

Leader distributes work in the system

Worker nodes vote, based upon:

Latency of communication with prospective leaderIndividual work load

Enter ‘Byzantine’ Voters!

PDSL, UT Austin Democratic Elections - ICDCN’13 3 / 31

Page 8: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Democratic Leader Election

Elect a leader

Each node has individual preferencesConduct an election where every node votes

Use Case:

Job processing system

Leader distributes work in the system

Worker nodes vote, based upon:

Latency of communication with prospective leaderIndividual work load

Enter ‘Byzantine’ Voters!

PDSL, UT Austin Democratic Elections - ICDCN’13 3 / 31

Page 9: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Why Not Use Exisiting Approaches?

‘Multivalued Byzantine Agreement’, Turpin and Coan 1984,

‘k−set Consensus’, Prisco et al. 1999

Every voter sends her top choice

Run Byzantine Agreement

Agree on the choice with most votes

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b a2nd choice a a a a a a b3rd choice b b b

P1 P2 P3 P4 P5 P6 P7

1st choice c c c a2nd choice a a a a a a3rd choice c c c c

Elect choice with most votes (at top) : c or b But . . .

#(a > b) = 4, #(b > a) = 3 and #(a > c) = 4, #(c > a) = 3

PDSL, UT Austin Democratic Elections - ICDCN’13 4 / 31

Page 10: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Why Not Use Exisiting Approaches?

‘Multivalued Byzantine Agreement’, Turpin and Coan 1984,

‘k−set Consensus’, Prisco et al. 1999

Every voter sends her top choice

Run Byzantine Agreement

Agree on the choice with most votes

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b a2nd choice a a a a a a b3rd choice b b b

P1 P2 P3 P4 P5 P6 P7

1st choice c c c a2nd choice a a a a a a3rd choice c c c c

Elect choice with most votes (at top) : c or b But . . .

#(a > b) = 4, #(b > a) = 3 and #(a > c) = 4, #(c > a) = 3

PDSL, UT Austin Democratic Elections - ICDCN’13 4 / 31

Page 11: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Why Not Use Exisiting Approaches?

‘Multivalued Byzantine Agreement’, Turpin and Coan 1984,

‘k−set Consensus’, Prisco et al. 1999

Every voter sends her top choice

Run Byzantine Agreement

Agree on the choice with most votes

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b a2nd choice a a a a a a b3rd choice b b b

P1 P2 P3 P4 P5 P6 P7

1st choice c c c a2nd choice a a a a a a3rd choice c c c c

Elect choice with most votes (at top) : c or b

But . . .

#(a > b) = 4, #(b > a) = 3 and #(a > c) = 4, #(c > a) = 3

PDSL, UT Austin Democratic Elections - ICDCN’13 4 / 31

Page 12: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Why Not Use Exisiting Approaches?

‘Multivalued Byzantine Agreement’, Turpin and Coan 1984,

‘k−set Consensus’, Prisco et al. 1999

Every voter sends her top choice

Run Byzantine Agreement

Agree on the choice with most votes

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b a2nd choice a a a a a a b3rd choice b b b

P1 P2 P3 P4 P5 P6 P7

1st choice c c c a2nd choice a a a a a a3rd choice c c c c

Elect choice with most votes (at top) : c or b But . . .

#(a > b) = 4, #(b > a) = 3 and #(a > c) = 4, #(c > a) = 3

PDSL, UT Austin Democratic Elections - ICDCN’13 4 / 31

Page 13: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Why Not Use Exisiting Approaches?

‘Multivalued Byzantine Agreement’, Turpin and Coan 1984,

‘k−set Consensus’, Prisco et al. 1999

Every voter sends her top choice

Run Byzantine Agreement

Agree on the choice with most votes

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b a2nd choice a a a a a a b3rd choice b b b

P1 P2 P3 P4 P5 P6 P7

1st choice c c c a2nd choice a a a a a a3rd choice c c c c

Elect choice with most votes (at top) : c or b But . . .

#(a > b) = 4, #(b > a) = 3

and #(a > c) = 4, #(c > a) = 3

PDSL, UT Austin Democratic Elections - ICDCN’13 4 / 31

Page 14: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Why Not Use Exisiting Approaches?

‘Multivalued Byzantine Agreement’, Turpin and Coan 1984,

‘k−set Consensus’, Prisco et al. 1999

Every voter sends her top choice

Run Byzantine Agreement

Agree on the choice with most votes

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b a2nd choice a a a a a a b3rd choice b b b

P1 P2 P3 P4 P5 P6 P7

1st choice c c c a2nd choice a a a a a a3rd choice c c c c

Elect choice with most votes (at top) : c or b But . . .

#(a > b) = 4, #(b > a) = 3 and #(a > c) = 4, #(c > a) = 3

PDSL, UT Austin Democratic Elections - ICDCN’13 4 / 31

Page 15: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Model & Constructs

System

n processes (voters)

f Byzantine processes (voters) : bad

Non-faulty processes (voters) : good

f < n/3

Jargon

A: Set of candidatesRanking: Total order over the set of candidates.Vote: A voter’s preference ranking over candidates.Ballot : Collection of all votes.Scheme : Mechanism that takes a ballot as input and outputs awinner.

PDSL, UT Austin Democratic Elections - ICDCN’13 5 / 31

Page 16: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Model & Constructs

System

n processes (voters)

f Byzantine processes (voters) : bad

Non-faulty processes (voters) : good

f < n/3

Jargon

A: Set of candidatesRanking: Total order over the set of candidates.Vote: A voter’s preference ranking over candidates.Ballot : Collection of all votes.Scheme : Mechanism that takes a ballot as input and outputs awinner.

PDSL, UT Austin Democratic Elections - ICDCN’13 5 / 31

Page 17: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Conducting Distributed Democratic Elections

Use Interactive Consistency

Agree on everyone’s vote1

Agree on the ballot

Use a scheme to decide the winner

1We use Gradecast based Byzantine Agreement by Ben-Or et al.PDSL, UT Austin Democratic Elections - ICDCN’13 6 / 31

Page 18: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice

Social Choice

Given a ballot, declare a candidate as the winner of the election.

Arrow 1950-51, Buchanan 1954, Graaff 1957

Byzantine Social Choice

Given a set of n processes of which at most f are faulty, and a set A ofk choices, design a protocol elects one candidate as the social choice,while meeting the ‘protocol requirements’.

PDSL, UT Austin Democratic Elections - ICDCN’13 7 / 31

Page 19: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Welfare

Social Welfare

Given a ballot, produce a total order over the set of candidate.

Arrow 1950-51, Buchanan 1954, Graaff 1957, Farquharson 1969

Byzantine Social Welfare

Given a set of n processes of which at most f are faulty, and a set A ofk choices, design a protocol that produces a total order over A, whilemeeting the ‘protocol requirements’.

PDSL, UT Austin Democratic Elections - ICDCN’13 8 / 31

Page 20: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Protocol Requirements

1 Agreement: All good processes decide on the same choice/ranking.

2 Termination: The protocol terminates in a finite number ofrounds.

PDSL, UT Austin Democratic Elections - ICDCN’13 9 / 31

Page 21: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Protocol Requirements

1 Agreement: All good processes decide on the same choice/ranking.

2 Termination: The protocol terminates in a finite number ofrounds.

PDSL, UT Austin Democratic Elections - ICDCN’13 9 / 31

Page 22: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Validity Condition

Validity: Requirement on the choice/ranking decided, based upon thevotes of good processes.

S: If v is the top choice of all good voters, then v must be thewinner.

S′: If v is the last choice of all good voters, then v must not bethe winner.

M ′: If v is last choice of majority of good voters, then v must notbe the winner.

PDSL, UT Austin Democratic Elections - ICDCN’13 10 / 31

Page 23: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Validity Condition

Validity: Requirement on the choice/ranking decided, based upon thevotes of good processes.

S: If v is the top choice of all good voters, then v must be thewinner.

S′: If v is the last choice of all good voters, then v must not bethe winner.

M ′: If v is last choice of majority of good voters, then v must notbe the winner.

PDSL, UT Austin Democratic Elections - ICDCN’13 10 / 31

Page 24: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Validity Conditions

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

Table: Ballot of 7 votes (P6, P7 Byzantine)

M (Elect majority of good voters) : elect b

P (Do not elect a candidate that is not the top choice of any good voters) :

do not elect a

PDSL, UT Austin Democratic Elections - ICDCN’13 11 / 31

Page 25: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Validity Conditions

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

Table: Ballot of 7 votes (P6, P7 Byzantine)

M (Elect majority of good voters) : elect b

P (Do not elect a candidate that is not the top choice of any good voters) :

do not elect a

PDSL, UT Austin Democratic Elections - ICDCN’13 11 / 31

Page 26: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Validity Conditions

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

Table: Ballot of 7 votes (P6, P7 Byzantine)

M (Elect majority of good voters) : elect b

P (Do not elect a candidate that is not the top choice of any good voters) :

do not elect a

PDSL, UT Austin Democratic Elections - ICDCN’13 11 / 31

Page 27: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Impossibilities

BSC(k, V )

Byzantine Social Choice problem with k candidates, and validitycondition/requirement V .

BSC(2,M):

M : elect top choice of majority of good votes

Impossible to solve for f ≥ n/4

Reason:f ≥ n/4⇒ can not differentiate b/w good and bad votes

BSC(2,M ′):

M ′: do not elect the last choice of majority of good votes

Impossible to solve for f ≥ n/4

PDSL, UT Austin Democratic Elections - ICDCN’13 12 / 31

Page 28: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Impossibilities

BSC(k, V )

Byzantine Social Choice problem with k candidates, and validitycondition/requirement V .

BSC(2,M):

M : elect top choice of majority of good votes

Impossible to solve for f ≥ n/4

Reason:f ≥ n/4⇒ can not differentiate b/w good and bad votes

BSC(2,M ′):

M ′: do not elect the last choice of majority of good votes

Impossible to solve for f ≥ n/4

PDSL, UT Austin Democratic Elections - ICDCN’13 12 / 31

Page 29: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Impossibilities

BSC(k, V )

Byzantine Social Choice problem with k candidates, and validitycondition/requirement V .

BSC(2,M):

M : elect top choice of majority of good votes

Impossible to solve for f ≥ n/4

Reason:f ≥ n/4⇒ can not differentiate b/w good and bad votes

BSC(2,M ′):

M ′: do not elect the last choice of majority of good votes

Impossible to solve for f ≥ n/4

PDSL, UT Austin Democratic Elections - ICDCN’13 12 / 31

Page 30: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Impossibilities

BSC(k, V )

Byzantine Social Choice problem with k candidates, and validitycondition/requirement V .

BSC(2,M):

M : elect top choice of majority of good votes

Impossible to solve for f ≥ n/4

Reason:f ≥ n/4⇒ can not differentiate b/w good and bad votes

BSC(2,M ′):

M ′: do not elect the last choice of majority of good votes

Impossible to solve for f ≥ n/4

PDSL, UT Austin Democratic Elections - ICDCN’13 12 / 31

Page 31: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Possibilities

BSC(k, S ∧M ′):

S: if v is first choice of all good voters, elect vM ′: if v′ is last choice of majority of good voters, do not elect v′

Solvable for k ≥ 3

Approach:

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

n = 7, f = 2, b(n− f)/2 + 1c = 3

Round 1 : Agree on last choices of all voters

Remove any candidates that appears b(n− f)/2 + 1c times or more

f < n/3 ∧ k ≥ 3⇒ at least one candidate that would not be removed

Round 2 : Use top choices from remaining candidates, agree and decide

PDSL, UT Austin Democratic Elections - ICDCN’13 13 / 31

Page 32: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Possibilities

BSC(k, S ∧M ′):

S: if v is first choice of all good voters, elect vM ′: if v′ is last choice of majority of good voters, do not elect v′

Solvable for k ≥ 3

Approach:

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

n = 7, f = 2, b(n− f)/2 + 1c = 3

Round 1 : Agree on last choices of all voters

Remove any candidates that appears b(n− f)/2 + 1c times or more

f < n/3 ∧ k ≥ 3⇒ at least one candidate that would not be removed

Round 2 : Use top choices from remaining candidates, agree and decide

PDSL, UT Austin Democratic Elections - ICDCN’13 13 / 31

Page 33: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Possibilities

BSC(k, S ∧M ′):

S: if v is first choice of all good voters, elect vM ′: if v′ is last choice of majority of good voters, do not elect v′

Solvable for k ≥ 3

Approach:

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

n = 7, f = 2, b(n− f)/2 + 1c = 3

Round 1 : Agree on last choices of all voters

Remove any candidates that appears b(n− f)/2 + 1c times or more

f < n/3 ∧ k ≥ 3⇒ at least one candidate that would not be removed

Round 2 : Use top choices from remaining candidates, agree and decide

PDSL, UT Austin Democratic Elections - ICDCN’13 13 / 31

Page 34: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Possibilities

BSC(k, S ∧M ′):

S: if v is first choice of all good voters, elect vM ′: if v′ is last choice of majority of good voters, do not elect v′

Solvable for k ≥ 3

Approach:

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

n = 7, f = 2, b(n− f)/2 + 1c = 3

Round 1 : Agree on last choices of all voters

Remove any candidates that appears b(n− f)/2 + 1c times or more

f < n/3 ∧ k ≥ 3⇒ at least one candidate that would not be removed

Round 2 : Use top choices from remaining candidates, agree and decide

PDSL, UT Austin Democratic Elections - ICDCN’13 13 / 31

Page 35: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Possibilities

BSC(k, S ∧M ′):

S: if v is first choice of all good voters, elect vM ′: if v′ is last choice of majority of good voters, do not elect v′

Solvable for k ≥ 3

Approach:

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

n = 7, f = 2, b(n− f)/2 + 1c = 3

Round 1 : Agree on last choices of all voters

Remove any candidates that appears b(n− f)/2 + 1c times or more

f < n/3 ∧ k ≥ 3⇒ at least one candidate that would not be removed

Round 2 : Use top choices from remaining candidates, agree and decide

PDSL, UT Austin Democratic Elections - ICDCN’13 13 / 31

Page 36: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Possibilities

BSC(k, S ∧M ′):

S: if v is first choice of all good voters, elect vM ′: if v′ is last choice of majority of good voters, do not elect v′

Solvable for k ≥ 3

Approach:

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

n = 7, f = 2, b(n− f)/2 + 1c = 3

Round 1 : Agree on last choices of all voters

Remove any candidates that appears b(n− f)/2 + 1c times or more

f < n/3 ∧ k ≥ 3⇒ at least one candidate that would not be removed

Round 2 : Use top choices from remaining candidates, agree and decide

PDSL, UT Austin Democratic Elections - ICDCN’13 13 / 31

Page 37: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Choice – Possibilities

BSC(k, S ∧M ′):

S: if v is first choice of all good voters, elect vM ′: if v′ is last choice of majority of good voters, do not elect v′

Solvable for k ≥ 3

Approach:

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

n = 7, f = 2, b(n− f)/2 + 1c = 3

Round 1 : Agree on last choices of all voters

Remove any candidates that appears b(n− f)/2 + 1c times or more

f < n/3 ∧ k ≥ 3⇒ at least one candidate that would not be removed

Round 2 : Use top choices from remaining candidates, agree and decide

PDSL, UT Austin Democratic Elections - ICDCN’13 13 / 31

Page 38: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

BSC(k, V ) Results – Summarized

Requirement Unsolvable SolvableS - k ≥ 2S′ - k ≥ 2M f ≥ n/4 ∧ k ≥ 2 -M ′ f ≥ n/4 ∧ k = 2 k ≥ 3P f ≥ 1 ∧ k ≥ n f < min(n/k, n/3)

∧ 2 ≤ k < n

Table: Impossibilities & Possibilities for BSC(k, V )

PDSL, UT Austin Democratic Elections - ICDCN’13 14 / 31

Page 39: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Welfare – Schemes

Given a ballot, produce a total order over the set of candidates

Place-Plurality Scheme:k candidates

for 1 ≤ i ≤ kci = candidate with most votes at position i in ballotresult[i] = ci

done

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

Result : b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 15 / 31

Page 40: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Welfare – Schemes

Given a ballot, produce a total order over the set of candidates

Place-Plurality Scheme:

k candidates

for 1 ≤ i ≤ kci = candidate with most votes at position i in ballotresult[i] = ci

done

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

Result : b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 15 / 31

Page 41: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Welfare – Schemes

Given a ballot, produce a total order over the set of candidates

Place-Plurality Scheme:k candidates

for 1 ≤ i ≤ kci = candidate with most votes at position i in ballotresult[i] = ci

done

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

Result : b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 15 / 31

Page 42: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Welfare – Schemes

Given a ballot, produce a total order over the set of candidates

Place-Plurality Scheme:k candidates

for 1 ≤ i ≤ kci = candidate with most votes at position i in ballotresult[i] = ci

done

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

Result : b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 15 / 31

Page 43: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Byzantine Social Welfare – Schemes

Given a ballot, produce a total order over the set of candidates

Place-Plurality Scheme:k candidates

for 1 ≤ i ≤ kci = candidate with most votes at position i in ballotresult[i] = ci

done

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

Result : b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 15 / 31

Page 44: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Median of a Ballot

Distance (d) between rankings: # of pair-orderings on which rankingsdifferPairwise Comparison, Condorcet, circa 1785

r r′ da b 1b a – differ onc c (a, b)

r r′ da c 2b b – differ onc a (a, b) and (b, c)

Median (m) of ballot: Ranking that has least distance from overallpair-wise comparisons in the ballot

PDSL, UT Austin Democratic Elections - ICDCN’13 16 / 31

Page 45: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Median of a Ballot

Distance (d) between rankings: # of pair-orderings on which rankingsdifferPairwise Comparison, Condorcet, circa 1785

r r′ da b 1b a – differ onc c (a, b)

r r′ da c 2b b – differ onc a (a, b) and (b, c)

Median (m) of ballot: Ranking that has least distance from overallpair-wise comparisons in the ballot

PDSL, UT Austin Democratic Elections - ICDCN’13 16 / 31

Page 46: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Median of a Ballot

Distance (d) between rankings: # of pair-orderings on which rankingsdifferPairwise Comparison, Condorcet, circa 1785

r r′ da b 1b a – differ onc c (a, b)

r r′ da c 2b b – differ onc a (a, b) and (b, c)

Median (m) of ballot: Ranking that has least distance from overallpair-wise comparisons in the ballot

PDSL, UT Austin Democratic Elections - ICDCN’13 16 / 31

Page 47: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Median of a Ballot

Distance (d) between rankings: # of pair-orderings on which rankingsdifferPairwise Comparison, Condorcet, circa 1785

r r′ da b 1b a – differ onc c (a, b)

r r′ da c 2b b – differ onc a (a, b) and (b, c)

Median (m) of ballot: Ranking that has least distance from overallpair-wise comparisons in the ballot

PDSL, UT Austin Democratic Elections - ICDCN’13 16 / 31

Page 48: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme

(1) J. Kemeny, 1959, (2) H. Young, 1995

Goal: Get as close to the median as possible.

For ranking r, let Pr := ordered pairs from r.Example: r = a � b � c then, Pr = {(a, b) (b, c) (a, c)}

For a given ballot B:

score(r,B) = Σ (frequency of p in B)

Sk: set of all permutations of k candidates (k! permutations)

foreach ranking r ∈ Sk docompute scorer = score(r,B)

doneselect ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 17 / 31

Page 49: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme

(1) J. Kemeny, 1959, (2) H. Young, 1995

Goal: Get as close to the median as possible.

For ranking r, let Pr := ordered pairs from r.

Example: r = a � b � c then, Pr = {(a, b) (b, c) (a, c)}

For a given ballot B:

score(r,B) = Σ (frequency of p in B)

Sk: set of all permutations of k candidates (k! permutations)

foreach ranking r ∈ Sk docompute scorer = score(r,B)

doneselect ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 17 / 31

Page 50: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme

(1) J. Kemeny, 1959, (2) H. Young, 1995

Goal: Get as close to the median as possible.

For ranking r, let Pr := ordered pairs from r.Example: r = a � b � c then, Pr = {(a, b) (b, c) (a, c)}

For a given ballot B:

score(r,B) = Σ (frequency of p in B)

Sk: set of all permutations of k candidates (k! permutations)

foreach ranking r ∈ Sk docompute scorer = score(r,B)

doneselect ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 17 / 31

Page 51: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme

(1) J. Kemeny, 1959, (2) H. Young, 1995

Goal: Get as close to the median as possible.

For ranking r, let Pr := ordered pairs from r.Example: r = a � b � c then, Pr = {(a, b) (b, c) (a, c)}

For a given ballot B:

score(r,B) = Σ (frequency of p in B)

Sk: set of all permutations of k candidates (k! permutations)

foreach ranking r ∈ Sk docompute scorer = score(r,B)

done

select ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 17 / 31

Page 52: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme

(1) J. Kemeny, 1959, (2) H. Young, 1995

Goal: Get as close to the median as possible.

For ranking r, let Pr := ordered pairs from r.Example: r = a � b � c then, Pr = {(a, b) (b, c) (a, c)}

For a given ballot B:

score(r,B) = Σ (frequency of p in B)

Sk: set of all permutations of k candidates (k! permutations)

foreach ranking r ∈ Sk docompute scorer = score(r,B)

doneselect ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 17 / 31

Page 53: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme – Example

Candidates: {a,b,c}

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

Permutations:

a a b b c cb c a c a bc b c a b a

Permutations:

a a b b c cb c a c a bc b c a b a1212 11 11 10 10 9

pairs: {(a, b) (b, c) (a, c)}

Kemeny-Young Scheme Result: a � b � c

PDSL, UT Austin Democratic Elections - ICDCN’13 18 / 31

Page 54: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme – Example

Candidates: {a,b,c}

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

Permutations:

a a b b c cb c a c a bc b c a b a

Permutations:

a a b b c cb c a c a bc b c a b a1212 11 11 10 10 9

pairs: {(a, b) (b, c) (a, c)}

Kemeny-Young Scheme Result: a � b � c

PDSL, UT Austin Democratic Elections - ICDCN’13 18 / 31

Page 55: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme – Example

Candidates: {a,b,c}

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

Permutations:

a a b b c cb c a c a bc b c a b a

Permutations:

a a b b c cb c a c a bc b c a b a

1212 11 11 10 10 9

pairs: {(a, b) (b, c) (a, c)}

Kemeny-Young Scheme Result: a � b � c

PDSL, UT Austin Democratic Elections - ICDCN’13 18 / 31

Page 56: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme – Example

Candidates: {a,b,c}

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

Permutations:

a a b b c cb c a c a bc b c a b a

Permutations:

a a b b c cb c a c a bc b c a b a12

12 11 11 10 10 9

pairs: {(a, b) (b, c) (a, c)}

Kemeny-Young Scheme Result: a � b � c

PDSL, UT Austin Democratic Elections - ICDCN’13 18 / 31

Page 57: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme – Example

Candidates: {a,b,c}

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

Permutations:

a a b b c cb c a c a bc b c a b a

Permutations:

a a b b c cb c a c a bc b c a b a

12

12 11 11 10 10 9

pairs: {(a, b) (b, c) (a, c)}

Kemeny-Young Scheme Result: a � b � c

PDSL, UT Austin Democratic Elections - ICDCN’13 18 / 31

Page 58: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Kemeny-Young Scheme – Example

Candidates: {a,b,c}

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

#(a � b) = 4, #(b � a) = 3, #(a � c) = 4,#(c � a) = 3, #(b � c) = 4, #(c � b) = 3

Permutations:

a a b b c cb c a c a bc b c a b a

Permutations:

a a b b c cb c a c a bc b c a b a

12

12 11 11 10 10 9

pairs: {(a, b) (b, c) (a, c)}

Kemeny-Young Scheme Result: a � b � c

PDSL, UT Austin Democratic Elections - ICDCN’13 18 / 31

Page 59: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young Scheme (this paper)

Objective: Minimize the influence of bad voters on the outcome

f bad voters (f < n/3)

B: Agreed upon ballot; Sk: set of all permutations of k candidates

foreach ranking r ∈ Sk doF = f most distant rankings from r in Bdefine B′ = B\Fcompute scorer = score(r,B′)

done

select ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 19 / 31

Page 60: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young Scheme (this paper)

Objective: Minimize the influence of bad voters on the outcome

f bad voters (f < n/3)

B: Agreed upon ballot; Sk: set of all permutations of k candidates

foreach ranking r ∈ Sk doF = f most distant rankings from r in Bdefine B′ = B\Fcompute scorer = score(r,B′)

done

select ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 19 / 31

Page 61: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young Scheme (this paper)

Objective: Minimize the influence of bad voters on the outcome

f bad voters (f < n/3)

B: Agreed upon ballot; Sk: set of all permutations of k candidates

foreach ranking r ∈ Sk doF = f most distant rankings from r in Bdefine B′ = B\Fcompute scorer = score(r,B′)

done

select ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 19 / 31

Page 62: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young Scheme (this paper)

Objective: Minimize the influence of bad voters on the outcome

f bad voters (f < n/3)

B: Agreed upon ballot; Sk: set of all permutations of k candidates

foreach ranking r ∈ Sk doF = f most distant rankings from r in Bdefine B′ = B\Fcompute scorer = score(r,B′)

done

select ranking with maximum scorer value as the outcome

PDSL, UT Austin Democratic Elections - ICDCN’13 19 / 31

Page 63: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young – Example

n = 7, f = 2

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P6 P7

1st choice b b b c a2nd choice a a a a b3rd choice c c c b c

a a b b c cb c a c a bc b c a b a

119 8 11 6 10 6

Pruned-Kemeny Scheme Result: b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 20 / 31

Page 64: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young – Example

n = 7, f = 2

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P6 P7

1st choice b b b c a2nd choice a a a a b3rd choice c c c b c

a a b b c cb c a c a bc b c a b a

119 8 11 6 10 6

Pruned-Kemeny Scheme Result: b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 20 / 31

Page 65: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young – Example

n = 7, f = 2

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P6 P7

1st choice b b b c a2nd choice a a a a b3rd choice c c c b c

a a b b c cb c a c a bc b c a b a

119 8 11 6 10 6

Pruned-Kemeny Scheme Result: b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 20 / 31

Page 66: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young – Example

n = 7, f = 2

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P6 P7

1st choice b b b c a2nd choice a a a a b3rd choice c c c b c

a a b b c cb c a c a bc b c a b a

11

9 8 11 6 10 6

Pruned-Kemeny Scheme Result: b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 20 / 31

Page 67: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young – Example

n = 7, f = 2

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P6 P7

1st choice b b b c a2nd choice a a a a b3rd choice c c c b c

a a b b c cb c a c a bc b c a b a

11

9 8 11 6 10 6

Pruned-Kemeny Scheme Result: b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 20 / 31

Page 68: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Pruned-Kemeny-Young – Example

n = 7, f = 2

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P4 P5 P6 P7

1st choice b b b c c c a2nd choice a a a a a a b3rd choice c c c b b b c

P1 P2 P3 P6 P7

1st choice b b b c a2nd choice a a a a b3rd choice c c c b c

a a b b c cb c a c a bc b c a b a

11

9 8 11 6 10 6

Pruned-Kemeny Scheme Result: b � a � c

PDSL, UT Austin Democratic Elections - ICDCN’13 20 / 31

Page 69: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Evaluating Scheme Efficacy

Suppose ω is an ideal ranking over k candidates

ω as the election outcome ⇒ maximum social welfare

All good voters in the system favor ωgoodProb: probability of a good voter putting a � b in her vote ifa �ω b

All bad voters in the system act hostile

try to minimize social welfare by voting against ωbadProb: probability of a bad voter putting b � a in her vote ifa �ω b

Analyze outcomes generated by schemes

# of voters = 100, # of bad voters = 33, badProb = 0.9

PDSL, UT Austin Democratic Elections - ICDCN’13 21 / 31

Page 70: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Evaluating Scheme Efficacy

Suppose ω is an ideal ranking over k candidates

ω as the election outcome ⇒ maximum social welfare

All good voters in the system favor ωgoodProb: probability of a good voter putting a � b in her vote ifa �ω b

All bad voters in the system act hostile

try to minimize social welfare by voting against ωbadProb: probability of a bad voter putting b � a in her vote ifa �ω b

Analyze outcomes generated by schemes

# of voters = 100, # of bad voters = 33, badProb = 0.9

PDSL, UT Austin Democratic Elections - ICDCN’13 21 / 31

Page 71: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Evaluating Scheme Efficacy

Suppose ω is an ideal ranking over k candidates

ω as the election outcome ⇒ maximum social welfare

All good voters in the system favor ωgoodProb: probability of a good voter putting a � b in her vote ifa �ω b

All bad voters in the system act hostile

try to minimize social welfare by voting against ωbadProb: probability of a bad voter putting b � a in her vote ifa �ω b

Analyze outcomes generated by schemes

# of voters = 100, # of bad voters = 33, badProb = 0.9

PDSL, UT Austin Democratic Elections - ICDCN’13 21 / 31

Page 72: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Evaluating Scheme Efficacy

Suppose ω is an ideal ranking over k candidates

ω as the election outcome ⇒ maximum social welfare

All good voters in the system favor ωgoodProb: probability of a good voter putting a � b in her vote ifa �ω b

All bad voters in the system act hostile

try to minimize social welfare by voting against ωbadProb: probability of a bad voter putting b � a in her vote ifa �ω b

Analyze outcomes generated by schemes

# of voters = 100, # of bad voters = 33, badProb = 0.9

PDSL, UT Austin Democratic Elections - ICDCN’13 21 / 31

Page 73: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Evaluating Scheme Efficacy

Suppose ω is an ideal ranking over k candidates

ω as the election outcome ⇒ maximum social welfare

All good voters in the system favor ωgoodProb: probability of a good voter putting a � b in her vote ifa �ω b

All bad voters in the system act hostile

try to minimize social welfare by voting against ωbadProb: probability of a bad voter putting b � a in her vote ifa �ω b

Analyze outcomes generated by schemes

# of voters = 100, # of bad voters = 33, badProb = 0.9

PDSL, UT Austin Democratic Elections - ICDCN’13 21 / 31

Page 74: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Simulation Results

Average (of 50 ballots) distances of produced outcomes from the idealranking

0

0.5

1

1.5

2

2.5

3

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityKemenyPruned

(a) # of Candidates = 3

0

1

2

3

4

5

6

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityKemenyPruned

(b) # of Candidates = 4

PDSL, UT Austin Democratic Elections - ICDCN’13 22 / 31

Page 75: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Simulation Results, contd.

Average (of 50 ballots) distances of produced outcomes from the idealranking

0

2

4

6

8

10

12

14

16

18

20

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityKemenyPruned

(c) # of Candidates = 7

0

5

10

15

20

25

30

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityKemenyPruned

(d) # of Candidates = 8

PDSL, UT Austin Democratic Elections - ICDCN’13 23 / 31

Page 76: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Conclusion

Introduction of democratic election problem in distributed systems

Pruned-Kemeny-Young Scheme for Byzantine Social Welfareproblem

PDSL, UT Austin Democratic Elections - ICDCN’13 24 / 31

Page 77: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Conclusion

Introduction of democratic election problem in distributed systems

Pruned-Kemeny-Young Scheme for Byzantine Social Welfareproblem

PDSL, UT Austin Democratic Elections - ICDCN’13 24 / 31

Page 78: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Future Work

Pruned-Kemeny-Young (and Kemeny-Young)

NP-Hard

Yet produce ‘better’ resultsExplore techniques for finding ‘better’ outcomes in polynomial steps

PDSL, UT Austin Democratic Elections - ICDCN’13 25 / 31

Page 79: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Future Work

Pruned-Kemeny-Young (and Kemeny-Young)

NP-HardYet produce ‘better’ results

Explore techniques for finding ‘better’ outcomes in polynomial steps

PDSL, UT Austin Democratic Elections - ICDCN’13 25 / 31

Page 80: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Future Work

Pruned-Kemeny-Young (and Kemeny-Young)

NP-HardYet produce ‘better’ resultsExplore techniques for finding ‘better’ outcomes in polynomial steps

PDSL, UT Austin Democratic Elections - ICDCN’13 25 / 31

Page 81: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Thanks!

PDSL, UT Austin Democratic Elections - ICDCN’13 26 / 31

Page 82: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Backup

0

0.5

1

1.5

2

2.5

3

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityPairwise

BordaKemenyPruned

(e) # of Candidates = 3

0

1

2

3

4

5

6

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityPairwise

BordaKemenyPruned

(f) # of Candidates = 4

PDSL, UT Austin Democratic Elections - ICDCN’13 27 / 31

Page 83: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Backup

Average (of 50 ballots) distances of produced outcomes from the idealranking

0

1

2

3

4

5

6

7

8

9

10

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityKemenyPruned

(g) # of Candidates = 5

0

2

4

6

8

10

12

14

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityKemenyPruned

(h) # of Candidates = 6

PDSL, UT Austin Democratic Elections - ICDCN’13 28 / 31

Page 84: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Backup

0

1

2

3

4

5

6

7

8

9

10

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityPairwise

BordaKemenyPruned

(i) # of Candidates = 5

0

2

4

6

8

10

12

14

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityPairwise

BordaKemenyPruned

(j) # of Candidates = 6

PDSL, UT Austin Democratic Elections - ICDCN’13 29 / 31

Page 85: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Backup

0

2

4

6

8

10

12

14

16

18

20

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityPairwise

BordaKemenyPruned

(k) # of Candidates = 7

0

5

10

15

20

25

30

0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9

Avg

. D

ista

nce

fro

m I

de

al

goodProb

PlacePluralityPairwise

BordaKemenyPruned

(l) # of Candidates = 8

PDSL, UT Austin Democratic Elections - ICDCN’13 30 / 31

Page 86: Himanshu Chauhanand Vijay K. Gargusers.ece.utexas.edu/~garg/dist/icdcn13-himanshu.pdfHimanshu Chauhanand Vijay K. Garg Parallel and Distributed Systems Lab, Department of Electrical

Related Work

Arrow’s Impossibility Theorem, and his work on Social Choice andWelfare Theory

1950, 1951

Pairwise Comparison Schemes, Social Welfare Schemes, Theory ofVoting, Welfare Economics

Condorcet circa 1785, Buchanan 1954, Graaff 1957, Kemeny 1959,Farquharson 1969, Ishikawa et al. 1979, Young 1988

Multivalued Byzantine Agreement Schemes, Byzantine LeaderElection, k-set Consensus

Turpin and Coan 1984, Ostrovsky et al. 1994, Russell et al. 1998,Kapron et al. 2008, Prisco et al. 1999

PDSL, UT Austin Democratic Elections - ICDCN’13 31 / 31