kompose/vendor/github.com/gonum/matrix/mat64/index_bound_checks.go
Tomas Kral 1f8a0e06c9
Upgrade OpenShift and its dependencies.
OpenShift version 1.4.0-alpha.0
2016-10-18 12:04:00 +02:00

152 lines
3.1 KiB
Go

// Copyright ©2014 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.
// This file must be kept in sync with index_no_bound_checks.go.
//+build bounds
package mat64
import "github.com/gonum/blas"
// At returns the element at row r, column c.
func (m *Dense) At(r, c int) float64 {
return m.at(r, c)
}
func (m *Dense) at(r, c int) float64 {
if r >= m.mat.Rows || r < 0 {
panic(ErrRowAccess)
}
if c >= m.mat.Cols || c < 0 {
panic(ErrColAccess)
}
return m.mat.Data[r*m.mat.Stride+c]
}
// Set sets the element at row r, column c to the value v.
func (m *Dense) Set(r, c int, v float64) {
m.set(r, c, v)
}
func (m *Dense) set(r, c int, v float64) {
if r >= m.mat.Rows || r < 0 {
panic(ErrRowAccess)
}
if c >= m.mat.Cols || c < 0 {
panic(ErrColAccess)
}
m.mat.Data[r*m.mat.Stride+c] = v
}
// At returns the element at row r, column c. It panics if c is not zero.
func (v *Vector) At(r, c int) float64 {
if c != 0 {
panic(ErrColAccess)
}
return v.at(r)
}
func (v *Vector) at(r int) float64 {
if r < 0 || r >= v.n {
panic(ErrRowAccess)
}
return v.mat.Data[r*v.mat.Inc]
}
// Set sets the element at row r to the value val. It panics if r is less than
// zero or greater than the length.
func (v *Vector) SetVec(i int, val float64) {
v.setVec(i, val)
}
func (v *Vector) setVec(i int, val float64) {
if i < 0 || i >= v.n {
panic(ErrVectorAccess)
}
v.mat.Data[i*v.mat.Inc] = val
}
// At returns the element at row r and column c.
func (t *SymDense) At(r, c int) float64 {
return t.at(r, c)
}
func (t *SymDense) at(r, c int) float64 {
if r >= t.mat.N || r < 0 {
panic(ErrRowAccess)
}
if c >= t.mat.N || c < 0 {
panic(ErrColAccess)
}
if r > c {
r, c = c, r
}
return t.mat.Data[r*t.mat.Stride+c]
}
// SetSym sets the elements at (r,c) and (c,r) to the value v.
func (t *SymDense) SetSym(r, c int, v float64) {
t.set(r, c, v)
}
func (t *SymDense) set(r, c int, v float64) {
if r >= t.mat.N || r < 0 {
panic(ErrRowAccess)
}
if c >= t.mat.N || c < 0 {
panic(ErrColAccess)
}
if r > c {
r, c = c, r
}
t.mat.Data[r*t.mat.Stride+c] = v
}
// At returns the element at row r, column c.
func (t *TriDense) At(r, c int) float64 {
return t.at(r, c)
}
func (t *TriDense) at(r, c int) float64 {
if r >= t.mat.N || r < 0 {
panic(ErrRowAccess)
}
if c >= t.mat.N || c < 0 {
panic(ErrColAccess)
}
if t.mat.Uplo == blas.Upper {
if r > c {
return 0
}
return t.mat.Data[r*t.mat.Stride+c]
}
if r < c {
return 0
}
return t.mat.Data[r*t.mat.Stride+c]
}
// SetTri sets the element of the triangular matrix at row r, column c to the value v.
// It panics if the location is outside the appropriate half of the matrix.
func (t *TriDense) SetTri(r, c int, v float64) {
t.set(r, c, v)
}
func (t *TriDense) set(r, c int, v float64) {
if r >= t.mat.N || r < 0 {
panic(ErrRowAccess)
}
if c >= t.mat.N || c < 0 {
panic(ErrColAccess)
}
if t.mat.Uplo == blas.Upper && r > c {
panic("mat64: triangular set out of bounds")
}
if t.mat.Uplo == blas.Lower && r < c {
panic("mat64: triangular set out of bounds")
}
t.mat.Data[r*t.mat.Stride+c] = v
}