Sha256: ae95b716606b6a46ac174dac0e69c45a40168c818354c887e64b1057f68b49fc

Contents?: true

Size: 1.74 KB

Versions: 1

Compression:

Stored size: 1.74 KB

Contents

# Provides a ruby implementation of several common matching algorithms
#
# Author::    Abhishek Chandrasekhar  (mailto:me@abhchand.me)
# License::   MIT

class StableMatching
  class Member
    attr_reader :name, :received_proposals_from, :accepted_proposal_from
    attr_writer :preference_list

    def initialize(name)
      @name = name
      @accepted_proposal_from = nil
    end

    def to_s
      name
    end

    def preference_list
      if @preference_list.nil?
        raise "preference list not set for member: #{name}"
      end

      @preference_list
    end

    def current_proposer
      @accepted_proposal_from
    end

    def current_acceptor
      preference_list.detect do |member|
        member.accepted_proposal_from == self
      end
    end

    def accepted_proposal?
      !current_proposer.nil?
    end

    def would_prefer?(new_proposer)
      return true unless accepted_proposal?
      preference_of(new_proposer) > preference_of(current_proposer)
    end

    def accept_proposal_from!(member)
      @accepted_proposal_from = member
    end

    def reject!(member)
      @accepted_proposal_from = nil if current_proposer == member

      # Delete each member from the other member's preference list
      preference_list.delete(member)
      member.preference_list.delete(self)
    end

    def first_preference
      preference_list.first
    end

    def second_preference
      preference_list[1]
    end

    def last_preference
      preference_list.last
    end

    private

    def preference_of(member)
      index = preference_list.index(member)
      return if index.nil?

      # Return the preference as the inverse of the index so a smaller index
      # has a greater preference
      preference_list.size - index
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
stable-matching-0.1.0 lib/stable-matching/member.rb