From c53e9fe25866376d1b3086579c01725444a04702 Mon Sep 17 00:00:00 2001 From: Fabian <@> Date: Tue, 26 Jul 2022 21:27:23 +0200 Subject: 0f1, Code ueberarbeitet --- buch/papers/0f1/listings/kettenbruchRekursion.c | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) (limited to 'buch/papers/0f1/listings/kettenbruchRekursion.c') diff --git a/buch/papers/0f1/listings/kettenbruchRekursion.c b/buch/papers/0f1/listings/kettenbruchRekursion.c index 958d4e1..143683f 100644 --- a/buch/papers/0f1/listings/kettenbruchRekursion.c +++ b/buch/papers/0f1/listings/kettenbruchRekursion.c @@ -1,18 +1,26 @@ -static double fractionIter0f1(const double b0, const double z, unsigned int n) +/** + * @brief Calculates the Hypergeometric Function 0F1(;c;z) + * @param c in 0F1(;c;z) + * @param z in 0F1(;c;z) + * @param k number of itertions (precision) + * @return Result + */ +static double fractionIter0f1(const double c, const double z, unsigned int k) { + //declaration double a = 0.0; double b = 0.0; - double abn = 0.0; + double abk = 0.0; double temp = 0.0; - for (; n > 0; --n) + for (; k > 0; --k) { - abn = z / (n * ((n - 1) + b0)); //abn = ak, bk + abk = z / (k * ((k - 1) + c)); //abk = ak, bk - a = n > 1 ? (1 + abn) : 1; //a0, a1 - b = n > 1 ? -abn : abn; //b1 + a = k > 1 ? (1 + abk) : 1; //a0, a1 + b = k > 1 ? -abk : abk; //b1 - temp = b / (a + temp); + temp = b / (a + temp); ////bk / (ak + last result) } return a + temp; //a0 + temp -- cgit v1.2.1 From 220b382cf4b7019b199c3023ddab73ba2658e27a Mon Sep 17 00:00:00 2001 From: Fabian <@> Date: Wed, 27 Jul 2022 13:08:39 +0200 Subject: 0f1, bilder --- buch/papers/0f1/listings/kettenbruchRekursion.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'buch/papers/0f1/listings/kettenbruchRekursion.c') diff --git a/buch/papers/0f1/listings/kettenbruchRekursion.c b/buch/papers/0f1/listings/kettenbruchRekursion.c index 143683f..3caaf43 100644 --- a/buch/papers/0f1/listings/kettenbruchRekursion.c +++ b/buch/papers/0f1/listings/kettenbruchRekursion.c @@ -17,11 +17,11 @@ static double fractionIter0f1(const double c, const double z, unsigned int k) { abk = z / (k * ((k - 1) + c)); //abk = ak, bk - a = k > 1 ? (1 + abk) : 1; //a0, a1 - b = k > 1 ? -abk : abk; //b1 + a = k > 1 ? (1 + abk) : 1; //a0, a1 + b = k > 1 ? -abk : abk; //b1 - temp = b / (a + temp); ////bk / (ak + last result) + temp = b / (a + temp); //bk / (ak + last result) } - return a + temp; //a0 + temp + return a + temp; //a0 + temp } \ No newline at end of file -- cgit v1.2.1