Translate

jueves, 4 de junio de 2015

Elm

Elm es un lenguaje funcional basado en Functional Reactive Programming.

Con características bien funcionales como inmutabilidad, funciones de primer orden y otras ventajas de los lenguajes funcionales, se hace fácil escribir código fácil de mantener y corto.

Elm compila a HTML, CSS y JavaScript. No es fácil crear aplicaciones web pero con este framework podemos generar el maquetado de forma automática.



Dejo link: http://elm-lang.org/

Lazy evaluation y Enfoque declarativo en Python

Cuando un lenguaje tiene un déficit, nace una librería que soluciona el problema pero si el lenguaje cubre todos los frentes se vuelve muy complejo. Por lo tanto lo mejor es tener un equilibrio.

Python es un ejemplo de equilibrio y elegancia. Pero no tiene tanto soporte para el paradigma funcional pero existen librerías que permiten extender el lenguaje.

Quiero compartir una presenta
ción que nos explica como obtener caracteríasticas de lenguajes funcionales en python:

http://kachayev.github.io/talks/kharkivpy%236/index.html#/

martes, 2 de junio de 2015

El Dr. Erik Meijer dicta Functional Programming Fundamentals en chanel 9


Mire lo que encontré, un excelente curso de programación funcional por el Dr. Erik Meijer :

http://channel9.msdn.com/Series/C9-Lectures-Erik-Meijer-Functional-Programming-Fundamentals/Lecture-Series-Erik-Meijer-Functional-Programming-Fundamentals-Chapter-1

Para el que no conoce al Dr Meijer, es un groso entre otras cosas responsable de Reactive programming framework (Reactive Extensions) para .NET, tambien dicta el curso de reactive en coursera.  Lo que más me interesa saber es donde compra esas remeras locas :P



domingo, 31 de mayo de 2015

Con que lenguaje de programación gane dinero?


Este es un post autoreferencial, hice un ejercicio mental. Me puse a pensar con cual lenguaje realmente gane dinero y cual no. Es como para evaluar el mercado, el que paso no el que vendrá y poder poner las cartas en la mesa, que si opino de esta forma es porque esto me dio trabajo. Es decir ver porque no soy objetivo.

Tengo en mi legado código en :

  • Java (la mayor cantidad de trabajos)
  • php (si si y el bug fixing me dio muchoo trabajo, debe ser que gracias a este lenguaje odie el tipado dinámico)
  • sql, pl/sql y Tsql (hice solo reportes y algun que otro store procedure)
  • javascript y HTML (cuando ajax se hacia sin frameworks, tuve mucho trabajo solo en javascript)
  • C++, Object Pascal (solo dando clases)
  • y otros pero muy poco, como Action script, C#, Ruby

Que lenguaje estudie más y trabaje menos? C# sin duda, es tan así que me rendí, lo deje en el C# 4; ahora tengo que retomar :(

Que lenguaje me gustaría trabajar en el futuro? Muchos Ruby, Groovy, Scala, Haskell y me da mucha curiosidad Go (aun que lo critico mucho)

Conclusión: billetera manda, no tengo la barita mágica pero estoy estudiando un poco python, scala y voy a retomar C#, que para mi, se van a utilizar más, hago bien?

jueves, 28 de mayo de 2015

R vs Python

Sigo con la disyuntiva R o Python para procesar datos en ambientes científicos.

R nació para manipular datos estadísticos, el lenguaje tiene muchas funcionalidades pero python esta ganando espacio de a poco y por alguna razón debe ser.

Les dejo una infografìa:



Dejo un link:
http://www.kdnuggets.com/2015/05/r-vs-python-data-science.html?utm_content=bufferf72a4&utm_medium=social&utm_source=plus.google.com&utm_campaign=update



SQL Server 2016 soporta JSON

Por fin! No es por comparar pero postgres hace 1 año o más que soporta json como tipo de dato nativo en su base de datos. Ahora la gente de Microsoft tiene el agrado de anunciar que Sql server 2016 siguiendo una natural corriente soporta JSON como un tipo de datos.

Es una muy buena noticia, las cosas de a poquito se van regulando, dado que a mi entender esto debería estar hace rato pero llego que es lo importante.

Como es esperable podemos importar datos con este formato y tambien exportar o extraer. A la vez podemos hacer consultas a estos datos.

Dejo link:
http://www.infoq.com/news/2015/05/SQL-Server-JSON

R vs Python vs SAS

Muchas veces comparamos lenguajes en el blog y hoy no va a ser diferente, les quiero dejar una comparativa de python vs r v SAS

SAS vs R vs Python infographic datascience

Dejo link;
http://www.analyticsvidhya.com/blog/2015/05/infographic-quick-guide-sas-python/


lunes, 25 de mayo de 2015

Java cumple 20 años, casi tan joven como yo!

Java cumple 20 años, existe un tecnicismo importante es la fecha del primer release que tiene poco que ver con java como lo conocemos, pero bueno siempre es ocación valida para festejar.

Les dejo una infografía:

domingo, 24 de mayo de 2015

Les presento a Debian 8

Sin palabras, que bueno que esta Debian 8 y viendo la nueva versión de gnome creo que encontraron el camino. Debian 8 nos demuestra que un sistema operativo pensado de forma robusta y para servidores tambien puede ser utilizado por usuarios finales.

Empece instalándolo, la instalación es igual a cualquier Debian, pero me sorprendió que me de a elegir que escritorio quería instalar, esto es muy bueno!!


Finalizada la instalación me encontré con un entorno intuitivo, mira:







Dejo link;
https://www.debian.org/index.es.html


viernes, 22 de mayo de 2015

Contratos en C#

Leyendo sobre C# en infoQ parece ser que quieren agregar contratos, pero que serían los  contratos? En un momento de mi vida yo escribí sobre contratos, escribí algo como esto:

"Eiffel es el lenguaje pionero en el diseño por contrato. Diseño por contrato es un concepto basado en la calidad del software.

Diseño por contrato es una metafora de como los objetos deben colaborar entre ellos. La metafora se puede explicar como un cliente que debe contratar un servicio; lo cual lo hace por medio de un contrato.

El proveedor debe proporcionar un producto determinado o servicio y tiene derecho a esperar hasta que el cliente pague.

El cliente debe pagar y tiene derecho a obtener el producto o servicio.
Ambas partes deben cumplir con ciertas obligaciones, tales como las leyes y reglamentos, aplicables a todos los contratos."

Volviendo a C# han decidido implementar un mecanismo de programación basada en contratos de la siguiente manera:

public int Insert(T item, int index)
    requires index >= 0 && index <= Count
    ensures return >= 0 && return < Count
{ … }

Lo que esta haciendo acá es asegurarse de que index sea mayor a 0 y menor a count.

Dejo link: http://www.infoq.com/news/2015/05/CSharp-7-contract

WCF es Open Source

Ya esta no? mucha publicidad a microsoft para este humilde blog. Pero que más decir para mi es impensable lo que esta pasando con microsoft y disculpen que sea tan entusiasta, si no soy entusiasta con esto, con que? WCF open source, no lo veía ni en figuritas.

Para el que no conoce, Windows Communication Foundation (WCF) es un marco de trabajo para la creación de aplicaciones orientadas a servicios. Con WCF, es posible enviar datos como mensajes asincrónicos de un extremo de servicio a otro. Un extremo de servicio puede formar parte de un servicio disponible continuamente hospedado por IIS, o puede ser un servicio hospedado en una aplicación. Un extremo puede ser un cliente de un servicio que solicita datos de un extremo de servicio.

La verdad es que desconozco las partes técnicas de WCF pero me atrevo a copiar las librerías que han liberado:

  • ServiceModel.Primitives
  • ServiceModel.Http
  • ServiceModel.NetTcp
  • ServiceModel.Duplex
  • ServiceModel.Security


Dejo link: http://www.infoq.com/news/2015/05/WCF-Open-Source

jueves, 21 de mayo de 2015

Si los lenguajes fueran autos.


En el blog hubo varias comparaciones de lenguajes de programación y comparándolo con varias cosas. Ahora llega una comparación con autos.

Dejo el link: http://crashworks.org/if_programming_languages_were_vehicles/

lunes, 18 de mayo de 2015

RabbitMQ, una cola de mensajería open source


Ya he hablado ciento de veces JMS en resumen podemos decir:

Cuando necesitamos comunicar 2 aplicaciones por medio de una red, se hace prioritario que las dos aplicaciones estén disponibles, por ejemplo cuando una aplicación se comunica con otra por medio llamados a procedimientos remotos (COM, CORBA, DCE y EJB) la aplicación receptora del mensaje debe estar activa, si esto no es así no recibirá nunca el mensaje. En ocasiones es poco probable poder realizar una comunicación sincrónica. La mensajería asíncrona es una forma de enviar mensajes indirectamente de una aplicación a otra sin esperar una respuesta.

JMS ofrece a las aplicaciones Java la opción de comunicarse de forma asíncrona. Cuando los mensajes se envían de forma asíncrona, el cliente no tiene que esperar a que el servicio procese el mensaje, ni a que el mensaje sea entregado. El cliente envía si mensaje y después continua con la suposición de que el servicio finalmente lo recibirá y procesará.

Cuando nosotros enviamos una carta no la enviamos por nuestros propios medios sino que la enviamos por medio del servicio postal. Ponemos la dirección la estampilla y listo. De forma similar, la vía indirecta el la clave de JMS. Cuando una aplicación envía información a otra mediante JMS, no hay vinculo directo entre ambas aplicaciones. En su lugar, la aplicación emisora coloca el mensaje en manos de un servicio que garantiza su entrega a la aplicación receptora. Hay dos conceptos principales en JMS: corredores de mensaje (message brokers) y destinos.

Cuando una aplicación envía un mensaje, lo entrega a un corredor de mensajes. El corredor de mensajes es la respuesta JMS a la oficina de correos. EL corredor de mensajes se asegurará de que el mensaje sea entregado en el destino especificado, dejando que el emisor siga con sus asuntos.

Cuando enviamos un correo es importante poner la dirección para que el servicio postal sepa dónde debe ser entregada. De igual forma, en JMS, los mensajes tienen una dirección con un destino. Los destinos son como los buzones donde se colocan los mensajes hasta que alguien llega a recogerlos.

No obstante, a diferencia de las direcciones postales, que indican una persona especifica o una calle, los destinos son menos específicos. A los destinos solo les incumbe donde sera recogido el mensaje, no quien lo recogerá. De esta forma los destinos son como enviar una carta dirigida “al residente”.

En JMS, hay dos tipos de destinos: colas y temas. Cada uno de estos está asociado a un modelo de mensajería concreto, bien de punto a punto (para colas) o bien de emisor a suscriptor (para temas)

Punto a Punto: cada mensaje tiene exactamente un emisor y un receptor. Cuando se entrega el mensaje al corredor de mensajes, este lo pone en una cola, cuando el receptor pide el mensaje este es eliminado de la cola.

Emisor a suscriptor: El mensaje es enviado a un tema todos los suscriptores del tema recibiran una copia del mensaje.

La comunicación asíncrona a través de JMS ofrece diversas ventajas sobre la comunicación sincrónica:

  • La comunicación sincrónica implica una espera.
  • El cliente no esta acoplado a la disponibilidad del servicio
  • El cliente no esta acoplado a la ubicación del servicio
La implementación más utilizada en java es ActiveMQ pero leyendo sobre RabbitMQ, quede sorprendido, entre sus características podemos decir:
  • Robusto
  • Fácil de utilizar
  • Multiplataforma
  • Soporte comercial y open source
Ojo no es solo utilizable desde Java, podemos utilizarlo desde multiples plataformas: Ruby, .net, python, erlang, haaskell, Go, C++, Node.js, PHP y todos los lenguajes java (scala, groovy, etc) 

Veamos un ejemplo, vamos a tener 2 aplicaciones una que envía hecha en python y la otra que recibe hecha en java;


#!/usr/bin/env python
import pika

connection = pika.BlockingConnection(pika.ConnectionParameters(
               'localhost'))
channel = connection.channel()
channel.queue_declare(queue='hello')
channel.basic_publish(exchange='',
                      routing_key='hello',
                      body='Hello World!')
print " [x] Sent 'Hello World!'"


Ahora vamos a hacer un cliente en java: 

import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.QueueingConsumer;

public class Recv {

  private final static String QUEUE_NAME = "hello";

  public static void main(String[] argv)
      throws java.io.IOException,
             java.lang.InterruptedException {

    ConnectionFactory factory = new ConnectionFactory();
    factory.setHost("localhost");
    Connection connection = factory.newConnection();
    Channel channel = connection.createChannel();

    channel.queueDeclare(QUEUE_NAME, false, false, false, null);
    
    QueueingConsumer consumer = new QueueingConsumer(channel);
    channel.basicConsume(QUEUE_NAME, true, consumer);

    while (true) {
      QueueingConsumer.Delivery delivery = consumer.nextDelivery();
      String message = new String(delivery.getBody());
      System.out.println(" [x] Received '" + message + "'");
    }

    }
}

Muy bueno!!

Dejo Link:

martes, 12 de mayo de 2015

ATOM, A hackable text editor for the 21st Century


Hace tiempo que utilizo ATOM pero nunca se me ocurrió hacer un post a este excelente editor.

Entre sus características podemos nombrar:

  • Multiplataforma
  • Integrado con node.js
  • Con un diseño modular, se pueden instalar más de 50 plugins
  • Bueno, tenemos un montón de cosas que son esperables de un editor, Snippets, File system browser, Code folding... 


Simplemente se baja y se instala y en pocos minutos se van a sentir como en casa.

Dejo link: https://atom.io/


lunes, 11 de mayo de 2015

Una nueva edición del ranking de lenguajes TIOBE

Se publico una nueva versión del ranking TIOBE, en este ranking se publican los lenguajes más utilizados y Java volvió a tomar la punta. Pero lo sigue bastante cerca C. Para ver más detalle:



Dejo link: