atl_srefrotg.c

来自「基于Blas CLapck的.用过的人知道是干啥的」· C语言 代码 · 共 147 行

C
147
字号
/* --------------------------------------------------------------------- * * -- Automatically Tuned Linear Algebra Software (ATLAS) *    (C) Copyright 2000 All Rights Reserved * * -- ATLAS routine -- Version 3.2 -- December 25, 2000 * * Author         : Antoine P. Petitet * Originally developed at the University of Tennessee, * Innovative Computing Laboratory, Knoxville TN, 37996-1301, USA. * * --------------------------------------------------------------------- * * -- Copyright notice and Licensing terms: * *  Redistribution  and  use in  source and binary forms, with or without *  modification, are  permitted provided  that the following  conditions *  are met: * * 1. Redistributions  of  source  code  must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce  the above copyright *    notice,  this list of conditions, and the  following disclaimer in *    the documentation and/or other materials provided with the distri- *    bution. * 3. The name of the University,  the ATLAS group,  or the names of its *    contributors  may not be used to endorse or promote products deri- *    ved from this software without specific written permission. * * -- Disclaimer: * * THIS  SOFTWARE  IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,  INCLUDING,  BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,  INDIRECT, INCIDENTAL, SPE- * CIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED * TO,  PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEO- * RY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT  (IN- * CLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * --------------------------------------------------------------------- *//* * Include files */#include "atlas_refmisc.h"#include "atlas_reflevel1.h"void ATL_srefrotg(   float                      * A,   float                      * B,   float                      * C,   float                      * S){/* * Purpose * ======= * * ATL_srefrotg  constructs a Givens plane rotation. Given the scalars a * and b, this routine computes the following quantities: * *    sigma = sgn(a) if |a| > |b|, sgn(b) otherwise; *    r     = sigma * sqrt( a^2 + b^2 ); *    c     = a / r if r <> 0, 1 otherwise; *    s     = b / r if r <> 0, 0 otherwise. * * The numbers c, s and r then satisfy the matrix equation: * *    [ c  s ] [ a ]    [ r ] *    [ -s c ] [ b ] =  [ 0 ]. * * The introduction of  sigma  is not essential  to the computation of a * Givens rotation matrix, but it permits later stable reconstruction of * c and s from just one stored number.  For  this purpose, this routine * also computes * *         s        if |a| > |b|, *    z =  1 / c    if |b| >= |a| and c <> 0, *         1        if c = 0. * * This subroutine returns r overwriting a, and z overwriting b, as well * as returning c and s. If one later wishes to reconstruct c and s from * z, it can be done as follows: * *    if  z  = 1,    set c = 0             and 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). * * See ``Basic Linear Algebra Subprograms for Fortran Usage'' by C. Law- * son, R. Hanson, D. Kincaid and F. Krogh, ACM Transactions on Mathema- * tical Software, 1979, 5(3) pp 308-323, for further information. * * Arguments * ========= * * A       (input/output)                float * *         On entry, A specifies the scalar a. On exit, A is overwritten *         by the scalar r defined above. * * B       (input/output)                float * *         On entry, B specifies the scalar b. On exit, B is overwritten *         by the scalar z defined above. * * C       (output)                      float * *         On exit, C  specifies the scalar c defined above. * * S       (output)                      float * *         On exit, S  specifies the scalar s defined above. * * --------------------------------------------------------------------- *//* * .. Local Variables .. */   register float             absa, absb, roe, scale, r, tmpa, tmpb, z;/* .. * .. Executable Statements .. * */   absa = Msabs( *A ); absb = Msabs( *B );   roe  = ( absa > absb ? (*A) :  (*B) ); scale = absa + absb;   if( scale != ATL_sZERO )   {      tmpa = (*A) / scale; tmpb = (*B) / scale;      if( roe < ATL_sZERO )      { r = - scale * sqrt( ( tmpa * tmpa ) + ( tmpb * tmpb ) ); }      else      { r =   scale * sqrt( ( tmpa * tmpa ) + ( tmpb * tmpb ) ); }      *C = (*A) / r; *S = (*B) / r; z =  ATL_sONE;      if(   absa >  absb ) { z = *S; }      if( ( absb >= absa ) && ( (*C) != ATL_sZERO ) )      { z = ATL_sONE / (*C); }   }   else { *C = ATL_sONE; *S = r = z = ATL_sZERO; }   *A = r; *B = z;/* * End of ATL_srefrotg */}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?