Diskuze: Brentův-Salaminův Algoritmus (Pí)
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 10 zpráv z 10.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Myslím, že pocet0 by asi neměl být double, ale int.
Co přesně ti nefunguje?
double a = 1;
double b = Math.Sqrt(2) / 2;
double r = 1;
double s = 0.5;
for (int i = 0; i < 5; i++)
{
double an = (a + b) / 2;
double bn = Math.Sqrt(a * b);
double cn = (an - b) * (an - b);
double rn = 2 * r;
double sn = s - cn * rn;
double pi = 2 * an * an / sn;
int k = (int)-Math.Log(cn, 10);
// PI s presnosti na K desetinnych mist
a = an;
b = bn;
r = rn;
s = sn;
}
Jenže, se to mění jen do 4. operace... Já bych potřeboval aby uživatel zadal počet operací.. Když tam dám víc, tak už se to jen opakuje ta stejná hodnota..
No tak má..no potřebuju jak mám ty vzorečky tak aby se v těch
vzorečkách nahrazovali hodnoty nejdříve tam mám ve vzroci a pak potřebuju
an pak an1 pak an2 a to u všech... Jestli chápeš
No jistě, protože typ double má přesnost 15 desetinných míst, víc z
něho už nedostaneš.
Dokonce i když zkusíš použít typ decimal, pořád dostaneš maximálně 28
desetinných míst, což odpovídá 4 krokům.
Brent-Salamin má kvadratickou konvergenci a vysoká přesnost během nízkého počtu iterací je jeho předností.
Nepůjde.
Pokud by ses pokusil použít nějakou knihovnu, která podporuje vyšší počet desetinných míst, vůbec si nepomůžeš, protože potřebuješ inicializovat horní limitu b=sqrtinv(2).
Co myslíš tím "No tak má"? Jakože to pocet0 má být double? Jak se počet desetinných míst zadává desetinným číslem?
Zobrazeno 10 zpráv z 10.