+++ /dev/null
-// Copyright ©2017 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 gonum
-
-import "gonum.org/v1/gonum/blas/blas64"
-
-// Dlapmt rearranges the columns of the m×n matrix X as specified by the
-// permutation k_0, k_1, ..., k_n-1 of the integers 0, ..., n-1.
-//
-// If forward is true a forward permutation is performed:
-//
-// X[0:m, k[j]] is moved to X[0:m, j] for j = 0, 1, ..., n-1.
-//
-// otherwise a backward permutation is performed:
-//
-// X[0:m, j] is moved to X[0:m, k[j]] for j = 0, 1, ..., n-1.
-//
-// k must have length n, otherwise Dlapmt will panic. k is zero-indexed.
-func (impl Implementation) Dlapmt(forward bool, m, n int, x []float64, ldx int, k []int) {
- checkMatrix(m, n, x, ldx)
- if len(k) != n {
- panic(badKperm)
- }
-
- if n <= 1 {
- return
- }
-
- for i, v := range k {
- v++
- k[i] = -v
- }
-
- bi := blas64.Implementation()
-
- if forward {
- for j, v := range k {
- if v >= 0 {
- continue
- }
- k[j] = -v
- i := -v - 1
- for k[i] < 0 {
- bi.Dswap(m, x[j:], ldx, x[i:], ldx)
-
- k[i] = -k[i]
- j = i
- i = k[i] - 1
- }
- }
- } else {
- for i, v := range k {
- if v >= 0 {
- continue
- }
- k[i] = -v
- j := -v - 1
- for j != i {
- bi.Dswap(m, x[j:], ldx, x[i:], ldx)
-
- k[j] = -k[j]
- j = k[j] - 1
- }
- }
- }
-
- for i := range k {
- k[i]--
- }
-}