Deutsch
Quelltexte/ Codesnippets

Moderne Alternativen zur Gammafunktion (Kontinuierliche Faktorielle+1-Funktion)

 

p.specht

Jakob Bernoulli's Vorschlag einer kontinuierlichen Funktion statt der nur für ganzzahlige positive Werte definierten Fakultät wurde von Leonard Euler 1729 aufgegriffen und gipfelte in einer sehr komplizierten, im Negativen komplexwertigen Funktion, der 'Gamma-Funktion'. Diese kann bis dato nur mit erheblichem Aufwand mehr oder weniger genau numerisch angenähert berechnet werden.

Daß diese Funktion aber nicht die einzige Möglichkeit darstellt, vernünftige Zwischenwerte zwischen natürlichzahligen Fakultäten zu berechnen, wurde einige Jahrzehnte später klar: Mathematiker wie etwa Hadamard machten Vorschläge, um die störenden Unendlichkeitsstellen und Diskontinuitäten auf der negativen Seite der Zahlenachse zu beseitigen.

Regelmäßig, und das bis in unserer Tage, werden immer wieder Versuche unternommen, die sperrige Gammafunktion endlich durch elegantere Varianten zu ersetzen. Ein Vorschlag von Herrn (p.t.) Peter Luschny aus 2006 beispielsweise schlägt eine besonders elegante und glatte Funktionskurve mit vielen interessanten mathematischen Eigenschaften vor. Wie stets gefordert, hat auch diese 'Luschny-L'-Funktion die Eigenschaft, an ganzzahligen Eingabewerten die entsprechenden, auch schulüblich ausmultiplizierbaren Fakultätswerte anzunehmen. Die Berechnung erfolgt unter Anwendung weiterer, jedoch gut erforschter zahlentheoretischer Funktionen. Anbei eine XProfan-Demoversion des entsprechenden, auf seiner Homepage veröffentlichten, C-Sharp-Programmes.

Hinweis: Das Urheberrecht liegt vollständig bei Herrn P. Luschny! Ein Hinweis auf seine Homepage findet sich im Programmtext.
WindowTitle "Die Luschny-L-Funktion - glatter und eleganter als das Bernoulli/Euler-Gamma"
' C#-Quelle: Appx.4 of https://www.luschny.de/math/factorial/hadamard/HadamardsGammaFunction.html
' Achtung: Die vollen Urheberrechte liegen allein bei Herrn (p.t.) Peter Luschny!
'(DT) Demo-Translation to XProfan11.2a in 2014-10 by P.Specht, Wien (Austria); Ohne Gewähr!
WindowStyle 24:Window 0,0-%maxx,%maxy-40:font 2:set("decimals",14)
var xh&=width(%hwnd)/2:var yh&=height(%hwnd)/2
line 0,yh&-2*xh&,yh&:line xh&,0-xh&,2*yh&
usepen 0,2,255
moveto 0,yh&-LFactorial(&Loop/10)

whileloop -100,100

    print " ";format$("%g",&Loop/10),tab(10);format$("%g",LFactorial(&Loop/10));mkstr$(" ",42-%pos)
    case %csrlin>42:locate 1,1
    lineto xh&+5*&Loop,yh&-10*LFactorial(&Loop/10)

endwhile

beep
waitinput
end

proc Psi :parameters x!

    declare psi!,piCotpix!,result!,C!,r!
    case (x!<=0) and (x!=Round(x!,0)):return -9999999

    if x!<0' reflection formula

        psi! = Psi(1-x!)
        piCotpix! = -Pi()/Tan(-Pi()*x!)
        return psi! - piCotpix!

    endif

    case x!<=val("1e-6"):return -0.57721566490153286 + 1.6449340668482264365 * x! - 1/x!
    result! = 0
    C! = 12

    while x!<C!

        result!=result!-1/x!
        x!=x!+1

    endwhile

    r! = 1/x!
    result!=result!+ Ln(x!) - 0.5 * r!
    r! = r!*r!
    r!=r!*(1/12-(r!*(1/120-(r!*(1/252-(r!*(1/240-(r!*1/132))))))) )
    return result!-r!

endproc'Psi

proc LnFactorial :parameters z!

    '//const double a0 = 1.0 / 12.0;
    '//const double a1 = 1.0 / 30.0;
    '//const double a2 = 53.0 / 210.0;
    '//const double a3 = 195.0 / 371.0;
    '//const double a4 = 22999.0 / 22737.0;
    '//const double a5 = 29944523.0 / 19733142.0;
    '//const double a6 = 109535241009.0 / 48264275462.0;
    var a0! = 0.0833333333333333333333333;
    var a1! = 0.0333333333333333333333333;
    var a2! = 0.252380952380952380952381;
    var a3! = 0.525606469002695417789757;
    var a4! = 1.01152306812684171174737;
    var a5! = 1.51747364915328739842849;
    var a6! = 2.26948897420495996090915;
    var sqrt2Pi! = 0.91893853320467274;
    z! = z! + 1
    return sqrt2Pi! + (Z! - 0.5) * Ln(Z!) - Z! +  \
    a0!/(Z!+a1!/(Z!+a2!/(Z!+a3!/(Z!+a4!/(Z!+a5!/(Z!+a6!/Z!))))))

endproc

proc Factorial :parameters x!

    case (x!<0) and (x!=Round(x!,0)):return -999999999
    case x!=0:return 1
    var y! = x!
    var p! = 1

    while y!<8:p!=p!*y!:y!=y!+1:endwhile

        var r! = Exp(LnFactorial(y!))

        if x!<8:r!=(r!*x!)/(p!*y!):endif

            return r!

        endproc

        proc LFactorial :parameters x!

            case x!=0:return 0.5
            var y! = if(x!<0,-x!*0.5,x!*0.5)
            var G! = y! * (Psi(y!+0.5) - Psi(y!)) - 0.5
            case x!<0:return G!/Factorial(-x!)
            y! = Pi()*x!
            var S! = Sin(y!)/y!
            return (1 - S! * G!) * Factorial(x!)

        endproc

 
XProfan 11
Computer: Gerät, daß es in Mikrosekunden erlaubt, 50.000 Fehler zu machen, zB 'daß' statt 'das'...
16.05.2021  
 



Zum Quelltext


Thementitel, max. 100 Zeichen.
 

Systemprofile:

Kein Systemprofil angelegt. [anlegen]

XProfan:

 Beitrag  Schrift  Smilies  ▼ 

Bitte anmelden um einen Beitrag zu verfassen.
 

Themenoptionen

1.508 Betrachtungen

Unbenanntvor 0 min.
p.specht21.11.2021
R.Schneider20.11.2021
Uwe Lang20.11.2021
Manfred Barei19.11.2021
Mehr...

Themeninformationen

Dieses Thema hat 1 Teilnehmer:

p.specht (1x)


Admins  |  AGB  |  Anwendungen  |  Autoren  |  Chat  |  Datenschutz  |  Download  |  Eingangshalle  |  Hilfe  |  Händlerportal  |  Impressum  |  Mart  |  Schnittstellen  |  SDK  |  Services  |  Spiele  |  Suche  |  Support

Ein Projekt aller XProfaner, die es gibt!


Mein XProfan
Private Nachrichten
Eigenes Ablageforum
Themen-Merkliste
Eigene Beiträge
Eigene Themen
Zwischenablage
Abmelden
 Deutsch English Français Español Italia
Übersetzungen

Datenschutz


Wir verwenden Cookies nur als Session-Cookies wegen der technischen Notwendigkeit und bei uns gibt es keine Cookies von Drittanbietern.

Wenn du hier auf unsere Webseite klickst oder navigierst, stimmst du unserer Erfassung von Informationen in unseren Cookies auf XProfan.Net zu.

Weitere Informationen zu unseren Cookies und dazu, wie du die Kontrolle darüber behältst, findest du in unserer nachfolgenden Datenschutzerklärung.


einverstandenDatenschutzerklärung
Ich möchte keinen Cookie