• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Число Пи на C#

  • Автор темы Автор темы Coxxx
  • Дата начала Дата начала

Coxxx

Ученик
Регистрация
26 Дек 2009
Сообщения
2
Реакции
0
Баллы
0
Число Пи на C#

Приветствую всех.
Помогите решить задачу.
Я пытаюсь сделать приложение которое считало бы число ПИ по этой формуле http://upload.wikimedia.org/math/0/3/7/65027f.png
Это так называемая BBP формула, с помощью которой можно узнать сразу 14 чисел после запятой без знания предыдущих.
На сайте Pi with - LiteratePrograms la_(Python)
использую немного изменённую формулу и предлагают пример на Питоне.
Вот что написал я:
Код:
for (int i = 0; i < 2; i++)
{
//j = j + (1 / 16 ^ i);
PiD = PiD + ((1 / Math.Pow(16, i)) * (4.0 / (8.0 * i + 1.0)) - (2.0 / (8.0 * i + 4.0)) - (1.0 / (8.0 * i + 5.0)) - (1.0 / (8.0 * i + 6.0)));
listBox1.Items.Add(PiD.ToString());

}
Это по формуле из Википедии. Ни каких результатов манипуляция не даёт, хотя всё сделанно как в формуле.
Вот ещё. Аналог Питоновских скриптов:
private double Pi(int n)
{
//n -= 1;
double ret;
double x = (4.0 * S(1.0, n) - 2.0 * S(4.0, n) - S(5.0, n) - S(6.0, n)) % 1.0;

ret = x*Math.Pow(16,n);

return ret;

}
private double S(double j,int n)
{
double r = 0;
double s = 0;
double t = 0;
int nn = 0;

if (n == 0)
nn = n + 1;
else
nn = n;
//Левая сторона
for (int k = 0; k < nn; k++)
{
r = 8 * k + j;
s = s + ((Math.Pow(16, n - k) * r) / r) % 1.0;

}

//Правая сторона
double newt=0;
bool test = true;
int kk = n + 1;
while (test)
{
newt = t + (Math.Pow(16, n - kk) / (8 * kk + j));
if (t == newt)
test = false;
else
t = newt;
kk++;
Console.WriteLine("KK " + kk);
}
return s + t;
Тоже ни чего дельного не даёт.
Помогите реализовать этот метод вычисления числа ПИ. Очень нужно для исследования.
Спасибо!!!
 
Последнее редактирование:
Ни одна из приведенных вами ссылок не открывается.
На первый взгляд, складывается впечатление, что ваши числа не вмещаются даже в double.
Для текстов программ у нас есть тег ]code[ и закрывающий его ]/code[ (разверните скобки) - приведите тексты в порядок.
 
По указанной выше ссылки нет ничего, кроме сообщения о пустой статье. Хотелось бы почитать про этот метод математическое описание, вместо того чтобы разбирать программу.
 
Назад
Сверху