mirror of
https://github.com/gonum/gonum.git
synced 2025-10-05 15:16:59 +08:00
58 lines
1.5 KiB
Go
58 lines
1.5 KiB
Go
// 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}
|
|
}
|