blob: 120d59255c38e951d275b3498f3e1b92a501c152 [file] [log] [blame]
// Copyright ©2015 The Gonum Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package mat
import (
"bytes"
"encoding"
"encoding/binary"
"io"
"io/ioutil"
"math"
"testing"
"gonum.org/v1/gonum/blas/blas64"
)
var (
_ encoding.BinaryMarshaler = (*Dense)(nil)
_ encoding.BinaryUnmarshaler = (*Dense)(nil)
_ encoding.BinaryMarshaler = (*VecDense)(nil)
_ encoding.BinaryUnmarshaler = (*VecDense)(nil)
)
var sizeInt64 = binary.Size(int64(0))
var denseData = []struct {
raw []byte
want *Dense
err error
eq func(got, want Matrix) bool
}{
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
want: &Dense{},
err: ErrZeroLength,
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x02\x00\x00\x00\x00\x00\x00\x00\x02\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@"),
want: NewDense(2, 2, []float64{1, 2, 3, 4}),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x02\x00\x00\x00\x00\x00\x00\x00\x03\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@\x00\x00\x00\x00\x00\x00\x14@\x00\x00\x00\x00\x00\x00\x18@"),
want: NewDense(2, 3, []float64{1, 2, 3, 4, 5, 6}),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x03\x00\x00\x00\x00\x00\x00\x00\x02\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@\x00\x00\x00\x00\x00\x00\x14@\x00\x00\x00\x00\x00\x00\x18@"),
want: NewDense(3, 2, []float64{1, 2, 3, 4, 5, 6}),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x03\x00\x00\x00\x00\x00\x00\x00\x03\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@\x00\x00\x00\x00\x00\x00\x14@\x00\x00\x00\x00\x00\x00\x18@\x00\x00\x00\x00\x00\x00\x1c@\x00\x00\x00\x00\x00\x00 @\x00\x00\x00\x00\x00\x00\"@"),
want: NewDense(3, 3, []float64{1, 2, 3, 4, 5, 6, 7, 8, 9}),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x02\x00\x00\x00\x00\x00\x00\x00\x02\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\x10@\x00\x00\x00\x00\x00\x00\x14@"),
want: NewDense(3, 3, []float64{1, 2, 3, 4, 5, 6, 7, 8, 9}).Slice(0, 2, 0, 2).(*Dense),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x02\x00\x00\x00\x00\x00\x00\x00\x02\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x14@\x00\x00\x00\x00\x00\x00\x18@\x00\x00\x00\x00\x00\x00 @\x00\x00\x00\x00\x00\x00\"@"),
want: NewDense(3, 3, []float64{1, 2, 3, 4, 5, 6, 7, 8, 9}).Slice(1, 3, 1, 3).(*Dense),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x03\x00\x00\x00\x00\x00\x00\x00\x02\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x14@\x00\x00\x00\x00\x00\x00\x18@\x00\x00\x00\x00\x00\x00 @\x00\x00\x00\x00\x00\x00\"@"),
want: NewDense(3, 3, []float64{1, 2, 3, 4, 5, 6, 7, 8, 9}).Slice(0, 3, 1, 3).(*Dense),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x01\x00\x00\x00\x00\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0\xff\x00\x00\x00\x00\x00\x00\xf0\u007f\x01\x00\x00\x00\x00\x00\xf8\u007f"),
want: NewDense(1, 4, []float64{0, math.Inf(-1), math.Inf(+1), math.NaN()}),
eq: func(got, want Matrix) bool {
for _, v := range []bool{
got.At(0, 0) == 0,
math.IsInf(got.At(0, 1), -1),
math.IsInf(got.At(0, 2), +1),
math.IsNaN(got.At(0, 3)),
} {
if !v {
return false
}
}
return true
},
},
}
func TestDenseMarshal(t *testing.T) {
t.Parallel()
for i, test := range denseData {
buf, err := test.want.MarshalBinary()
if err != nil {
t.Errorf("error encoding test-%d: %v\n", i, err)
continue
}
nrows, ncols := test.want.Dims()
sz := headerSize + nrows*ncols*sizeFloat64
if len(buf) != sz {
t.Errorf("encoded size test-%d: want=%d got=%d\n", i, sz, len(buf))
}
if !bytes.Equal(buf, test.raw) {
t.Errorf("error encoding test-%d: bytes mismatch.\n got=%q\nwant=%q\n",
i,
string(buf),
string(test.raw),
)
continue
}
}
}
func TestDenseMarshalTo(t *testing.T) {
t.Parallel()
for i, test := range denseData {
buf := new(bytes.Buffer)
n, err := test.want.MarshalBinaryTo(buf)
if err != nil {
t.Errorf("error encoding test-%d: %v\n", i, err)
continue
}
nrows, ncols := test.want.Dims()
sz := headerSize + nrows*ncols*sizeFloat64
if n != sz {
t.Errorf("encoded size test-%d: want=%d got=%d\n", i, sz, n)
}
if !bytes.Equal(buf.Bytes(), test.raw) {
t.Errorf("error encoding test-%d: bytes mismatch.\n got=%q\nwant=%q\n",
i,
buf.Bytes(),
test.raw,
)
continue
}
}
}
func TestDenseUnmarshal(t *testing.T) {
t.Parallel()
for i, test := range denseData {
var v Dense
err := v.UnmarshalBinary(test.raw)
if err != nil {
if err != test.err {
t.Errorf("error decoding test-%d: %v\n", i, err)
}
continue
}
if !test.eq(&v, test.want) {
t.Errorf("error decoding test-%d: values differ.\n got=%v\nwant=%v\n",
i,
&v,
test.want,
)
}
}
}
func TestDenseUnmarshalFrom(t *testing.T) {
t.Parallel()
for i, test := range denseData {
var v Dense
buf := bytes.NewReader(test.raw)
n, err := v.UnmarshalBinaryFrom(buf)
if err != nil {
if err != test.err {
t.Errorf("error decoding test-%d: %v\n", i, err)
}
continue
}
if n != len(test.raw) {
t.Errorf("error decoding test-%d: lengths differ.\n got=%d\nwant=%d\n",
i, n, len(test.raw),
)
}
if !test.eq(&v, test.want) {
t.Errorf("error decoding test-%d: values differ.\n got=%v\nwant=%v\n",
i,
&v,
test.want,
)
}
}
}
func TestDenseUnmarshalFromError(t *testing.T) {
t.Parallel()
test := denseData[1]
for i, tt := range []struct {
beg int
end int
}{
{
beg: 0,
end: len(test.raw) - 1,
},
{
beg: 0,
end: len(test.raw) - sizeFloat64,
},
{
beg: 0,
end: 0,
},
{
beg: 0,
end: 1,
},
{
beg: 0,
end: sizeInt64,
},
{
beg: 0,
end: sizeInt64 - 1,
},
{
beg: 0,
end: sizeInt64 + 1,
},
{
beg: 0,
end: 2*sizeInt64 - 1,
},
{
beg: 0,
end: 2 * sizeInt64,
},
{
beg: 0,
end: 2*sizeInt64 + 1,
},
{
beg: 0,
end: 2*sizeInt64 + sizeFloat64 - 1,
},
{
beg: 0,
end: 2*sizeInt64 + sizeFloat64,
},
{
beg: 0,
end: 2*sizeInt64 + sizeFloat64 + 1,
},
} {
buf := bytes.NewReader(test.raw[tt.beg:tt.end])
var m Dense
_, err := m.UnmarshalBinaryFrom(buf)
if err != io.ErrUnexpectedEOF {
t.Errorf("test #%d: error decoding. got=%v. want=%v\n", i, err, io.ErrUnexpectedEOF)
}
}
}
func TestDenseIORoundTrip(t *testing.T) {
t.Parallel()
for i, test := range denseData {
buf, err := test.want.MarshalBinary()
if err != nil {
t.Errorf("error encoding test #%d: %v\n", i, err)
}
var got Dense
err = got.UnmarshalBinary(buf)
if err != nil {
if err != test.err {
t.Errorf("error decoding test #%d: %v\n", i, err)
}
continue
}
if !test.eq(&got, test.want) {
t.Errorf("r/w test #%d failed\n got=%#v\nwant=%#v\n", i, &got, test.want)
}
wbuf := new(bytes.Buffer)
_, err = test.want.MarshalBinaryTo(wbuf)
if err != nil {
t.Errorf("error encoding test #%d: %v\n", i, err)
}
if !bytes.Equal(buf, wbuf.Bytes()) {
t.Errorf("r/w test #%d encoding via MarshalBinary and MarshalBinaryTo differ:\nwith-stream: %q\n no-stream: %q\n",
i, wbuf.Bytes(), buf,
)
}
var wgot Dense
_, err = wgot.UnmarshalBinaryFrom(wbuf)
if err != nil {
t.Errorf("error decoding test #%d: %v\n", i, err)
}
if !test.eq(&wgot, test.want) {
t.Errorf("r/w test #%d failed\n got=%#v\nwant=%#v\n", i, &wgot, test.want)
}
}
}
var vectorData = []struct {
raw []byte
want *VecDense
err error
eq func(got, want Matrix) bool
}{
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x00\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"),
want: &VecDense{},
err: ErrZeroLength,
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x04\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@"),
want: NewVecDense(4, []float64{1, 2, 3, 4}),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x06\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@\x00\x00\x00\x00\x00\x00\x14@\x00\x00\x00\x00\x00\x00\x18@"),
want: NewVecDense(6, []float64{1, 2, 3, 4, 5, 6}),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\t\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@\x00\x00\x00\x00\x00\x00\x14@\x00\x00\x00\x00\x00\x00\x18@\x00\x00\x00\x00\x00\x00\x1c@\x00\x00\x00\x00\x00\x00 @\x00\x00\x00\x00\x00\x00\"@"),
want: NewVecDense(9, []float64{1, 2, 3, 4, 5, 6, 7, 8, 9}),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x03\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@"),
want: NewVecDense(9, []float64{1, 2, 3, 4, 5, 6, 7, 8, 9}).SliceVec(0, 3).(*VecDense),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x03\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@"),
want: NewVecDense(9, []float64{1, 2, 3, 4, 5, 6, 7, 8, 9}).SliceVec(1, 4).(*VecDense),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\b\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0?\x00\x00\x00\x00\x00\x00\x00@\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x10@\x00\x00\x00\x00\x00\x00\x14@\x00\x00\x00\x00\x00\x00\x18@\x00\x00\x00\x00\x00\x00\x1c@\x00\x00\x00\x00\x00\x00 @"),
want: NewVecDense(9, []float64{1, 2, 3, 4, 5, 6, 7, 8, 9}).SliceVec(0, 8).(*VecDense),
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x03\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\b@\x00\x00\x00\x00\x00\x00\x18@"),
want: &VecDense{
mat: blas64.Vector{
N: 3,
Data: []float64{0, 1, 2, 3, 4, 5, 6},
Inc: 3,
},
},
eq: Equal,
},
{
raw: []byte("\x01\x00\x00\x00GFA\x00\x04\x00\x00\x00\x00\x00\x00\x00\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xf0\xff\x00\x00\x00\x00\x00\x00\xf0\u007f\x01\x00\x00\x00\x00\x00\xf8\u007f"),
want: NewVecDense(4, []float64{0, math.Inf(-1), math.Inf(+1), math.NaN()}),
eq: func(got, want Matrix) bool {
for _, v := range []bool{
got.At(0, 0) == 0,
math.IsInf(got.At(1, 0), -1),
math.IsInf(got.At(2, 0), +1),
math.IsNaN(got.At(3, 0)),
} {
if !v {
return false
}
}
return true
},
},
}
func TestVecDenseMarshal(t *testing.T) {
t.Parallel()
for i, test := range vectorData {
buf, err := test.want.MarshalBinary()
if err != nil {
t.Errorf("error encoding test-%d: %v\n", i, err)
continue
}
nrows, ncols := test.want.Dims()
sz := headerSize + nrows*ncols*sizeFloat64
if len(buf) != sz {
t.Errorf("encoded size test-%d: want=%d got=%d\n", i, sz, len(buf))
}
if !bytes.Equal(buf, test.raw) {
t.Errorf("error encoding test-%d: bytes mismatch.\n got=%q\nwant=%q\n",
i,
string(buf),
string(test.raw),
)
continue
}
}
}
func TestVecDenseMarshalTo(t *testing.T) {
t.Parallel()
for i, test := range vectorData {
buf := new(bytes.Buffer)
n, err := test.want.MarshalBinaryTo(buf)
if err != nil {
t.Errorf("error encoding test-%d: %v\n", i, err)
continue
}
nrows, ncols := test.want.Dims()
sz := headerSize + nrows*ncols*sizeFloat64
if n != sz {
t.Errorf("encoded size test-%d: want=%d got=%d\n", i, sz, n)
}
if !bytes.Equal(buf.Bytes(), test.raw) {
t.Errorf("error encoding test-%d: bytes mismatch.\n got=%q\nwant=%q\n",
i,
buf.Bytes(),
test.raw,
)
continue
}
}
}
func TestVecDenseUnmarshal(t *testing.T) {
t.Parallel()
for i, test := range vectorData {
var v VecDense
err := v.UnmarshalBinary(test.raw)
if err != nil {
if err != test.err {
t.Errorf("error decoding test-%d: %v\n", i, err)
}
continue
}
if !test.eq(&v, test.want) {
t.Errorf("error decoding test-%d: values differ.\n got=%v\nwant=%v\n",
i,
&v,
test.want,
)
}
}
}
func TestVecDenseUnmarshalFrom(t *testing.T) {
t.Parallel()
for i, test := range vectorData {
var v VecDense
buf := bytes.NewReader(test.raw)
n, err := v.UnmarshalBinaryFrom(buf)
if err != nil {
if err != test.err {
t.Errorf("error decoding test-%d: %v\n", i, err)
}
continue
}
if n != len(test.raw) {
t.Errorf("error decoding test-%d: lengths differ.\n got=%d\nwant=%d\n",
i,
n,
len(test.raw),
)
}
if !test.eq(&v, test.want) {
t.Errorf("error decoding test-%d: values differ.\n got=%v\nwant=%v\n",
i,
&v,
test.want,
)
}
}
}
func TestVecDenseUnmarshalFromError(t *testing.T) {
t.Parallel()
test := vectorData[1]
for i, tt := range []struct {
beg int
end int
}{
{
beg: 0,
end: len(test.raw) - 1,
},
{
beg: 0,
end: len(test.raw) - sizeFloat64,
},
{
beg: 0,
end: 0,
},
{
beg: 0,
end: 1,
},
{
beg: 0,
end: sizeInt64,
},
{
beg: 0,
end: sizeInt64 - 1,
},
{
beg: 0,
end: sizeInt64 + 1,
},
{
beg: 0,
end: sizeInt64 + sizeFloat64 - 1,
},
{
beg: 0,
end: sizeInt64 + sizeFloat64,
},
{
beg: 0,
end: sizeInt64 + sizeFloat64 + 1,
},
} {
buf := bytes.NewReader(test.raw[tt.beg:tt.end])
var v VecDense
_, err := v.UnmarshalBinaryFrom(buf)
if err != io.ErrUnexpectedEOF {
t.Errorf("test #%d: error decoding. got=%v. want=%v\n", i, err, io.ErrUnexpectedEOF)
}
}
}
func TestVecDenseIORoundTrip(t *testing.T) {
t.Parallel()
for i, test := range vectorData {
buf, err := test.want.MarshalBinary()
if err != nil {
t.Errorf("error encoding test #%d: %v\n", i, err)
}
var got VecDense
err = got.UnmarshalBinary(buf)
if err != nil {
if err != test.err {
t.Errorf("error decoding test #%d: %v\n", i, err)
}
continue
}
if !test.eq(&got, test.want) {
t.Errorf("r/w test #%d failed\n got=%#v\nwant=%#v\n", i, &got, test.want)
}
wbuf := new(bytes.Buffer)
_, err = test.want.MarshalBinaryTo(wbuf)
if err != nil {
t.Errorf("error encoding test #%d: %v\n", i, err)
}
if !bytes.Equal(buf, wbuf.Bytes()) {
t.Errorf("test #%d encoding via MarshalBinary and MarshalBinaryTo differ:\nwith-stream: %q\n no-stream: %q\n",
i, wbuf.Bytes(), buf,
)
}
var wgot VecDense
_, err = wgot.UnmarshalBinaryFrom(wbuf)
if err != nil {
t.Errorf("error decoding test #%d: %v\n", i, err)
}
if !test.eq(&wgot, test.want) {
t.Errorf("r/w test #%d failed\n got=%#v\nwant=%#v\n", i, &wgot, test.want)
}
}
}
func BenchmarkMarshalDense10(b *testing.B) { marshalBinaryBenchDense(b, 10) }
func BenchmarkMarshalDense100(b *testing.B) { marshalBinaryBenchDense(b, 100) }
func BenchmarkMarshalDense1000(b *testing.B) { marshalBinaryBenchDense(b, 1000) }
func BenchmarkMarshalDense10000(b *testing.B) { marshalBinaryBenchDense(b, 10000) }
func marshalBinaryBenchDense(b *testing.B, size int) {
data := make([]float64, size)
for i := range data {
data[i] = float64(i)
}
m := NewDense(1, size, data)
b.ResetTimer()
for n := 0; n < b.N; n++ {
_, err := m.MarshalBinary()
if err != nil {
b.Fatalf("unexpected error: %v", err)
}
}
}
func BenchmarkUnmarshalDense10(b *testing.B) { unmarshalBinaryBenchDense(b, 10) }
func BenchmarkUnmarshalDense100(b *testing.B) { unmarshalBinaryBenchDense(b, 100) }
func BenchmarkUnmarshalDense1000(b *testing.B) { unmarshalBinaryBenchDense(b, 1000) }
func BenchmarkUnmarshalDense10000(b *testing.B) { unmarshalBinaryBenchDense(b, 10000) }
func unmarshalBinaryBenchDense(b *testing.B, size int) {
data := make([]float64, size)
for i := range data {
data[i] = float64(i)
}
buf, err := NewDense(1, size, data).MarshalBinary()
if err != nil {
b.Fatalf("error creating binary buffer (size=%d): %v\n", size, err)
}
b.ResetTimer()
for n := 0; n < b.N; n++ {
var m Dense
err := m.UnmarshalBinary(buf)
if err != nil {
b.Fatalf("unexpected error: %v", err)
}
}
}
func BenchmarkMarshalToDense10(b *testing.B) { marshalBinaryToBenchDense(b, 10) }
func BenchmarkMarshalToDense100(b *testing.B) { marshalBinaryToBenchDense(b, 100) }
func BenchmarkMarshalToDense1000(b *testing.B) { marshalBinaryToBenchDense(b, 1000) }
func BenchmarkMarshalToDense10000(b *testing.B) { marshalBinaryToBenchDense(b, 10000) }
func marshalBinaryToBenchDense(b *testing.B, size int) {
data := make([]float64, size)
for i := range data {
data[i] = float64(i)
}
m := NewDense(1, size, data)
w := ioutil.Discard
b.ResetTimer()
for n := 0; n < b.N; n++ {
_, err := m.MarshalBinaryTo(w)
if err != nil {
b.Fatalf("unexpected error: %v", err)
}
}
}
type readerTest struct {
buf []byte
pos int
}
func (r *readerTest) Read(data []byte) (int, error) {
n := copy(data, r.buf[r.pos:r.pos+len(data)])
r.pos += n
return n, nil
}
func (r *readerTest) reset() {
r.pos = 0
}
func BenchmarkUnmarshalFromDense10(b *testing.B) { unmarshalBinaryFromBenchDense(b, 10) }
func BenchmarkUnmarshalFromDense100(b *testing.B) { unmarshalBinaryFromBenchDense(b, 100) }
func BenchmarkUnmarshalFromDense1000(b *testing.B) { unmarshalBinaryFromBenchDense(b, 1000) }
func BenchmarkUnmarshalFromDense10000(b *testing.B) { unmarshalBinaryFromBenchDense(b, 10000) }
func unmarshalBinaryFromBenchDense(b *testing.B, size int) {
data := make([]float64, size)
for i := range data {
data[i] = float64(i)
}
buf, err := NewDense(1, size, data).MarshalBinary()
if err != nil {
b.Fatalf("error creating binary buffer (size=%d): %v\n", size, err)
}
r := &readerTest{buf: buf}
b.ResetTimer()
for n := 0; n < b.N; n++ {
var m Dense
_, err := m.UnmarshalBinaryFrom(r)
if err != nil {
b.Fatalf("unexpected error: %v", err)
}
r.reset()
}
}
func BenchmarkMarshalVecDense10(b *testing.B) { marshalBinaryBenchVecDense(b, 10) }
func BenchmarkMarshalVecDense100(b *testing.B) { marshalBinaryBenchVecDense(b, 100) }
func BenchmarkMarshalVecDense1000(b *testing.B) { marshalBinaryBenchVecDense(b, 1000) }
func BenchmarkMarshalVecDense10000(b *testing.B) { marshalBinaryBenchVecDense(b, 10000) }
func marshalBinaryBenchVecDense(b *testing.B, size int) {
data := make([]float64, size)
for i := range data {
data[i] = float64(i)
}
vec := NewVecDense(size, data)
b.ResetTimer()
for n := 0; n < b.N; n++ {
_, err := vec.MarshalBinary()
if err != nil {
b.Fatalf("unexpected error: %v", err)
}
}
}
func BenchmarkUnmarshalVecDense10(b *testing.B) { unmarshalBinaryBenchVecDense(b, 10) }
func BenchmarkUnmarshalVecDense100(b *testing.B) { unmarshalBinaryBenchVecDense(b, 100) }
func BenchmarkUnmarshalVecDense1000(b *testing.B) { unmarshalBinaryBenchVecDense(b, 1000) }
func BenchmarkUnmarshalVecDense10000(b *testing.B) { unmarshalBinaryBenchVecDense(b, 10000) }
func unmarshalBinaryBenchVecDense(b *testing.B, size int) {
data := make([]float64, size)
for i := range data {
data[i] = float64(i)
}
buf, err := NewVecDense(size, data).MarshalBinary()
if err != nil {
b.Fatalf("error creating binary buffer (size=%d): %v\n", size, err)
}
b.ResetTimer()
for n := 0; n < b.N; n++ {
var vec VecDense
err := vec.UnmarshalBinary(buf)
if err != nil {
b.Fatalf("unexpected error: %v", err)
}
}
}
func BenchmarkMarshalToVecDense10(b *testing.B) { marshalBinaryToBenchVecDense(b, 10) }
func BenchmarkMarshalToVecDense100(b *testing.B) { marshalBinaryToBenchVecDense(b, 100) }
func BenchmarkMarshalToVecDense1000(b *testing.B) { marshalBinaryToBenchVecDense(b, 1000) }
func BenchmarkMarshalToVecDense10000(b *testing.B) { marshalBinaryToBenchVecDense(b, 10000) }
func marshalBinaryToBenchVecDense(b *testing.B, size int) {
data := make([]float64, size)
for i := range data {
data[i] = float64(i)
}
vec := NewVecDense(size, data)
w := ioutil.Discard
b.ResetTimer()
for n := 0; n < b.N; n++ {
_, err := vec.MarshalBinaryTo(w)
if err != nil {
b.Fatalf("unexpected error: %v", err)
}
}
}
func BenchmarkUnmarshalFromVecDense10(b *testing.B) { unmarshalBinaryFromBenchVecDense(b, 10) }
func BenchmarkUnmarshalFromVecDense100(b *testing.B) { unmarshalBinaryFromBenchVecDense(b, 100) }
func BenchmarkUnmarshalFromVecDense1000(b *testing.B) { unmarshalBinaryFromBenchVecDense(b, 1000) }
func BenchmarkUnmarshalFromVecDense10000(b *testing.B) { unmarshalBinaryFromBenchVecDense(b, 10000) }
func unmarshalBinaryFromBenchVecDense(b *testing.B, size int) {
data := make([]float64, size)
for i := range data {
data[i] = float64(i)
}
buf, err := NewVecDense(size, data).MarshalBinary()
if err != nil {
b.Fatalf("error creating binary buffer (size=%d): %v\n", size, err)
}
r := &readerTest{buf: buf}
b.ResetTimer()
for n := 0; n < b.N; n++ {
var vec VecDense
_, err := vec.UnmarshalBinaryFrom(r)
if err != nil {
b.Fatalf("unexpected error: %v", err)
}
r.reset()
}
}