Blame sysdeps/ieee754/ldbl-96/lgamma_product.c

Packit 6c4009
/* Compute a product of 1 + (T/X), 1 + (T/(X+1)), ....
Packit 6c4009
   Copyright (C) 2015-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#include <math.h>
Packit 6c4009
#include <math_private.h>
Packit 6c4009
#include <float.h>
Packit 6c4009
Packit 6c4009
/* Compute the product of 1 + (T / (X + X_EPS)), 1 + (T / (X + X_EPS +
Packit 6c4009
   1)), ..., 1 + (T / (X + X_EPS + N - 1)), minus 1.  X is such that
Packit 6c4009
   all the values X + 1, ..., X + N - 1 are exactly representable, and
Packit 6c4009
   X_EPS / X is small enough that factors quadratic in it can be
Packit 6c4009
   neglected.  */
Packit 6c4009
Packit 6c4009
double
Packit 6c4009
__lgamma_product (double t, double x, double x_eps, int n)
Packit 6c4009
{
Packit 6c4009
  long double x_full = (long double) x + (long double) x_eps;
Packit 6c4009
  long double ret = 0;
Packit 6c4009
  for (int i = 0; i < n; i++)
Packit 6c4009
    ret += (t / (x_full + i)) * (1 + ret);
Packit 6c4009
  return ret;
Packit 6c4009
}