LAPACK
3.12.1
LAPACK: Linear Algebra PACKage
Loading...
Searching...
No Matches
slapmt.f
Go to the documentation of this file.
1
*> \brief \b SLAPMT performs a forward or backward permutation of the columns of a matrix.
2
*
3
* =========== DOCUMENTATION ===========
4
*
5
* Online html documentation available at
6
* http://www.netlib.org/lapack/explore-html/
7
*
8
*> Download SLAPMT + dependencies
9
*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.tgz?format=tgz&filename=/lapack/lapack_routine/slapmt.f">
10
*> [TGZ]</a>
11
*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.zip?format=zip&filename=/lapack/lapack_routine/slapmt.f">
12
*> [ZIP]</a>
13
*> <a href="http://www.netlib.org/cgi-bin/netlibfiles.txt?format=txt&filename=/lapack/lapack_routine/slapmt.f">
14
*> [TXT]</a>
15
*
16
* Definition:
17
* ===========
18
*
19
* SUBROUTINE SLAPMT( FORWRD, M, N, X, LDX, K )
20
*
21
* .. Scalar Arguments ..
22
* LOGICAL FORWRD
23
* INTEGER LDX, M, N
24
* ..
25
* .. Array Arguments ..
26
* INTEGER K( * )
27
* REAL X( LDX, * )
28
* ..
29
*
30
*
31
*> \par Purpose:
32
* =============
33
*>
34
*> \verbatim
35
*>
36
*> SLAPMT rearranges the columns of the M by N matrix X as specified
37
*> by the permutation K(1),K(2),...,K(N) of the integers 1,...,N.
38
*> If FORWRD = .TRUE., forward permutation:
39
*>
40
*> X(*,K(J)) is moved X(*,J) for J = 1,2,...,N.
41
*>
42
*> If FORWRD = .FALSE., backward permutation:
43
*>
44
*> X(*,J) is moved to X(*,K(J)) for J = 1,2,...,N.
45
*> \endverbatim
46
*
47
* Arguments:
48
* ==========
49
*
50
*> \param[in] FORWRD
51
*> \verbatim
52
*> FORWRD is LOGICAL
53
*> = .TRUE., forward permutation
54
*> = .FALSE., backward permutation
55
*> \endverbatim
56
*>
57
*> \param[in] M
58
*> \verbatim
59
*> M is INTEGER
60
*> The number of rows of the matrix X. M >= 0.
61
*> \endverbatim
62
*>
63
*> \param[in] N
64
*> \verbatim
65
*> N is INTEGER
66
*> The number of columns of the matrix X. N >= 0.
67
*> \endverbatim
68
*>
69
*> \param[in,out] X
70
*> \verbatim
71
*> X is REAL array, dimension (LDX,N)
72
*> On entry, the M by N matrix X.
73
*> On exit, X contains the permuted matrix X.
74
*> \endverbatim
75
*>
76
*> \param[in] LDX
77
*> \verbatim
78
*> LDX is INTEGER
79
*> The leading dimension of the array X, LDX >= MAX(1,M).
80
*> \endverbatim
81
*>
82
*> \param[in,out] K
83
*> \verbatim
84
*> K is INTEGER array, dimension (N)
85
*> On entry, K contains the permutation vector. K is used as
86
*> internal workspace, but reset to its original value on
87
*> output.
88
*> \endverbatim
89
*
90
* Authors:
91
* ========
92
*
93
*> \author Univ. of Tennessee
94
*> \author Univ. of California Berkeley
95
*> \author Univ. of Colorado Denver
96
*> \author NAG Ltd.
97
*
98
*> \ingroup lapmt
99
*
100
* =====================================================================
101
SUBROUTINE
slapmt
( FORWRD, M, N, X, LDX, K )
102
*
103
* -- LAPACK auxiliary routine --
104
* -- LAPACK is a software package provided by Univ. of Tennessee, --
105
* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
106
*
107
* .. Scalar Arguments ..
108
LOGICAL
FORWRD
109
INTEGER
LDX, M, N
110
* ..
111
* .. Array Arguments ..
112
INTEGER
K( * )
113
REAL
X( LDX, * )
114
* ..
115
*
116
* =====================================================================
117
*
118
* .. Local Scalars ..
119
INTEGER
I, II, J, IN
120
REAL
TEMP
121
* ..
122
* .. Executable Statements ..
123
*
124
IF
( n.LE.1 )
125
$
RETURN
126
*
127
DO
10 i = 1, n
128
k( i ) = -k( i )
129
10
CONTINUE
130
*
131
IF
( forwrd )
THEN
132
*
133
* Forward permutation
134
*
135
DO
60 i = 1, n
136
*
137
IF
( k( i ).GT.0 )
138
$
GO TO
40
139
*
140
j = i
141
k( j ) = -k( j )
142
in = k( j )
143
*
144
20
CONTINUE
145
IF
( k( in ).GT.0 )
146
$
GO TO
40
147
*
148
DO
30 ii = 1, m
149
temp = x( ii, j )
150
x( ii, j ) = x( ii, in )
151
x( ii, in ) = temp
152
30
CONTINUE
153
*
154
k( in ) = -k( in )
155
j = in
156
in = k( in )
157
GO TO
20
158
*
159
40
CONTINUE
160
*
161
60
CONTINUE
162
*
163
ELSE
164
*
165
* Backward permutation
166
*
167
DO
110 i = 1, n
168
*
169
IF
( k( i ).GT.0 )
170
$
GO TO
100
171
*
172
k( i ) = -k( i )
173
j = k( i )
174
80
CONTINUE
175
IF
( j.EQ.i )
176
$
GO TO
100
177
*
178
DO
90 ii = 1, m
179
temp = x( ii, i )
180
x( ii, i ) = x( ii, j )
181
x( ii, j ) = temp
182
90
CONTINUE
183
*
184
k( j ) = -k( j )
185
j = k( j )
186
GO TO
80
187
*
188
100
CONTINUE
189
190
110
CONTINUE
191
*
192
END IF
193
*
194
RETURN
195
*
196
* End of SLAPMT
197
*
198
END
slapmt
subroutine slapmt(forwrd, m, n, x, ldx, k)
SLAPMT performs a forward or backward permutation of the columns of a matrix.
Definition
slapmt.f:102
SRC
slapmt.f
Generated on Mon Jan 20 2025 17:18:12 for LAPACK by
1.11.0