123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381 |
- #include "slatec-internal.hpp"
- static integer const c__4 = 4;
- static integer const c__15 = 15;
- static integer const c__16 = 16;
- static integer const c__5 = 5;
- static integer const c__14 = 14;
- static integer const c__9 = 9;
- static integer const c__1 = 1;
- static integer const c__2 = 2;
- int zbesk_(double *zr, double *zi, double const *fnu,
- integer const *kode, integer const *n, double *cyr, double *cyi, integer *
- nz, integer *ierr)
- {
-
- integer i__1, i__2;
- double d__1;
-
- integer k, k1, k2;
- double aa, bb, fn, az;
- integer nn;
- double rl;
- integer mr, nw;
- double dig, arg, aln, r1m5, ufl;
- integer nuf;
- double tol, alim, elim;
- double fnul;
-
- --cyi;
- --cyr;
-
- *ierr = 0;
- *nz = 0;
- if (*zi == (float)0. && *zr == (float)0.) {
- *ierr = 1;
- }
- if (*fnu < 0.) {
- *ierr = 1;
- }
- if (*kode < 1 || *kode > 2) {
- *ierr = 1;
- }
- if (*n < 1) {
- *ierr = 1;
- }
- if (*ierr != 0) {
- return 0;
- }
- nn = *n;
- d__1 = d1mach_(4);
- tol = max(d__1,1e-18);
- k1 = i1mach_(15);
- k2 = i1mach_(16);
- r1m5 = d1mach_(5);
- i__1 = abs(k1), i__2 = abs(k2);
- k = min(i__1,i__2);
- elim = (k * r1m5 - 3.) * 2.303;
- k1 = i1mach_(14) - 1;
- aa = r1m5 * k1;
- dig = min(aa,18.);
- aa *= 2.303;
- d__1 = -aa;
- alim = elim + max(d__1,-41.45);
- fnul = (dig - 3.) * 6. + 10.;
- rl = dig * 1.2 + 3.;
- az = zabs_(zr, zi);
- fn = *fnu + (nn - 1);
- aa = .5 / tol;
- bb = i1mach_(9) * .5;
- aa = min(aa,bb);
- if (az > aa) {
- goto L260;
- }
- if (fn > aa) {
- goto L260;
- }
- aa = sqrt(aa);
- if (az > aa) {
- *ierr = 3;
- }
- if (fn > aa) {
- *ierr = 3;
- }
- ufl = d1mach_(1) * 1e3;
- if (az < ufl) {
- goto L180;
- }
- if (*fnu > fnul) {
- goto L80;
- }
- if (fn <= 1.) {
- goto L60;
- }
- if (fn > 2.) {
- goto L50;
- }
- if (az > tol) {
- goto L60;
- }
- arg = az * .5;
- aln = -fn * log(arg);
- if (aln > elim) {
- goto L180;
- }
- goto L60;
- L50:
- zuoik_(zr, zi, fnu, kode, &c__2, &nn, &cyr[1], &cyi[1], &nuf, &tol, &elim,
- &alim);
- if (nuf < 0) {
- goto L180;
- }
- *nz += nuf;
- nn -= nuf;
- if (nn == 0) {
- goto L100;
- }
- L60:
- if (*zr < 0.) {
- goto L70;
- }
- zbknu_(zr, zi, fnu, kode, &nn, &cyr[1], &cyi[1], &nw, &tol, &elim, &alim);
- if (nw < 0) {
- goto L200;
- }
- *nz = nw;
- return 0;
- L70:
- if (*nz != 0) {
- goto L180;
- }
- mr = 1;
- if (*zi < 0.) {
- mr = -1;
- }
- zacon_(zr, zi, fnu, kode, &mr, &nn, &cyr[1], &cyi[1], &nw, &rl, &fnul, &
- tol, &elim, &alim);
- if (nw < 0) {
- goto L200;
- }
- *nz = nw;
- return 0;
- L80:
- mr = 0;
- if (*zr >= 0.) {
- goto L90;
- }
- mr = 1;
- if (*zi < 0.) {
- mr = -1;
- }
- L90:
- zbunk_(zr, zi, fnu, kode, &mr, &nn, &cyr[1], &cyi[1], &nw, &tol, &elim, &
- alim);
- if (nw < 0) {
- goto L200;
- }
- *nz += nw;
- return 0;
- L100:
- if (*zr < 0.) {
- goto L180;
- }
- return 0;
- L180:
- *nz = 0;
- *ierr = 2;
- return 0;
- L200:
- if (nw == -1) {
- goto L180;
- }
- *nz = 0;
- *ierr = 5;
- return 0;
- L260:
- *nz = 0;
- *ierr = 4;
- return 0;
- }
|