C Library Functions  - srotg (3)

NAME

srotg(3f) - [BLAS:SINGLE_BLAS_LEVEL1] Generate Given’s rotation.

CONTENTS

Synopsis
Definition
Options
     A
     B
Authors
     Further Details
See Also

SYNOPSIS

subroutine srotg( a, b, c, s )

   .. Scalar Arguments ..
   real(wp),intent(inout) :: a, b
   real(wp),intent(out)   :: c, s
   ..
   .. Local Scalars ..
   real(wp) :: anorm, bnorm, scl, sigma, r, z
   ..

DEFINITION

SROTG constructs a plane rotation

     [  c  s ] [ a ] = [ r ]
     [ -s  c ] [ b ]   [ 0 ]

satisfying c**2 + s**2 = 1.

The computation uses the formulas

    sigma = sgn(a)    if |a| >  |b|
          = sgn(b)    if |b| >= |a|
    r = sigma*sqrt( a**2 + b**2 )
    c = 1; s = 0      if r = 0
    c = a/r; s = b/r  if r != 0

The subroutine also computes

    z = s    if |a| > |b|,
      = 1/c  if |b| >= |a| and c != 0
      = 1    if c = 0

This allows c and s to be reconstructed from z as follows:

    If z = 1, set c = 0, s = 1.
    If |z| < 1, set c = sqrt(1 - z**2) and s = z.
    If |z| > 1, set c = 1/z and s = sqrt( 1 - c**2).

OPTIONS

    A

A is REAL On entry, the scalar a. On exit, the scalar r.

    B

B is REAL On entry, the scalar b. On exit, the scalar z.

    C

C is REAL The scalar c.

    S

S is REAL The scalar s.

AUTHORS

o Edward Anderson, Lockheed Martin

 \par Contributors:

Weslley Pereira, University of Colorado Denver, USA

    FURTHER DETAILS

Anderson E. (2017) Algorithm 978: Safe Scaling in the Level 1 BLAS ACM Trans Math Softw 44:1--28 https://doi.org/10.1145/3061665

SEE ALSO

Online html documentation available at http://www.netlib.org/lapack/explore-html/


Nemo Release 3.1 srotg (3) July 22, 2023
Generated by manServer 1.08 from adb004cf-7eb1-4bad-9ec6-28e030d3189f using man macros.