Ir al contenido principal

Reporte 7 - Distribuidos

Esta semana estubo buena, aclaramos puntos que teniamos que hacer, se puso en claro que es lo que habiamos logrado, y tambien lo que se logra hacer.

En la casa de Saúl, se vieron puntos como:

¿Con que distrubuccion trabajar?                                                                       = Ububtu 10.04
¿Cual es la mejor 32/64 bits?                                                                            = 64 bits
¿Cuales herramientas vamos a instalar para hacer nuestra distribucción?
¿Que lograremos?                                                                                            = conectar todas las pc por vpn
¿Fecha?                                                                                                          = empezamos el 26 de marzo

Ahora que esta todo en la mesa y las cartas repartidas, ya nadamas es cuestion de jugar un rato (con la configuración).

Mostrando avances


Leí sobre MPI y vi muchos códigos, PUNTOS EXTRAS para Emmanuel, por una entrada bien explicada el cual me guié. El objetivo de esta semana era modificar el código de Cecy (pi en paralelo) para hacerlo para cluster.

Este es el código que tengo hasta ahora, como pueden ver es el mismo código que Cecy, entonces, ¿que lo hace diferente? solamente 2 lineas (lo relevante).

import random
import math
import mpi

def enCirculo(x,y):
 acierta = false
 resultado = x**2 + y**2
 if resultado <= 1
  acierta = true
 return acierta

def piCalculo(n):
 c=0
 random.seed(mpi.rank)
 for i in range(n):
  x = random.random()
  y = random.random() 
  acierta = enCirculo(x,y)
  if acierta:
   c += 1
  pi = (4.0*c)/n
 return pi

if mpi.rank == 0:
 print "pi=", piCalculo(10000000/mpi.size), "para un rango", mpi.rank

pimpi = (1.0/mpi.size) * mpi.allreduce(pi,mpi.SUM)

if mpi.rank == 0
 print "valor calculado de PI en", mpi.size, "procesos es" ,pimpi
 print "usando", mpi.size*n, "numeros"


Lo Relevante

Se agregaron varias lineas, al final del código. Pero lo interesante ocurre en las siguientes 2 lineas

random.seed(mpi.rank)

Esto inicializa el generador de números aleatorios, lo que garantiza que nos da una secuencia diferentes
en cada proceso.

mpi.allreduce(pi,mpi.SUM)

Esto nos proporciona una forma de sumar los resultados obtenidos en los procesos. Este programa calcula pi, sumando el promedio de los resultados obtenidos en cada proceso individual.

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
En estos momentos estoy peleando con instalando/configurando el cluster, para correr el ejemplo. El programa lo hice a mano y segun yo debe funcionar.

nadamas que el cluster este listo, pongo las impresiones de pantalla.

Comentarios

Entradas populares de este blog

Pequeño Juego con LEDS y Dip Switch

Siguiendo con los mini-proyectos, lo que quería hacer originalmente era un tipo "candado" con push-button y LEDs, el objetivo seria, meter la combinacion de botones correcta y los LEDS encendería por un motivo practico, en forma de serpiente. El objetivo no cambio, pero por falta de "material" lo hice con un dip switch de X entradas(depende de que tan grande quieras la combinación). CONOCIMIENTOS(max. 7 estrellas): Electronica:     ★ ★ Programación: ★ ★ Juego de Combinación + LEDs El programa es un poco mas complicado que el mini-proyecto pasado , pero aun asi es basico. Guardamos las salidas de los LEDs en un arreglo, despues con los valores recibidos y comparados de los dip switch jugamos con los LEDś. Hardware Requerido (1) Arduino Uno (6) LED (8) Resistencias 330 Ω (1) Dip Switch Circuito Usamos las salidas del ARduino 2-7 para los LEDS Usamos la salida A5, A4 para el dip switch Para hacer prender los LEDS tienes que encontrar la ...

Tarea #2 - LAB Visión - Sal y Pimienta - Procesamiento de imagenes - Python

Que tal para esta entrada se nos encargo  modificar  o agregar a nuestro código, una rutina que agregara degradación por adición de ruido(Sal y pimienta) base a dos parámetros: Intensidad = que tanto porcentaje de la imagen se le agregara sal y pimienta Polarización = que tan negros/blancos se pone un pixel seleccionado. y otra rutina que quitara filtrara ese ruido. Antes de comenzar Mi programa se esta empezando a poner " FEO " son demasiados métodos y por cada tarea esta creciendo considerablemente, pese a esto, esta sera la ultima entrada que estaré modificando este código, el las siguientes trabajare por clases.  El los avances de la tarea están en mi  github . Un poco de teoría Les comparto información de relevante que me ayudo a despejar dudas, al final de la entrada en el apartado de REFERENCIAS pondré los links de TODA esta información. El RUIDO en las imágen...

Tarea #5 - Codigo Hamming - Python

Codigo hamming Liga al repo Teoria segun wikipedia Antes de los códigos Hamming se utilizaron ciertos códigos detectores de error, como lo fueron el código linteing, pero ninguno llegó a ser tan eficaz como los de Hamming. A continuación se describen algunos de estos códigos. Paridad   La   paridad   consiste en añadir un bit, denominado   bit de paridad , que indique si el número de los bits de valor 1 en los datos precedentes es par o impar. Si un solo bit cambiara por error en la transmisión, el mensaje cambiará de paridad y el error se puede detectar (nótese que el bit donde se produzca el error puede ser el mismo bit de paridad). La convención más común es que un valor de paridad   1   indica que hay un número impar de unos en los datos, y un valor de paridad de   0   indica que hay un número par de unos en los datos. info. completa y un vídeo que me ayudo mucho para esta tarea: (TIENEN QUE VERLO - OBLIGATORIO) http://www.you...