Foro de elhacker.net

Programación => Java => Mensaje iniciado por: Debci en 21 Abril 2010, 20:37 pm



Título: Calculo del numero PI (Distributivo)
Publicado por: Debci 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