mageo 0.0.1 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/test/test_vector.rb CHANGED
@@ -1,9 +1,11 @@
1
1
  #! /usr/bin/ruby
2
2
 
3
- require "test/unit"
3
+ require "helper"
4
+ #require "test/unit"
4
5
  require "matrix"
5
- require "mageo/vector.rb"
6
- require "mageo/vector3d.rb"
6
+ #require 'mageo.rb'
7
+ #require "mageo/vector.rb"
8
+ #require "mageo/vector3d.rb"
7
9
 
8
10
  class TC_Vector < Test::Unit::TestCase
9
11
  #include Math
@@ -21,7 +23,7 @@ class TC_Vector < Test::Unit::TestCase
21
23
  end
22
24
 
23
25
  def test_unit_vector
24
- assert_raise( Vector::ZeroOperation ){ Vector[0.0, 0.0, 0.0].unit_vector }
26
+ assert_raise( Vector::ZeroOperationError ){ Vector[0.0, 0.0, 0.0].unit_vector }
25
27
 
26
28
  assert_in_delta( 1.0/Math::sqrt(14.0), @v0.unit_vector[0], $tolerance )
27
29
  assert_in_delta( 2.0/Math::sqrt(14.0), @v0.unit_vector[1], $tolerance )
@@ -60,8 +62,8 @@ class TC_Vector < Test::Unit::TestCase
60
62
  assert_equal(2, tmp.size)
61
63
 
62
64
  # inherited class
63
- tmp = Vector3D[1.1, 2.2, 3.3].floor
64
- assert_equal(Vector3D, tmp.class)
65
+ tmp = Mageo::Vector3D[1.1, 2.2, 3.3].floor
66
+ assert_equal(Mageo::Vector3D, tmp.class)
65
67
  assert_equal(1, tmp[0])
66
68
  assert_equal(2, tmp[1])
67
69
  assert_equal(3, tmp[2])
@@ -1,11 +1,13 @@
1
1
  #! /usr/bin/ruby
2
2
 
3
- require "test/unit"
3
+ require "helper"
4
+ #require "test/unit"
4
5
  require "matrix"
5
- require "mageo/vector3d.rb"
6
- require "mageo/vector3dinternal.rb"
7
- require "mageo/polar2d.rb"
8
- require "mageo/polar3d.rb"
6
+ #require 'mageo.rb'
7
+ #require "mageo/vector3d.rb"
8
+ #require "mageo/vector3dinternal.rb"
9
+ #require "mageo/polar2d.rb"
10
+ #require "mageo/polar3d.rb"
9
11
 
10
12
  class TC_Array < Test::Unit::TestCase
11
13
  $tolerance = 10.0**(-10)
@@ -15,12 +17,12 @@ class TC_Array < Test::Unit::TestCase
15
17
  end
16
18
 
17
19
  def test_to_v3d
18
- assert_equal( Vector3D, @a.to_v3d.class )
20
+ assert_equal( Mageo::Vector3D, @a.to_v3d.class )
19
21
  assert_in_delta( 1.0, @a.to_v3d[0], $tolerance )
20
22
  assert_in_delta( 2.0, @a.to_v3d[1], $tolerance )
21
23
  assert_in_delta( 3.0, @a.to_v3d[2], $tolerance )
22
- assert_raise( Vector3D::RangeError ){ [1.0].to_v3d }
23
- assert_raise( Vector3D::RangeError ){ [0.0, 1.0, 2.0, 3.0].to_v3d }
24
+ assert_raise( Mageo::Vector3D::RangeError ){ [1.0].to_v3d }
25
+ assert_raise( Mageo::Vector3D::RangeError ){ [0.0, 1.0, 2.0, 3.0].to_v3d }
24
26
  end
25
27
  end
26
28
 
@@ -36,12 +38,12 @@ class TC_Vector < Test::Unit::TestCase
36
38
  end
37
39
 
38
40
  def test_to_v3d
39
- assert_equal( Vector3D, @v0.to_v3d.class )
41
+ assert_equal( Mageo::Vector3D, @v0.to_v3d.class )
40
42
  assert_in_delta( 1.0, @v0.to_v3d[0], $tolerance )
41
43
  assert_in_delta( 2.0, @v0.to_v3d[1], $tolerance )
42
44
  assert_in_delta( 3.0, @v0.to_v3d[2], $tolerance )
43
- assert_raise( Vector3D::RangeError ){ Vector[1.0].to_v3d }
44
- assert_raise( Vector3D::RangeError ){ Vector[0.0, 1.0, 2.0, 3.0].to_v3d }
45
+ assert_raise( Mageo::Vector3D::RangeError ){ Vector[1.0].to_v3d }
46
+ assert_raise( Mageo::Vector3D::RangeError ){ Vector[0.0, 1.0, 2.0, 3.0].to_v3d }
45
47
  end
46
48
  end
47
49
 
@@ -50,30 +52,30 @@ class TC_Vector3D < Test::Unit::TestCase
50
52
  include Math
51
53
 
52
54
  def setup
53
- @v00 = Vector3D[1.0, 0.0, 0.0]
54
- @v01 = Vector3D[1.0, 0.0, 0.0]
55
- @v02 = Vector3D[0.0, 1.0, 0.0]
56
- @v03 = Vector3D[0.0, 0.0, 1.0]
57
- @v04 = Vector3D[0.0, 0.0, 0.0]
58
- @v05 = Vector3D[0.5, 0.5, 0.0]
59
- @v07 = Vector3D[1.0, 2.0, 3.0]
60
- @v08 = Vector3D[0.1, 0.2, 0.3]
55
+ @v00 = Mageo::Vector3D[1.0, 0.0, 0.0]
56
+ @v01 = Mageo::Vector3D[1.0, 0.0, 0.0]
57
+ @v02 = Mageo::Vector3D[0.0, 1.0, 0.0]
58
+ @v03 = Mageo::Vector3D[0.0, 0.0, 1.0]
59
+ @v04 = Mageo::Vector3D[0.0, 0.0, 0.0]
60
+ @v05 = Mageo::Vector3D[0.5, 0.5, 0.0]
61
+ @v07 = Mageo::Vector3D[1.0, 2.0, 3.0]
62
+ @v08 = Mageo::Vector3D[0.1, 0.2, 0.3]
61
63
  end
62
64
 
63
65
  def test_initialize
64
- assert_raise( Vector3D::RangeError ){ Vector3D[0.0, 0.0] }
65
- assert_raise( Vector3D::RangeError ){ Vector3D[0.0, 0.0, 0.0, 0.0] }
66
+ assert_raise( Mageo::Vector3D::RangeError ){ Mageo::Vector3D[0.0, 0.0] }
67
+ assert_raise( Mageo::Vector3D::RangeError ){ Mageo::Vector3D[0.0, 0.0, 0.0, 0.0] }
66
68
 
67
- assert_equal( Vector3D, Vector3D[0.0, 0.0, 1.0].class )
69
+ assert_equal( Mageo::Vector3D, Mageo::Vector3D[0.0, 0.0, 1.0].class )
68
70
  end
69
71
 
70
72
  def test_add_and_delete
71
73
  #追加できないことを確認。
72
- assert_raise( NoMethodError ){ Vector3D.push( 0.0 ) }
73
- assert_raise( NoMethodError ){ Vector3D[3] = 0.0 }
74
+ assert_raise( NoMethodError ){ Mageo::Vector3D.push( 0.0 ) }
75
+ assert_raise( NoMethodError ){ Mageo::Vector3D[3] = 0.0 }
74
76
 
75
- assert_raise( NoMethodError ){ Vector3D.pop( 0.0 ) }
76
- assert_raise( NoMethodError ){ Vector3D.delete[3] = 0.0 }
77
+ assert_raise( NoMethodError ){ Mageo::Vector3D.pop( 0.0 ) }
78
+ assert_raise( NoMethodError ){ Mageo::Vector3D.delete[3] = 0.0 }
77
79
  end
78
80
 
79
81
  def test_access
@@ -81,8 +83,8 @@ class TC_Vector3D < Test::Unit::TestCase
81
83
  assert_equal(1.0, @v00[0])
82
84
  assert_equal(0.0, @v00[1])
83
85
  assert_equal(0.0, @v00[2])
84
- assert_raise(Vector3D::RangeError){@v00[3]}
85
- assert_raise(Vector3D::RangeError){@v00[-1]}
86
+ assert_raise(Mageo::Vector3D::RangeError){@v00[3]}
87
+ assert_raise(Mageo::Vector3D::RangeError){@v00[-1]}
86
88
 
87
89
  # write
88
90
  @v00[0] = 2.0
@@ -91,8 +93,8 @@ class TC_Vector3D < Test::Unit::TestCase
91
93
  assert_equal(2.0, @v00[0])
92
94
  assert_equal(3.0, @v00[1])
93
95
  assert_equal(4.0, @v00[2])
94
- assert_raise(Vector3D::RangeError){@v00[3] = 0.0}
95
- assert_raise(Vector3D::RangeError){@v00[-1] = 0.0}
96
+ assert_raise(Mageo::Vector3D::RangeError){@v00[3] = 0.0}
97
+ assert_raise(Mageo::Vector3D::RangeError){@v00[-1] = 0.0}
96
98
  end
97
99
 
98
100
  def test_size
@@ -101,37 +103,37 @@ class TC_Vector3D < Test::Unit::TestCase
101
103
 
102
104
  def test_exterior_product
103
105
  #For class method
104
- assert_raise( Vector3D::TypeError ){ Vector3D.exterior_product( @v00, [1.0, 2.0, 3.0] ) }
105
- assert_raise( Vector3D::TypeError ){ Vector3D.exterior_product( @v00, Vector[1.0, 2.0, 3.0] ) }
106
- assert_raise( Vector3D::TypeError ){ Vector3D.exterior_product( @v00, Vector3DInternal[1.0, 2.0, 3.0] ) }
107
- assert_raise( Vector3D::TypeError ){ Vector3D.exterior_product( [1.0, 2.0, 3.0] , @v00 ) }
108
- assert_raise( Vector3D::TypeError ){ Vector3D.exterior_product( Vector[1.0, 2.0, 3.0] , @v00 ) }
109
- assert_raise( Vector3D::TypeError ){ Vector3D.exterior_product( Vector3DInternal[1.0, 2.0, 3.0], @v00 ) }
110
-
111
- assert_equal( Vector3D, Vector3D.exterior_product( @v00, @v01 ).class)
112
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v01 )[0], $tolerance )
113
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v01 )[1], $tolerance )
114
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v01 )[2], $tolerance )
115
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v02 )[0], $tolerance )
116
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v02 )[1], $tolerance )
117
- assert_in_delta( 1.0, Vector3D.exterior_product( @v00, @v02 )[2], $tolerance )
118
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v03 )[0], $tolerance )
119
- assert_in_delta(-1.0, Vector3D.exterior_product( @v00, @v03 )[1], $tolerance )
120
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v03 )[2], $tolerance )
121
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v04 )[0], $tolerance )
122
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v04 )[1], $tolerance )
123
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v04 )[2], $tolerance )
124
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v05 )[0], $tolerance )
125
- assert_in_delta( 0.0, Vector3D.exterior_product( @v00, @v05 )[1], $tolerance )
126
- assert_in_delta( 0.5, Vector3D.exterior_product( @v00, @v05 )[2], $tolerance )
127
-
128
- assert_in_delta( 0.5, Vector3D.cross_product( @v00, @v05 )[2], $tolerance )
129
- assert_in_delta( 0.5, Vector3D.vector_product( @v00, @v05 )[2], $tolerance )
106
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.exterior_product( @v00, [1.0, 2.0, 3.0] ) }
107
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.exterior_product( @v00, Vector[1.0, 2.0, 3.0] ) }
108
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.exterior_product( @v00, Mageo::Vector3DInternal[1.0, 2.0, 3.0] ) }
109
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.exterior_product( [1.0, 2.0, 3.0] , @v00 ) }
110
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.exterior_product( Vector[1.0, 2.0, 3.0] , @v00 ) }
111
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.exterior_product( Mageo::Vector3DInternal[1.0, 2.0, 3.0], @v00 ) }
112
+
113
+ assert_equal( Mageo::Vector3D, Mageo::Vector3D.exterior_product( @v00, @v01 ).class)
114
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v01 )[0], $tolerance )
115
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v01 )[1], $tolerance )
116
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v01 )[2], $tolerance )
117
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v02 )[0], $tolerance )
118
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v02 )[1], $tolerance )
119
+ assert_in_delta( 1.0, Mageo::Vector3D.exterior_product( @v00, @v02 )[2], $tolerance )
120
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v03 )[0], $tolerance )
121
+ assert_in_delta(-1.0, Mageo::Vector3D.exterior_product( @v00, @v03 )[1], $tolerance )
122
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v03 )[2], $tolerance )
123
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v04 )[0], $tolerance )
124
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v04 )[1], $tolerance )
125
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v04 )[2], $tolerance )
126
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v05 )[0], $tolerance )
127
+ assert_in_delta( 0.0, Mageo::Vector3D.exterior_product( @v00, @v05 )[1], $tolerance )
128
+ assert_in_delta( 0.5, Mageo::Vector3D.exterior_product( @v00, @v05 )[2], $tolerance )
129
+
130
+ assert_in_delta( 0.5, Mageo::Vector3D.cross_product( @v00, @v05 )[2], $tolerance )
131
+ assert_in_delta( 0.5, Mageo::Vector3D.vector_product( @v00, @v05 )[2], $tolerance )
130
132
 
131
133
  #For instance method
132
- assert_raise( Vector3D::TypeError ){ @v00.exterior_product( [1.0, 2.0, 3.0] ) }
133
- assert_raise( Vector3D::TypeError ){ @v00.exterior_product( Vector[1.0, 2.0, 3.0] ) }
134
- assert_raise( Vector3D::TypeError ){ @v00.exterior_product( Vector3DInternal[1.0, 2.0, 3.0] ) }
134
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.exterior_product( [1.0, 2.0, 3.0] ) }
135
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.exterior_product( Vector[1.0, 2.0, 3.0] ) }
136
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.exterior_product( Mageo::Vector3DInternal[1.0, 2.0, 3.0] ) }
135
137
 
136
138
  assert_equal( 0.0, @v00.exterior_product( @v01 )[0], $tolerance )
137
139
  assert_equal( 0.0, @v00.exterior_product( @v01 )[1], $tolerance )
@@ -154,31 +156,31 @@ class TC_Vector3D < Test::Unit::TestCase
154
156
  end
155
157
 
156
158
  def test_class
157
- assert_equal( Vector3D, @v00.class )
158
- assert_equal( Vector3D, ( @v00 - @v01 ).class )
159
- assert_equal( Vector3D, ( @v00 * 3.0 ).class )
160
- assert_equal( Vector3D, @v00.clone.class )
161
- assert_equal( Vector3D, @v00.dup.class )
162
-
163
- #assert_equal( Vector3D, @v00.collect{|x| x }.class )
164
- #assert_equal( Vector3D, @v00.map{|x| x }.class )
165
- #assert_equal( Vector3D, @v00.map2{|x| x }.class )
159
+ assert_equal( Mageo::Vector3D, @v00.class )
160
+ assert_equal( Mageo::Vector3D, ( @v00 - @v01 ).class )
161
+ assert_equal( Mageo::Vector3D, ( @v00 * 3.0 ).class )
162
+ assert_equal( Mageo::Vector3D, @v00.clone.class )
163
+ assert_equal( Mageo::Vector3D, @v00.dup.class )
164
+
165
+ #assert_equal( Mageo::Vector3D, @v00.collect{|x| x }.class )
166
+ #assert_equal( Mageo::Vector3D, @v00.map{|x| x }.class )
167
+ #assert_equal( Mageo::Vector3D, @v00.map2{|x| x }.class )
166
168
  end
167
169
 
168
170
  def test_equal_in_delta?
169
- assert_raise(Vector3D::TypeError){@v00.equal_in_delta?( Vector[ 1.0, 0.0, 0.0 ])}
170
- assert_raise(Vector3D::TypeError){@v00.equal_in_delta?( Vector3DInternal[ 1.0, 0.0, 0.0 ])}
171
- assert_equal(true , @v00.equal_in_delta?( Vector3D[ 1.0, 0.0, 0.0 ]))
172
- assert_equal(false, @v00.equal_in_delta?( Vector3D[ 1.0, 0.0, 0.1 ]))
173
- assert_equal(true , @v00.equal_in_delta?( Vector3D[ 1.0, 0.0, 0.1 ], 1.0))
171
+ assert_raise(Mageo::Vector3D::TypeError){@v00.equal_in_delta?( Vector[ 1.0, 0.0, 0.0 ])}
172
+ assert_raise(Mageo::Vector3D::TypeError){@v00.equal_in_delta?( Mageo::Vector3DInternal[ 1.0, 0.0, 0.0 ])}
173
+ assert_equal(true , @v00.equal_in_delta?( Mageo::Vector3D[ 1.0, 0.0, 0.0 ]))
174
+ assert_equal(false, @v00.equal_in_delta?( Mageo::Vector3D[ 1.0, 0.0, 0.1 ]))
175
+ assert_equal(true , @v00.equal_in_delta?( Mageo::Vector3D[ 1.0, 0.0, 0.1 ], 1.0))
174
176
  end
175
177
 
176
178
  def test_plus
177
- assert_raise( Vector3D::TypeError ){ @v07 + [0.0, 1.0, 2.0] }
178
- assert_raise( Vector3D::TypeError ){ @v07 + Vector[0.0, 1.0, 2.0] }
179
- assert_raise( Vector3D::TypeError ){ @v07 + Vector3DInternal[0.0, 1.0, 2.0] }
179
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 + [0.0, 1.0, 2.0] }
180
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 + Vector[0.0, 1.0, 2.0] }
181
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 + Mageo::Vector3DInternal[0.0, 1.0, 2.0] }
180
182
 
181
- assert_equal( Vector3D, ( @v07 + @v08 ).class )
183
+ assert_equal( Mageo::Vector3D, ( @v07 + @v08 ).class )
182
184
  t = @v07 + @v08
183
185
  assert_in_delta( 1.1, t[0], $tolerance )
184
186
  assert_in_delta( 2.2, t[1], $tolerance )
@@ -186,11 +188,11 @@ class TC_Vector3D < Test::Unit::TestCase
186
188
  end
187
189
 
188
190
  def test_minus
189
- assert_raise( Vector3D::TypeError ){ @v07 - [0.0, 1.0, 2.0] }
190
- assert_raise( Vector3D::TypeError ){ @v07 - Vector[0.0, 1.0, 2.0] }
191
- assert_raise( Vector3D::TypeError ){ @v07 - Vector3DInternal[0.0, 1.0, 2.0] }
191
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 - [0.0, 1.0, 2.0] }
192
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 - Vector[0.0, 1.0, 2.0] }
193
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 - Mageo::Vector3DInternal[0.0, 1.0, 2.0] }
192
194
 
193
- assert_equal( Vector3D, ( @v07 - @v08 ).class )
195
+ assert_equal( Mageo::Vector3D, ( @v07 - @v08 ).class )
194
196
  t = @v07 - @v08
195
197
  assert_in_delta( 0.9, t[0], $tolerance )
196
198
  assert_in_delta( 1.8, t[1], $tolerance )
@@ -198,18 +200,18 @@ class TC_Vector3D < Test::Unit::TestCase
198
200
  end
199
201
 
200
202
  def test_multiply
201
- assert_raise( Vector3D::TypeError ){ @v07 * [0.0, 1.0, 2.0] }
202
- assert_raise( Vector3D::TypeError ){ @v07 * Vector[0.0, 1.0, 2.0] }
203
- assert_raise( Vector3D::TypeError ){ @v07 * Vector3DInternal[0.0, 1.0, 2.0] }
203
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 * [0.0, 1.0, 2.0] }
204
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 * Vector[0.0, 1.0, 2.0] }
205
+ assert_raise( Mageo::Vector3D::TypeError ){ @v07 * Mageo::Vector3DInternal[0.0, 1.0, 2.0] }
204
206
 
205
207
  t = @v07 * 3
206
- assert_equal( Vector3D, t.class )
208
+ assert_equal( Mageo::Vector3D, t.class )
207
209
  assert_in_delta( 3.0, t[0], $tolerance )
208
210
  assert_in_delta( 6.0, t[1], $tolerance )
209
211
  assert_in_delta( 9.0, t[2], $tolerance )
210
212
 
211
213
  t = @v07 * 3.0
212
- assert_equal( Vector3D, t.class )
214
+ assert_equal( Mageo::Vector3D, t.class )
213
215
  assert_in_delta( 3.0, t[0], $tolerance )
214
216
  assert_in_delta( 6.0, t[1], $tolerance )
215
217
  assert_in_delta( 9.0, t[2], $tolerance )
@@ -217,57 +219,57 @@ class TC_Vector3D < Test::Unit::TestCase
217
219
 
218
220
  def test_scalar_triple_product
219
221
  #For class method
220
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( @v00, @v02, [1.0, 2.0, 3.0] ) }
221
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( @v00, @v02, Vector[1.0, 2.0, 3.0] ) }
222
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( @v00, @v02, Vector3DInternal[1.0, 2.0, 3.0] ) }
223
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( @v00, [1.0, 2.0, 3.0] , @v02 ) }
224
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( @v00, Vector[1.0, 2.0, 3.0] , @v02 ) }
225
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( @v00, Vector3DInternal[1.0, 2.0, 3.0], @v02 ) }
226
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( [1.0, 2.0, 3.0] , @v00, @v02 ) }
227
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( Vector[1.0, 2.0, 3.0] , @v00, @v02 ) }
228
- assert_raise( Vector3D::TypeError ){ Vector3D.scalar_triple_product( Vector3DInternal[1.0, 2.0, 3.0], @v00, @v02 ) }
229
-
230
- assert_in_delta( 0.0, Vector3D.scalar_triple_product( @v00, @v01, @v02), $tolerance )
231
- assert_in_delta( 1.0, Vector3D.scalar_triple_product( @v00, @v02, @v03), $tolerance )
232
- assert_in_delta(-1.0, Vector3D.scalar_triple_product( @v00, @v03, @v02), $tolerance )
233
- assert_in_delta( 0.0, Vector3D.scalar_triple_product( @v00, @v03, @v04), $tolerance )
222
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( @v00, @v02, [1.0, 2.0, 3.0] ) }
223
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( @v00, @v02, Vector[1.0, 2.0, 3.0] ) }
224
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( @v00, @v02, Mageo::Vector3DInternal[1.0, 2.0, 3.0] ) }
225
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( @v00, [1.0, 2.0, 3.0] , @v02 ) }
226
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( @v00, Vector[1.0, 2.0, 3.0] , @v02 ) }
227
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( @v00, Mageo::Vector3DInternal[1.0, 2.0, 3.0], @v02 ) }
228
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( [1.0, 2.0, 3.0] , @v00, @v02 ) }
229
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( Vector[1.0, 2.0, 3.0] , @v00, @v02 ) }
230
+ assert_raise( Mageo::Vector3D::TypeError ){ Mageo::Vector3D.scalar_triple_product( Mageo::Vector3DInternal[1.0, 2.0, 3.0], @v00, @v02 ) }
231
+
232
+ assert_in_delta( 0.0, Mageo::Vector3D.scalar_triple_product( @v00, @v01, @v02), $tolerance )
233
+ assert_in_delta( 1.0, Mageo::Vector3D.scalar_triple_product( @v00, @v02, @v03), $tolerance )
234
+ assert_in_delta(-1.0, Mageo::Vector3D.scalar_triple_product( @v00, @v03, @v02), $tolerance )
235
+ assert_in_delta( 0.0, Mageo::Vector3D.scalar_triple_product( @v00, @v03, @v04), $tolerance )
234
236
 
235
237
  #For instance method
236
- assert_raise( Vector3D::TypeError ){ @v00.scalar_triple_product( @v02, [1.0, 2.0, 3.0] ) }
237
- assert_raise( Vector3D::TypeError ){ @v00.scalar_triple_product( @v02, Vector[1.0, 2.0, 3.0] ) }
238
- assert_raise( Vector3D::TypeError ){ @v00.scalar_triple_product( @v02, Vector3DInternal[1.0, 2.0, 3.0] ) }
239
- assert_raise( Vector3D::TypeError ){ @v00.scalar_triple_product( [1.0, 2.0, 3.0] , @v02 ) }
240
- assert_raise( Vector3D::TypeError ){ @v00.scalar_triple_product( Vector[1.0, 2.0, 3.0] , @v02 ) }
241
- assert_raise( Vector3D::TypeError ){ @v00.scalar_triple_product( Vector3DInternal[1.0, 2.0, 3.0], @v02 ) }
238
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.scalar_triple_product( @v02, [1.0, 2.0, 3.0] ) }
239
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.scalar_triple_product( @v02, Vector[1.0, 2.0, 3.0] ) }
240
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.scalar_triple_product( @v02, Mageo::Vector3DInternal[1.0, 2.0, 3.0] ) }
241
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.scalar_triple_product( [1.0, 2.0, 3.0] , @v02 ) }
242
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.scalar_triple_product( Vector[1.0, 2.0, 3.0] , @v02 ) }
243
+ assert_raise( Mageo::Vector3D::TypeError ){ @v00.scalar_triple_product( Mageo::Vector3DInternal[1.0, 2.0, 3.0], @v02 ) }
242
244
 
243
245
  assert_in_delta( 0.0, @v00.scalar_triple_product( @v01, @v02), $tolerance )
244
246
  assert_in_delta( 1.0, @v00.scalar_triple_product( @v02, @v03), $tolerance )
245
247
  assert_in_delta(-1.0, @v00.scalar_triple_product( @v03, @v02), $tolerance )
246
248
  assert_in_delta( 0.0, @v00.scalar_triple_product( @v03, @v04), $tolerance )
247
249
 
248
- #どれかが Vector3D 以外の、Vector クラスで3要素のものだった場合は例外。
250
+ #どれかが Mageo::Vector3D 以外の、Vector クラスで3要素のものだった場合は例外。
249
251
  end
250
252
 
251
253
  def test_angle_radian
252
254
  #For class method
253
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_radian( @v00, [1.0, 2.0, 3.0] ) }
254
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_radian( @v00, Vector[1.0, 2.0, 3.0] ) }
255
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_radian( @v00, Vector3DInternal[1.0, 2.0, 3.0] ) }
256
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_radian( [1.0, 2.0, 3.0] , @v00 ) }
257
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_radian( Vector[1.0, 2.0, 3.0] , @v00 ) }
258
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_radian( Vector3DInternal[1.0, 2.0, 3.0], @v00 ) }
259
- assert_raise( Vector3D::ZeroOperation ) { Vector3D.angle_radian( @v00, @v04) }
260
-
261
- assert_in_delta( 0.0, Vector3D.angle_radian( @v00, @v01), $tolerance )
262
- assert_in_delta( PI/2.0, Vector3D.angle_radian( @v00, @v02), $tolerance )
263
- assert_in_delta( PI/2.0, Vector3D.angle_radian( @v00, @v03), $tolerance )
264
- assert_in_delta( PI/4.0, Vector3D.angle_radian( @v00, @v05), $tolerance )
255
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_radian( @v00, [1.0, 2.0, 3.0] ) }
256
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_radian( @v00, Vector[1.0, 2.0, 3.0] ) }
257
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_radian( @v00, Mageo::Vector3DInternal[1.0, 2.0, 3.0] ) }
258
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_radian( [1.0, 2.0, 3.0] , @v00 ) }
259
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_radian( Vector[1.0, 2.0, 3.0] , @v00 ) }
260
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_radian( Mageo::Vector3DInternal[1.0, 2.0, 3.0], @v00 ) }
261
+ assert_raise( Mageo::Vector3D::ZeroOperation ) { Mageo::Vector3D.angle_radian( @v00, @v04) }
262
+
263
+ assert_in_delta( 0.0, Mageo::Vector3D.angle_radian( @v00, @v01), $tolerance )
264
+ assert_in_delta( PI/2.0, Mageo::Vector3D.angle_radian( @v00, @v02), $tolerance )
265
+ assert_in_delta( PI/2.0, Mageo::Vector3D.angle_radian( @v00, @v03), $tolerance )
266
+ assert_in_delta( PI/4.0, Mageo::Vector3D.angle_radian( @v00, @v05), $tolerance )
265
267
 
266
268
  #For instance method
267
- assert_raise( Vector3D::TypeError ) { @v00.angle_radian( [1.0, 2.0, 3.0] ) }
268
- assert_raise( Vector3D::TypeError ) { @v00.angle_radian( Vector[1.0, 2.0, 3.0] ) }
269
- assert_raise( Vector3D::TypeError ) { @v00.angle_radian( Vector3DInternal[1.0, 2.0, 3.0] ) }
270
- assert_raise( Vector3D::ZeroOperation ){ @v00.angle_radian( @v04) }
269
+ assert_raise( Mageo::Vector3D::TypeError ) { @v00.angle_radian( [1.0, 2.0, 3.0] ) }
270
+ assert_raise( Mageo::Vector3D::TypeError ) { @v00.angle_radian( Vector[1.0, 2.0, 3.0] ) }
271
+ assert_raise( Mageo::Vector3D::TypeError ) { @v00.angle_radian( Mageo::Vector3DInternal[1.0, 2.0, 3.0] ) }
272
+ assert_raise( Mageo::Vector3D::ZeroOperation ){ @v00.angle_radian( @v04) }
271
273
  assert_in_delta( 0.0, @v00.angle_radian( @v01), $tolerance )
272
274
  assert_in_delta( PI/2.0, @v00.angle_radian( @v02), $tolerance )
273
275
  assert_in_delta( PI/2.0, @v00.angle_radian( @v03), $tolerance )
@@ -277,50 +279,50 @@ class TC_Vector3D < Test::Unit::TestCase
277
279
 
278
280
  def test_angle_degree
279
281
  #For class method
280
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_degree( @v00, [1.0, 2.0, 3.0] ) }
281
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_degree( @v00, Vector[1.0, 2.0, 3.0] ) }
282
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_degree( @v00, Vector3DInternal[1.0, 2.0, 3.0] ) }
283
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_degree( [1.0, 2.0, 3.0] , @v00 ) }
284
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_degree( Vector[1.0, 2.0, 3.0] , @v00 ) }
285
- assert_raise( Vector3D::TypeError ) { Vector3D.angle_degree( Vector3DInternal[1.0, 2.0, 3.0] , @v00 ) }
286
- assert_raise( Vector3D::ZeroOperation ) { Vector3D.angle_degree( @v00, @v04) }
287
- assert_in_delta( 0.0, Vector3D.angle_degree( @v00, @v01), $tolerance )
288
- assert_in_delta( 90.0, Vector3D.angle_degree( @v00, @v02), $tolerance )
289
- assert_in_delta( 90.0, Vector3D.angle_degree( @v00, @v03), $tolerance )
290
- assert_in_delta( 45.0, Vector3D.angle_degree( @v00, @v05), $tolerance )
282
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_degree( @v00, [1.0, 2.0, 3.0] ) }
283
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_degree( @v00, Vector[1.0, 2.0, 3.0] ) }
284
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_degree( @v00, Mageo::Vector3DInternal[1.0, 2.0, 3.0] ) }
285
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_degree( [1.0, 2.0, 3.0] , @v00 ) }
286
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_degree( Vector[1.0, 2.0, 3.0] , @v00 ) }
287
+ assert_raise( Mageo::Vector3D::TypeError ) { Mageo::Vector3D.angle_degree( Mageo::Vector3DInternal[1.0, 2.0, 3.0] , @v00 ) }
288
+ assert_raise( Mageo::Vector3D::ZeroOperation ) { Mageo::Vector3D.angle_degree( @v00, @v04) }
289
+ assert_in_delta( 0.0, Mageo::Vector3D.angle_degree( @v00, @v01), $tolerance )
290
+ assert_in_delta( 90.0, Mageo::Vector3D.angle_degree( @v00, @v02), $tolerance )
291
+ assert_in_delta( 90.0, Mageo::Vector3D.angle_degree( @v00, @v03), $tolerance )
292
+ assert_in_delta( 45.0, Mageo::Vector3D.angle_degree( @v00, @v05), $tolerance )
291
293
 
292
294
  #For instance method
293
- assert_raise( Vector3D::TypeError ) { @v00.angle_degree( [1.0, 2.0, 3.0] ) }
294
- assert_raise( Vector3D::TypeError ) { @v00.angle_degree( Vector[1.0, 2.0, 3.0] ) }
295
- assert_raise( Vector3D::TypeError ) { @v00.angle_degree( Vector3DInternal[1.0, 2.0, 3.0] ) }
296
- assert_raise( Vector3D::ZeroOperation ){ @v00.angle_degree( @v04) }
295
+ assert_raise( Mageo::Vector3D::TypeError ) { @v00.angle_degree( [1.0, 2.0, 3.0] ) }
296
+ assert_raise( Mageo::Vector3D::TypeError ) { @v00.angle_degree( Vector[1.0, 2.0, 3.0] ) }
297
+ assert_raise( Mageo::Vector3D::TypeError ) { @v00.angle_degree( Mageo::Vector3DInternal[1.0, 2.0, 3.0] ) }
298
+ assert_raise( Mageo::Vector3D::ZeroOperation ){ @v00.angle_degree( @v04) }
297
299
  assert_in_delta( 0.0, @v00.angle_degree( @v01), $tolerance )
298
300
  assert_in_delta( 90.0, @v00.angle_degree( @v02), $tolerance )
299
301
  assert_in_delta( 90.0, @v00.angle_degree( @v03), $tolerance )
300
302
  assert_in_delta( 45.0, @v00.angle_degree( @v05), $tolerance )
301
303
 
302
- #どれかが Vector3D 以外の、Vector クラスで3要素のものだった場合は例外。
304
+ #どれかが Mageo::Vector3D 以外の、Vector クラスで3要素のものだった場合は例外。
303
305
  end
304
306
 
305
307
  def test_to_v3di
306
308
  array = [ [1.0, 1.0, 1.0], [0.0, 1.0, 1.0], [0.0, 0.0, 1.0] ]
307
- assert_raise(Vector3D::TypeError){ Vector3D[ 2.0, 5.0, 9.0 ].to_v3di(array) }
309
+ assert_raise(Mageo::Vector3D::TypeError){ Mageo::Vector3D[ 2.0, 5.0, 9.0 ].to_v3di(array) }
308
310
 
309
- axes = Axes.new(array)
310
- t = Vector3D[ 2.0, 5.0, 9.0 ].to_v3di( axes )
311
- assert_equal( Vector3DInternal, t.class )
311
+ axes = Mageo::Axes.new(array)
312
+ t = Mageo::Vector3D[ 2.0, 5.0, 9.0 ].to_v3di( axes )
313
+ assert_equal( Mageo::Vector3DInternal, t.class )
312
314
  assert_in_delta( 2.0, t[0], $tolerance )
313
315
  assert_in_delta( 3.0, t[1], $tolerance )
314
316
  assert_in_delta( 4.0, t[2], $tolerance )
315
317
  end
316
318
 
317
319
  def test_to_p3d
318
- vA = Vector3D[ 2.0, 2.0, 2.0]
319
- vB = Vector3D[ 0.0, 2.0, 2.0]
320
- vC = Vector3D[ 0.0, 0.0, 2.0]
321
- vD = Vector3D[-2.0,-2.0,-2.0]
322
- vE = Vector3D[ 0.0,-2.0,-2.0]
323
- vF = Vector3D[ 0.0, 0.0,-2.0]
320
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0]
321
+ vB = Mageo::Vector3D[ 0.0, 2.0, 2.0]
322
+ vC = Mageo::Vector3D[ 0.0, 0.0, 2.0]
323
+ vD = Mageo::Vector3D[-2.0,-2.0,-2.0]
324
+ vE = Mageo::Vector3D[ 0.0,-2.0,-2.0]
325
+ vF = Mageo::Vector3D[ 0.0, 0.0,-2.0]
324
326
 
325
327
  assert_in_delta( 2.0*sqrt(3.0) , vA.to_p3d.r , $tolerance )
326
328
  assert_in_delta( acos( sqrt(1/3.0) ) , vA.to_p3d.theta, $tolerance )
@@ -346,47 +348,47 @@ class TC_Vector3D < Test::Unit::TestCase
346
348
  end
347
349
 
348
350
  def test_rotate_axis!
349
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
350
- assert_raise( Vector3D::RangeError ){ vA.rotate_axis!( -1, 0.25*PI ) }
351
- assert_raise( Vector3D::RangeError ){ vA.rotate_axis!( 3, 0.25*PI ) }
351
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
352
+ assert_raise( Mageo::Vector3D::RangeError ){ vA.rotate_axis!( -1, 0.25*PI ) }
353
+ assert_raise( Mageo::Vector3D::RangeError ){ vA.rotate_axis!( 3, 0.25*PI ) }
352
354
 
353
355
  r8 = sqrt(8.0)
354
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
356
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
355
357
 
356
358
  vA.rotate_axis!( 0, 0.25*PI )
357
- assert_equal( Vector3D , vA.class )
359
+ assert_equal( Mageo::Vector3D , vA.class )
358
360
 
359
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
361
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
360
362
  vA.rotate_axis!( 0, 0.25*PI )
361
363
  assert_in_delta( 2.0, vA[0], $tolerance )
362
364
  assert_in_delta( 0.0, vA[1], $tolerance )
363
365
  assert_in_delta( r8 , vA[2], $tolerance )
364
366
 
365
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
367
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
366
368
  vA.rotate_axis!( 1, 0.25*PI )
367
369
  assert_in_delta( r8 , vA[0], $tolerance )
368
370
  assert_in_delta( 2.0, vA[1], $tolerance )
369
371
  assert_in_delta( 0.0, vA[2], $tolerance )
370
372
 
371
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
373
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
372
374
  vA.rotate_axis!( 2, 0.25*PI )
373
375
  assert_in_delta( 0.0, vA[0], $tolerance )
374
376
  assert_in_delta( r8 , vA[1], $tolerance )
375
377
  assert_in_delta( 2.0, vA[2], $tolerance )
376
378
 
377
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
379
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
378
380
  vA.rotate_axis!( 0, -0.25*PI )
379
381
  assert_in_delta( 2.0, vA[0], $tolerance )
380
382
  assert_in_delta( r8 , vA[1], $tolerance )
381
383
  assert_in_delta( 0.0, vA[2], $tolerance )
382
384
 
383
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
385
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
384
386
  vA.rotate_axis!( 1, -0.25*PI )
385
387
  assert_in_delta( 0.0, vA[0], $tolerance )
386
388
  assert_in_delta( 2.0, vA[1], $tolerance )
387
389
  assert_in_delta( r8 , vA[2], $tolerance )
388
390
 
389
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
391
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
390
392
  vA.rotate_axis!( 2, -0.25*PI )
391
393
  assert_in_delta( r8 , vA[0], $tolerance )
392
394
  assert_in_delta( 0.0, vA[1], $tolerance )
@@ -394,14 +396,14 @@ class TC_Vector3D < Test::Unit::TestCase
394
396
  end
395
397
 
396
398
  def test_rotate_axis
397
- vA = Vector3D[ 2.0, 2.0, 2.0 ]
398
- assert_raise( Vector3D::RangeError ){ vA.rotate_axis( -1, 0.25*PI ) }
399
- assert_raise( Vector3D::RangeError ){ vA.rotate_axis( 3, 0.25*PI ) }
399
+ vA = Mageo::Vector3D[ 2.0, 2.0, 2.0 ]
400
+ assert_raise( Mageo::Vector3D::RangeError ){ vA.rotate_axis( -1, 0.25*PI ) }
401
+ assert_raise( Mageo::Vector3D::RangeError ){ vA.rotate_axis( 3, 0.25*PI ) }
400
402
 
401
403
  r8 = sqrt(8.0)
402
- assert_equal( Vector3D , vA.rotate_axis( 0, 0.25*PI ).class )
403
- assert_equal( Vector3D , vA.rotate_axis( 1, 0.25*PI ).class )
404
- assert_equal( Vector3D , vA.rotate_axis( 2, 0.25*PI ).class )
404
+ assert_equal( Mageo::Vector3D , vA.rotate_axis( 0, 0.25*PI ).class )
405
+ assert_equal( Mageo::Vector3D , vA.rotate_axis( 1, 0.25*PI ).class )
406
+ assert_equal( Mageo::Vector3D , vA.rotate_axis( 2, 0.25*PI ).class )
405
407
 
406
408
  assert_in_delta( 2.0, vA.rotate_axis( 0, 0.25*PI )[0], $tolerance )
407
409
  assert_in_delta( 0.0, vA.rotate_axis( 0, 0.25*PI )[1], $tolerance )