Ultrix-3.1/src/libF77/c_sqrt.c
/**********************************************************************
* Copyright (c) Digital Equipment Corporation 1984, 1985, 1986. *
* All Rights Reserved. *
* Reference "/usr/src/COPYRIGHT" for applicable restrictions. *
**********************************************************************/
/*
* SCCSID: @(#)c_sqrt.c 3.0 4/22/86
*/
#include "complex"
c_sqrt(r, z)
complex *r, *z;
{
double mag, sqrt(), cabs();
if( (mag = cabs(z->real, z->imag)) == 0.)
r->real = r->imag = 0.;
else if(z->real > 0)
{
r->real = sqrt(0.5 * (mag + z->real) );
r->imag = z->imag / r->real / 2;
}
else
{
r->imag = sqrt(0.5 * (mag - z->real) );
if(z->imag < 0)
r->imag = - r->imag;
r->real = z->imag / r->imag /2;
}
}