2022-01-05 01:37:57 -05:00
|
|
|
require "./spec_helper"
|
|
|
|
require "../src/matrix"
|
|
|
|
|
|
|
|
include PF
|
|
|
|
|
|
|
|
describe Matrix do
|
|
|
|
it "Creates a square matrix with bracket notation" do
|
|
|
|
m = Matrix[
|
|
|
|
0, 1,
|
|
|
|
1, 0,
|
|
|
|
]
|
|
|
|
|
|
|
|
m.class.should eq(Matrix(Int32, 2, 2))
|
|
|
|
m[1, 0].should eq(1)
|
|
|
|
m[0, 1].should eq(1)
|
|
|
|
end
|
2022-01-06 00:35:47 -05:00
|
|
|
|
|
|
|
describe "#*" do
|
|
|
|
it "returns the same matrix when multiplied by identity" do
|
|
|
|
mat = Matrix[
|
|
|
|
1.0, 2.0, 3.0, 4.0,
|
|
|
|
1.0, 2.0, 3.0, 4.0,
|
|
|
|
1.0, 2.0, 3.0, 4.0,
|
|
|
|
1.0, 2.0, 3.0, 4.0,
|
|
|
|
]
|
|
|
|
|
|
|
|
mat.class.should eq(Matrix(Float64, 4, 4))
|
|
|
|
|
|
|
|
ident = Matrix[
|
|
|
|
1.0, 0.0, 0.0, 0.0,
|
|
|
|
0.0, 1.0, 0.0, 0.0,
|
|
|
|
0.0, 0.0, 1.0, 0.0,
|
|
|
|
0.0, 0.0, 0.0, 1.0,
|
|
|
|
]
|
|
|
|
|
|
|
|
result = mat * ident
|
|
|
|
result.should eq(mat)
|
|
|
|
end
|
2022-01-22 23:43:34 -05:00
|
|
|
|
|
|
|
it "multiplies different types" do
|
|
|
|
m1 = Matrix[1, 2, 3, 4]
|
|
|
|
m2 = Matrix[2.0, 0.0, 0.0, 2.0]
|
|
|
|
m3 = Matrix[2.0, 4.0, 6.0, 8.0]
|
|
|
|
(m1 * m2).should eq(m3)
|
|
|
|
end
|
2022-01-06 00:35:47 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "#size" do
|
|
|
|
it "returns the size of the matrix" do
|
|
|
|
mat = Matrix[
|
|
|
|
1, 2,
|
|
|
|
3, 4,
|
|
|
|
]
|
|
|
|
|
2022-01-22 23:43:34 -05:00
|
|
|
mat.width.should eq(2)
|
2022-01-06 00:35:47 -05:00
|
|
|
end
|
2022-01-22 23:43:34 -05:00
|
|
|
end
|
2022-01-06 00:35:47 -05:00
|
|
|
|
2022-01-22 23:43:34 -05:00
|
|
|
describe "#==" do
|
|
|
|
it "accurately show equality" do
|
|
|
|
m1 = Matrix[
|
|
|
|
1, 1, 1,
|
|
|
|
1, 1, 1,
|
|
|
|
1, 1, 1,
|
|
|
|
]
|
|
|
|
|
|
|
|
m2 = Matrix[
|
|
|
|
1, 1, 1,
|
|
|
|
1, 1, 1,
|
|
|
|
1, 1, 1,
|
|
|
|
]
|
|
|
|
|
|
|
|
m3 = Matrix[
|
|
|
|
2, 2, 2,
|
|
|
|
2, 2, 2,
|
|
|
|
2, 2, 2,
|
|
|
|
]
|
2022-01-06 00:35:47 -05:00
|
|
|
|
2022-01-22 23:43:34 -05:00
|
|
|
(m1 == m2).should eq(true)
|
|
|
|
(m1 == m3).should eq(false)
|
2022-01-06 00:35:47 -05:00
|
|
|
end
|
|
|
|
end
|
2022-01-05 01:37:57 -05:00
|
|
|
end
|