Class: Hornetseye::Mask

Inherits:
Node show all
Defined in:
lib/multiarray/mask.rb

Overview

Class for representing masking operations

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Node

#+@, #<=>, ===, #[], #[]=, #allocate, #b=, #b_with_decompose, basetype, #basetype, #between?, bool, byte, #check_shape, #clip, #coerce, coercion_bool, coercion_byte, coercion_maxint, #collect, compilable?, #components, cond, #conditional, #convolve, #decompose, define_binary_op, define_unary_op, descriptor, #diagonal, #dilate, #dimension, dimension, #downsample, #dup, #each, #empty?, #eq_with_multiarray, #erode, #fill!, #finalised?, #flip, float, float_scalar, floating, #fmod_with_float, #force, #g=, #g_with_decompose, #gauss_blur, #gauss_gradient, #get, #height, #histogram, #histogram_with_rgb, identity, #if, #if_else, #imag=, #imag_with_decompose, indgen, #inject, #inspect, #integral, #lut, #lut_with_rgb, #malloc, #mask, match, #matched?, #max, maxint, #mean, #memorise, #memory, #min, #normalise, #prod, #r=, #r_with_decompose, #range, #real=, #real_with_decompose, #reshape, #rgb?, rgb?, #roll, scalar, shape, #shift, #simplify, #size, #sobel, #stretch, #stride, #strides, strip, subst, #sum, #swap_rgb_with_scalar, #table, #to_a, #to_s, to_s, #to_type, to_type, #to_type_with_identity, #to_type_with_rgb, #transpose, typecode, typecodes, #unmask, #unroll, variables, #warp, #width

Methods included from Field_::Match

#align, #fit

Methods included from FLOAT_::Match

#align, #fit

Methods included from OBJECT::Match

#align, #fit

Methods included from COMPLEX_::Match

#align, #fit

Methods included from BOOL::Match

#fit

Methods included from RGB_::Match

#align, #fit

Methods included from INT_::Match

#fit

Constructor Details

#initialize(dest, source, m, index) ⇒ Mask

Constructor

Parameters:

  • dest (Node)

    Target array to write histogram to.

  • source (Node)

    Source array with values to apply mask to.

  • m (Node)

    Boolean array with values of mask.

  • index (Node)

    Counter for maintaining size of result.



44
45
46
# File 'lib/multiarray/mask.rb', line 44

def initialize( dest, source, m, index )
  @dest, @source, @m, @index = dest, source, m, index
end

Class Method Details

.finalised?Boolean

Check whether objects of this class are finalised computations

Returns:

  • (Boolean)

    Returns false.



30
31
32
# File 'lib/multiarray/mask.rb', line 30

def finalised?
  false
end

Instance Method Details

#compilable?Boolean

Check whether this term is compilable

Returns:

  • (Boolean)

    Returns whether this term is compilable.



143
144
145
# File 'lib/multiarray/mask.rb', line 143

def compilable?
  [ @dest, @source, @m, @index ].all? { |value| value.compilable? }
end

#demandNode

Perform masking operation

Returns:

  • (Node)

    Result of computation



73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# File 'lib/multiarray/mask.rb', line 73

def demand
  if variables.empty?
    index = @index.simplify
    if @m.dimension > 0
      @m.shape.last.times do |i|
        m = @m.element INT.new( i )
        source = @source.element INT.new( i )
        Mask.new( @dest, source, m, index ).demand
      end  
    else
      @m.if do
        Store.new( @dest.element( index ), @source ).demand
        index.assign index + 1
      end
    end
    if @index.is_a? Pointer_
      @index.store index
    else
      @index.assign index
    end
    @dest
  else
    super
  end
end

#descriptor(hash) ⇒ String

Get unique descriptor of this object

Parameters:

  • hash (Hash)

    Labels for any variables.

Returns:

  • (String)

    Descriptor of this object,



55
56
57
58
# File 'lib/multiarray/mask.rb', line 55

def descriptor( hash )
  "Mask(#{@dest.descriptor( hash )},#{@source.descriptor( hash )}," +
    "#{@m.descriptor( hash )},#{@index.descriptor( hash )})"
end

#shapeObject



64
65
66
# File 'lib/multiarray/mask.rb', line 64

def shape
  @dest.shape
end

#stripArray<Array,Node>

Strip of all values

Split up into variables, values, and a term where all values have been replaced with variables.

values, and the term based on variables.

Returns:



131
132
133
134
135
136
# File 'lib/multiarray/mask.rb', line 131

def strip
  stripped = [ @dest, @source, @m, @index ].collect { |value| value.strip }
  return stripped.inject([]) { |vars,elem| vars + elem[0] },
       stripped.inject([]) { |values,elem| values + elem[1] },
       self.class.new( *stripped.collect { |elem| elem[2] } )
end

#subst(hash) ⇒ Node

Substitute variables

Substitute the variables with the values given in the hash.

Parameters:

  • hash (Hash)

    Substitutions to apply.

Returns:

  • (Node)

    Term with substitutions applied.



108
109
110
111
# File 'lib/multiarray/mask.rb', line 108

def subst( hash )
  self.class.new @dest.subst( hash ), @source.subst( hash ), @m.subst( hash ),
                 @index.subst( hash )
end

#typecodeObject



60
61
62
# File 'lib/multiarray/mask.rb', line 60

def typecode
  @dest.typecode
end

#variablesSet

Get variables contained in this term

Returns:

  • (Set)

    Returns list of variables.



118
119
120
# File 'lib/multiarray/mask.rb', line 118

def variables
  @dest.variables + @source.variables + @m.variables + @index.variables
end