blob: 4b2832c6bf2fce09458413951cd68f0b9d5ed9f0 [file] [log] [blame]
// Copyright ©2019 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_test
import (
"fmt"
"gonum.org/v1/gonum/blas/blas64"
"gonum.org/v1/gonum/mat"
)
// This example shows how simple user types can be constructed to
// implement basic vector functionality within the mat package.
func Example_userVectors() {
// Perform the cross product of [1 2 3 4] and [1 2 3].
r := row{1, 2, 3, 4}
c := column{1, 2, 3}
var m mat.Dense
m.Mul(c, r)
fmt.Println(mat.Formatted(&m))
// Output:
//
// ⎡ 1 2 3 4⎤
// ⎢ 2 4 6 8⎥
// ⎣ 3 6 9 12⎦
}
// row is a user-defined row vector.
type row []float64
// Dims, At and T minimally satisfy the mat.Matrix interface.
func (v row) Dims() (r, c int) { return 1, len(v) }
func (v row) At(_, j int) float64 { return v[j] }
func (v row) T() mat.Matrix { return column(v) }
// RawVector allows fast path computation with the vector.
func (v row) RawVector() blas64.Vector {
return blas64.Vector{N: len(v), Data: v, Inc: 1}
}
// column is a user-defined column vector.
type column []float64
// Dims, At and T minimally satisfy the mat.Matrix interface.
func (v column) Dims() (r, c int) { return len(v), 1 }
func (v column) At(i, _ int) float64 { return v[i] }
func (v column) T() mat.Matrix { return row(v) }
// RawVector allows fast path computation with the vector.
func (v column) RawVector() blas64.Vector {
return blas64.Vector{N: len(v), Data: v, Inc: 1}
}