Class: Axiom::Optimizer::Algebra::Join::EqualHeaders

Inherits:
Axiom::Optimizer::Algebra::Join show all
Defined in:
lib/axiom/optimizer/algebra/join.rb

Overview

Optimize when operands’ headers are equal

Constant Summary

Constants inherited from Axiom::Optimizer::Algebra::Join

CONTRADICTION

Constants inherited from Axiom::Optimizer

Identity, VERSION

Instance Attribute Summary

Attributes included from Function::Binary

#left, #right

Attributes inherited from Axiom::Optimizer

#operation

Instance Method Summary collapse

Methods included from Function::Binary

#initialize

Methods inherited from Axiom::Optimizer

chain, #initialize

Instance Method Details

#optimizable?Boolean

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Test if the operands’ headers are equal

Returns:

  • (Boolean)


44
45
46
# File 'lib/axiom/optimizer/algebra/join.rb', line 44

def optimizable?
  left.header.eql?(right.header)
end

#optimizeAlgebra::Intersection

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

A Join with equal headers is an Intersection



53
54
55
# File 'lib/axiom/optimizer/algebra/join.rb', line 53

def optimize
  left.intersect(right)
end