| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 
 | --- 
:name: ssyequb
:md5sum: f38f288f9e8b71ede27c0a88d4d0021f
:category: :subroutine
:arguments: 
- uplo: 
    :type: char
    :intent: input
- n: 
    :type: integer
    :intent: input
- a: 
    :type: real
    :intent: input
    :dims: 
    - lda
    - n
- lda: 
    :type: integer
    :intent: input
- s: 
    :type: real
    :intent: output
    :dims: 
    - n
- scond: 
    :type: real
    :intent: output
- amax: 
    :type: real
    :intent: output
- work: 
    :type: real
    :intent: workspace
    :dims: 
    - 3*n
- info: 
    :type: integer
    :intent: output
:substitutions: {}
:fortran_help: "      SUBROUTINE SSYEQUB( UPLO, N, A, LDA, S, SCOND, AMAX, WORK, INFO )\n\n\
  *  Purpose\n\
  *  =======\n\
  *\n\
  *  SSYEQUB computes row and column scalings intended to equilibrate a\n\
  *  symmetric matrix A and reduce its condition number\n\
  *  (with respect to the two-norm).  S contains the scale factors,\n\
  *  S(i) = 1/sqrt(A(i,i)), chosen so that the scaled matrix B with\n\
  *  elements B(i,j) = S(i)*A(i,j)*S(j) has ones on the diagonal.  This\n\
  *  choice of S puts the condition number of B within a factor N of the\n\
  *  smallest possible condition number over all possible diagonal\n\
  *  scalings.\n\
  *\n\n\
  *  Arguments\n\
  *  =========\n\
  *\n\
  *  UPLO    (input) CHARACTER*1\n\
  *          Specifies whether the details of the factorization are stored\n\
  *          as an upper or lower triangular matrix.\n\
  *          = 'U':  Upper triangular, form is A = U*D*U**T;\n\
  *          = 'L':  Lower triangular, form is A = L*D*L**T.\n\
  *\n\
  *  N       (input) INTEGER\n\
  *          The order of the matrix A.  N >= 0.\n\
  *\n\
  *  A       (input) REAL array, dimension (LDA,N)\n\
  *          The N-by-N symmetric matrix whose scaling\n\
  *          factors are to be computed.  Only the diagonal elements of A\n\
  *          are referenced.\n\
  *\n\
  *  LDA     (input) INTEGER\n\
  *          The leading dimension of the array A.  LDA >= max(1,N).\n\
  *\n\
  *  S       (output) REAL array, dimension (N)\n\
  *          If INFO = 0, S contains the scale factors for A.\n\
  *\n\
  *  SCOND   (output) REAL\n\
  *          If INFO = 0, S contains the ratio of the smallest S(i) to\n\
  *          the largest S(i).  If SCOND >= 0.1 and AMAX is neither too\n\
  *          large nor too small, it is not worth scaling by S.\n\
  *\n\
  *  AMAX    (output) REAL\n\
  *          Absolute value of largest matrix element.  If AMAX is very\n\
  *          close to overflow or very close to underflow, the matrix\n\
  *          should be scaled.\n\
  *\n\
  *  WORK    (workspace) REAL array, dimension (3*N)\n\
  *\n\
  *  INFO    (output) INTEGER\n\
  *          = 0:  successful exit\n\
  *          < 0:  if INFO = -i, the i-th argument had an illegal value\n\
  *          > 0:  if INFO = i, the i-th diagonal element is nonpositive.\n\
  *\n\n\
  *  Further Details\n\
  *  ======= =======\n\
  *\n\
  *  Reference: Livne, O.E. and Golub, G.H., \"Scaling by Binormalization\",\n\
  *  Numerical Algorithms, vol. 35, no. 1, pp. 97-120, January 2004.\n\
  *  DOI 10.1023/B:NUMA.0000016606.32820.69\n\
  *  Tech report version: http://ruready.utah.edu/archive/papers/bin.pdf\n\
  *\n\
  *  =====================================================================\n\
  *\n"
 |