Sha256: beacda4c068f96ac272ece44f632cefafb32d308b996c4fba81fd7463618550d

Contents?: true

Size: 1.8 KB

Versions: 1

Compression:

Stored size: 1.8 KB

Contents

#! /usr/bin/env ruby
# coding: utf-8

require "matrix"

# n 次元空間における座標系を表現する n 本のベクトルを扱うクラス。
class Axes
  attr_reader :axes

  class InitializeError < Exception; end


  # 要素数が nxn でなければ例外。0x0 も例外。
  # 角各要素は to_f メソッドを持たなければならない。
  def initialize(vectors)
    raise InitializeError if vectors.size == 0
    @axes = vectors.map{|vector| Vector[*vector]}

    #raise InitializeError unless @axes.regular? # この判定はうまくいかない。バグ?
    @axes.each do |vector|
      raise InitializeError unless @axes.size == vector.size
    end
  end

  def self.independent?(axes)
    return Matrix[* axes.map{|i| i.to_a}].regular?
  end

  # Return true is the vector is not independent.
  def self.dependent?(axes)
    return ! (self.independent?(axes))
  end

  # Return a number of vectors in axes, always three.
  # Mimic for Array.
  def size
    return @axes.size
  end

  # Check equal.
  # Usually, this method should not be used, except for tests.
  def ==(other)
    result = true
    size.times do |i|
      size.times do |j|
        result = false if @axes[i][j] != other.axes[i][j]
      end
    end

    return result
  end

  def dependent?
    self.class.dependent?(@axes)
  end

  def independent?
    self.class.independent?(@axes)
  end

  def to_a
    result = [
      @axes[0].to_a,
      @axes[1].to_a,
      @axes[2].to_a,
    ]
    return result
  end

  # Item access for three axes in cartesian coordinates.
  # Note: []= method is not provided.
  def [](index)
    @axes[ index ]
  end

  # Iterate each vector of axes.
  def each
    @axes.each { |i| yield(i) }
  end

  # Convert to Array. Non-destructive.
  def to_a
    return @axes.map { |vector| vector.to_a }
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
mageo-0.0.1 lib/mageo/axes.rb