Sha256: a54c2e370068867887a43d13f93274d05541f675c3def25d19005fa265aaf42c
Contents?: true
Size: 1.98 KB
Versions: 2
Compression:
Stored size: 1.98 KB
Contents
require 'hilbert/world/base' require 'hilbert/world/propositional_logic' module Hilbert module World class Entity @@propositions = [] class << self def <<(logic_str) @@propositions << to_rb_obj(logic_str) %|"Defined: #{logic_str} is TRUE"| end def impl(logic_str) # HOTFIX: we need to .. return eval_rslt(logic_str, 'UNDEFINED') if @@propositions.empty? logic = (@@propositions.inject(:*) >= to_rb_obj(logic_str)) str = logic.dpll!.to_s case str when 'TRUE' eval_rslt(logic_str, 'TRUE') when 'FALSE' eval_rslt(logic_str, 'FALSE') else logic = (@@propositions.inject(:*) >= (~to_rb_obj(logic_str))) str = logic.dpll!.to_s case str when 'TRUE' eval_rslt(logic_str, 'FALSE') when 'FALSE' eval_rslt(logic_str, 'TRUE') else eval_rslt(logic_str, 'UNDEFINED') end end end def atom(sym) unless sym.to_s == sym.to_s.upcase && sym.to_s.length == 1 raise 'Proposltionla variable should be capital character' end eval "$#{sym} ||= PropositionalLogic::Atom.new(:#{sym})" end def clear! @@propositions = [] end def paradox? return %|"FALSE"| if @@propositions.empty? str = (!!!!!!!(@@propositions.inject(:*) >= (atom(:P) * ~atom(:P)))).to_s case str when 'TRUE' %|"TRUE"| else %|"FALSE"| end end # Internal Utils def to_rb_obj(logic_str) lexeds = Lexer::WorldLexer.execute(logic_str) Parser::WorldParser.execute(lexeds) eval Parser::WorldParser.parsed_srt end def eval_rslt(logic_str, rslt) %|"Evaluate: #{logic_str} is #{rslt}"| end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
hilbert-0.0.2700320 | lib/hilbert/world.rb |
hilbert-0.0.2700300 | lib/hilbert/world.rb |