elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Guía actualizada para evitar que un ransomware ataque tu empresa


+  Foro de elhacker.net
|-+  Programación
| |-+  Programación General
| | |-+  Java
| | | |-+  Calculo del numero PI (Distributivo)
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] Ir Abajo Respuesta Imprimir
Autor Tema: Calculo del numero PI (Distributivo)  (Leído 3,171 veces)
Debci
Wiki

Desconectado Desconectado

Mensajes: 2.021


Actualizate o muere!


Ver Perfil WWW
Calculo del numero PI (Distributivo)
« en: 21 Abril 2010, 20:37 pm »

Hola a todos, estoy creando un sistema para calcular el numero PI con una precisión arbitraria, y tengo varias dudas, si quiero calcularlo bien, quiero hacerlo de manera ordenada, y por tanto dsitributiva, entre varios PC, por lo que he caido en la idea de diseñar una red P2P mezclando JRMI, con sockets y tal, pero no veo la manera de dividir la operacion entre varias personas, en teoria no pretendo dividirla, si no usar todos los PC a la vez para calcularlo.

Luego se me presenta otro problema, que es que quiero ir mostrando numeros uno por uno de los que voy calculando, tengo el siguiente algoritmo:

Código
  1.  
  2. import java.math.*;
  3.  
  4. public class Pi {
  5.    // constantes utilizadas en el calculo de pi
  6.    private static final BigDecimal ZERO = BigDecimal.valueOf(0);
  7.    private static final BigDecimal  ONE = BigDecimal.valueOf(1);
  8.    private static final BigDecimal FOUR = BigDecimal.valueOf(4);
  9.  
  10.    // modo de redondeo utilizado durante el calculo
  11.    private static final int roundingMode = BigDecimal.ROUND_HALF_EVEN;
  12.    //numero de digitos tras el punto decimal
  13.    private int digits;
  14.  
  15.    //Construye una tarea para calcular el numero pi con la precision especificada.    
  16.    public Pi(int digits) {
  17.        this.digits = digits;
  18.    }
  19.    public static void main(String args[])
  20.    {
  21.  
  22.     System.out.println(computePi(100000000));
  23.    }
  24.    // Calcula pi
  25.    public Object execute() {
  26.        return computePi(digits);
  27.    }
  28.  
  29.  
  30.    public static BigDecimal computePi(int digits) {
  31.        int scale = digits + 5;
  32.        BigDecimal arctan1_5 = arctan(5, scale);
  33.        BigDecimal arctan1_239 = arctan(239, scale);
  34.        BigDecimal pi = arctan1_5.multiply(FOUR).subtract(arctan1_239).multiply(FOUR);
  35.         return pi.setScale(digits, BigDecimal.ROUND_HALF_UP);
  36.    }
  37.  
  38.  
  39.    public static BigDecimal arctan(int inverseX, int scale)     {
  40.        BigDecimal result, numer, term;
  41.        BigDecimal invX = BigDecimal.valueOf(inverseX);
  42.        BigDecimal invX2 = BigDecimal.valueOf(inverseX * inverseX);
  43.  
  44.        numer = ONE.divide(invX, scale, roundingMode);
  45.  
  46.        result = numer;
  47.        int i = 1;
  48.        do {
  49.            numer = numer.divide(invX2, scale, roundingMode);
  50.            int denom = 2 * i + 1;
  51.            term = numer.divide(BigDecimal.valueOf(denom), scale, roundingMode);
  52.            if ((i % 2) != 0) {
  53.                result = result.subtract(term);
  54.            } else {
  55.                result = result.add(term);
  56.            }
  57.            System.out.println(term);
  58.            i++;
  59.        } while (term.compareTo(ZERO) != 0);
  60.        return result;
  61.    }
  62. }
  63.  

La cosa esta en que si meto un numero muy bestia, se queda calculando y hasta que no tiene un resultado no muestra, por lo que quiero que cada decimal que se calcule, sea mostrado.

Alguna idea?

Saludos


En línea

Páginas: [1] Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
Google celebra el día del número pi con nuevo récord de cálculo
Noticias
wolfbcn 0 1,161 Último mensaje 14 Marzo 2019, 14:53 pm
por wolfbcn
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines