Class: Propose::Tree::Sequent

Inherits:
Node
  • Object
show all
Defined in:
lib/propose/tree/sequent.rb

Overview

Statement indicating that a set of premises (propositional formulae) can be used to prove to a conclusion (another propositional formula).

Sequents which the premises do not prove the conclusion are called invalid.

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods inherited from Node

#literal?

Constructor Details

#initialize(premises, conclusion) ⇒ Sequent

Returns a new instance of Sequent.



9
10
11
12
# File 'lib/propose/tree/sequent.rb', line 9

def initialize(premises, conclusion)
  @premises = premises
  @conclusion = conclusion
end

Instance Attribute Details

#conclusionObject (readonly)

Returns the value of attribute conclusion.



7
8
9
# File 'lib/propose/tree/sequent.rb', line 7

def conclusion
  @conclusion
end

#premisesObject (readonly)

Returns the value of attribute premises.



7
8
9
# File 'lib/propose/tree/sequent.rb', line 7

def premises
  @premises
end

Instance Method Details

#==(other) ⇒ Object



14
15
16
# File 'lib/propose/tree/sequent.rb', line 14

def ==(other)
  super || @premises == other.premises && @conclusion == other.conclusion
end

#childrenObject



18
19
20
# File 'lib/propose/tree/sequent.rb', line 18

def children
  premises + [conclusion]
end

#inspectObject



22
23
24
# File 'lib/propose/tree/sequent.rb', line 22

def inspect
  "#<Sequent [#{premises.map(&:inspect).join(', ')}] ⊢ #{conclusion.inspect}"
end

#to_sObject



26
27
28
# File 'lib/propose/tree/sequent.rb', line 26

def to_s
  "#{premises.map(&:to_s).join(', ')}#{conclusion}"
end