Sha256: db1c0fdc101d3d3abbfe38ca9f73308e0568e0dc5cd633f9759679040ac5d54b
Contents?: true
Size: 1.87 KB
Versions: 2
Compression:
Stored size: 1.87 KB
Contents
module Daru module Maths module Arithmetic module Vector def + other binary_op :+, other end def - other binary_op :-, other end def * other binary_op :*, other end def / other binary_op :/, other end def % other binary_op :%, other end def ** other binary_op :**, other end def exp math_unary_op :exp end def sqrt math_unary_op :sqrt end def abs self.recode { |e| e.abs unless e.nil? } end def round precision=0 self.recode { |e| e.round(precision) unless e.nil? } end private def math_unary_op operation self.recode { |e| Math.send(operation, e) unless e.nil? } end def binary_op operation, other case other when Daru::Vector v2v_binary operation, other else v2o_binary operation, other end end def v2o_binary operation, other Daru::Vector.new self.map { |e| e.nil? ? nil : e.send(operation, other) }, name: @name, index: @index end def v2v_binary operation, other common_idxs = [] elements = [] index = (@index.to_a | other.index.to_a).sort index.each do |idx| this = self.index.include?(idx) ? self[idx] : nil that = other.index.include?(idx) ? other[idx] : nil if this and that elements << this.send(operation ,that) common_idxs << idx else elements << nil common_idxs << idx end end Daru::Vector.new(elements, name: @name, index: common_idxs) end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
daru-0.1.2 | lib/daru/maths/arithmetic/vector.rb |
daru-0.1.1 | lib/daru/maths/arithmetic/vector.rb |