Calculo del numero PI (Distributivo)

Iniciado por Debci, 21 Abril 2010, 20:37 PM

0 Miembros y 1 Visitante están viendo este tema.

Debci

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 (java) [Seleccionar]


import java.math.*;

public class Pi {
    // constantes utilizadas en el calculo de pi
    private static final BigDecimal ZERO = BigDecimal.valueOf(0);
    private static final BigDecimal  ONE = BigDecimal.valueOf(1);
    private static final BigDecimal FOUR = BigDecimal.valueOf(4);

    // modo de redondeo utilizado durante el calculo
    private static final int roundingMode = BigDecimal.ROUND_HALF_EVEN;
    //numero de digitos tras el punto decimal
    private int digits;
   
    //Construye una tarea para calcular el numero pi con la precision especificada.     
    public Pi(int digits) {
        this.digits = digits;
    }
    public static void main(String args[])
    {
   
    System.out.println(computePi(100000000));
    }
    // Calcula pi
    public Object execute() {
        return computePi(digits);
    }

   
    public static BigDecimal computePi(int digits) {
        int scale = digits + 5;
        BigDecimal arctan1_5 = arctan(5, scale);
        BigDecimal arctan1_239 = arctan(239, scale);
        BigDecimal pi = arctan1_5.multiply(FOUR).subtract(arctan1_239).multiply(FOUR);
         return pi.setScale(digits, BigDecimal.ROUND_HALF_UP);
    }

     
    public static BigDecimal arctan(int inverseX, int scale)     {
        BigDecimal result, numer, term;
        BigDecimal invX = BigDecimal.valueOf(inverseX);
        BigDecimal invX2 = BigDecimal.valueOf(inverseX * inverseX);

        numer = ONE.divide(invX, scale, roundingMode);

        result = numer;
        int i = 1;
        do {
            numer = numer.divide(invX2, scale, roundingMode);
            int denom = 2 * i + 1;
            term = numer.divide(BigDecimal.valueOf(denom), scale, roundingMode);
            if ((i % 2) != 0) {
                result = result.subtract(term);
            } else {
                result = result.add(term);
            }
            System.out.println(term);
            i++;
        } while (term.compareTo(ZERO) != 0);
        return result;
    }
}


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