mirror of
https://github.com/gonum/gonum.git
synced 2025-10-05 15:16:59 +08:00
41 lines
1018 B
Go
41 lines
1018 B
Go
// 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 native
|
|
|
|
import "github.com/gonum/blas"
|
|
|
|
// Dlacpy copies the elements of A specified by uplo into B. Uplo can specify
|
|
// a triangular portion with blas.Upper or blas.Lower, or can specify all of the
|
|
// elemest with blas.All.
|
|
//
|
|
// Dlacpy is an internal routine. It is exported for testing purposes.
|
|
func (impl Implementation) Dlacpy(uplo blas.Uplo, m, n int, a []float64, lda int, b []float64, ldb int) {
|
|
checkMatrix(m, n, a, lda)
|
|
checkMatrix(m, n, b, ldb)
|
|
switch uplo {
|
|
default:
|
|
panic(badUplo)
|
|
case blas.Upper:
|
|
for i := 0; i < m; i++ {
|
|
for j := i; j < n; j++ {
|
|
b[i*ldb+j] = a[i*lda+j]
|
|
}
|
|
}
|
|
|
|
case blas.Lower:
|
|
for i := 0; i < m; i++ {
|
|
for j := 0; j < min(i+1, n); j++ {
|
|
b[i*ldb+j] = a[i*lda+j]
|
|
}
|
|
}
|
|
case blas.All:
|
|
for i := 0; i < m; i++ {
|
|
for j := 0; j < n; j++ {
|
|
b[i*ldb+j] = a[i*lda+j]
|
|
}
|
|
}
|
|
}
|
|
}
|