Translate

jueves, 24 de abril de 2014

Netbeans 8, con soporte para Java 8 y Html 5


Para que decir más Netbeans parece una IDE venida del futuro, antes que ningún otra IDE tiene las novedades, en su versión 8. Trae soporte para Java 8 y para HTML 5.

Lo podemos descargar en diferentes versiones, les dejo el cuadro:

NetBeans IDE Download Bundles
Supported technologies*Java SEJava EEC/C++HTML5 & PHPAll
NetBeans Platform SDK
Java SE
Java FX
Java EE
Java ME
HTML5
Java Card™ 3 Connected
C/C++
Groovy
PHP
Bundled servers
GlassFish Server Open Source Edition 4.0
Apache Tomcat 8.0.3
Free, 89 MBFree, 191 MBFree, 62 MBFree, 63 MBFree, 203 MB

Dejo link:
https://netbeans.org
http://www.infoq.com/news/2014/04/netbeans8

Functional Programming Principles in Scala

Otra vez coursera lanza el curso "Functional Programming Principles in Scala" para el que no lo hizo, lo recomiendo, muy bueno!!




Dejo link:
https://www.coursera.org/course/progfun

miércoles, 23 de abril de 2014

Desarrolla en Android con Scala con Scaloid

Al parecer se puede programar en Android con Scala gracias a Scaloid.

Scaloid es una biblioteca que simplifica el código de Android. Esto hace que el código sea fácil de entender y mantener gracias al lenguaje Scala.

Veamos un ejemplo en Java:

val button = new Button(context)
button.setText("Greet")
button.setOnClickListener(new OnClickListener() {
  def onClick(v: View) {
    Toast.makeText(context, "Hello!", Toast.LENGTH_SHORT).show()
  }
})
layout.addView(button);

Y ahora en Scala con Scaloid:

SButton("Greet", toast("Hello!"))

Y eso es todo!

Parece de cuento la verdad, lo voy a tener que probar...

Dejo el link:
https://github.com/pocorall/scaloid
http://blog.scaloid.org/2014/04/scaloid-33-is-released.html

martes, 22 de abril de 2014

Flask es un microframework para Python basado en Werkzeug, Jinja 2 y las buenas intenciones.


Flask es un microframework para Python basado en Werkzeug, Jinja 2 y las buenas intenciones. Jeje, que buena presentación!

Se acuerdan que les hable de Sinatra, un microframework para Ruby que inspiro a otros microframework, quiero presentarles un hijo de Sinatra ya bastante maduro para Python, Flask.

La idea es hacer paginas web en tiempo récord, veamos un ejemplo:

from flask import Flask
app = Flask(__name__)

@app.route("/")
def hello():
    return "Hola Mundo!"

if __name__ == "__main__":
    app.run()

Lo ejecutamos de la siguiente manera:

$ python hello.py
 * Running on http://127.0.0.1:5000/

Y ya tenemos un "Hola Mundo"!!!

Rápido y fácil de utilizar, de esta manera podemos describir a Flask. Y además se encuentra bajo licencia BSD!

Dejo el link:
http://flask.pocoo.org/
http://flask.pocoo.org/docs/

domingo, 20 de abril de 2014

Hoja de trucos de Clojure


Siempre es bueno tener un machete, no hablo del cuchillo, sino de las anotaciones que hacemos para los exámenes para ayudar a nuestra memoria.  Les dejo un ayuda memoria de Clojure. Muy útil!!

Dejo link:

viernes, 18 de abril de 2014

Característica ocultas de Android Kitkat


R, un lenguaje y entorno de programación para análisis estadístico


Como les conté en el post anterior estoy haciendo un curso de R en Coursera. Por eso me atrevo a realizar un post de R.

R es un lenguaje y entorno de programación para análisis estadístico y gráfico. Su historia es larga pero para hacer un resumen, podríamos decir que es un dialecto libre del lenguaje S, desarrollado por Robert Gentleman y Ross Ihaka del Departamento de Estadística de la Universidad de Auckland en 1993.

En qué me puede ayudar R?

  • R al estar orientado a las estadísticas, proporciona un amplio abanico de herramientas.
  • Entre otras características de R, podemos nombrar su capacidad gráfica, que permite generar gráficos con alta calidad, con sólo utilizar las funciones de graficación.
  • R también puede usarse como herramienta de cálculo numérico y a la vez ser útil para la minería de datos.

Como dije anteriormente R es un poderoso entorno y lenguaje en el cual podemos tratar datos y gráficar. Pero no quiero detenerme en el entorno sino que quiero revisar el lenguaje.

Al igual que S, se trata de un lenguaje de programación, lo que permite que permite extender sus propias funciones. La gran mayoría de las funciones de R fueron escritas en R pero por cuestiones de rendimiento existen funciones escritas en lenguajes de más bajo nivel como C o Fortran.

R es un lenguaje interpretado, el usuario normalmente accede por líneas de comandos o consola. Veamos unos ejemplos:

Si queremos hacer un Hola mundo podemos hacerlo de la siguiente manera:

> print("Hola Mundo")

[1] "Hola Mundo"

Sumemos 2 números:

> 2 + 3

[1] 5

Pero que hace tan potente a R? Momento, que recién empezamos! Veamos a R haciendo lo que mejor sabe hacer, analizar datos.

Vamos a crear una colección:

x <- c(1,2,3,4,5,6)

Vamos a calcular el cuadrado de cada elemento:

> y <- x^2

> y

[1] 1 4 9 16 25 36

Ahora vamos a calcular la media, la varianza y vamos a gráficar!

> mean(y)

[1] 15.16667

> var(y)

[1] 178.9667

> plot (y)




Como podemos ver R es un lenguaje y entorno muy poderoso, orientado al estudio de datos estadísticos.

Además, R puede integrarse con distintas bases de datos y existen bibliotecas que facilitan su utilización desde lenguajes de programación interpretados como Perl, Python y Ruby. Y por supuesto existen proyectos que permiten utilizar R desde Java o .net.

Y por si fuera poco cuenta con un poderoso entorno de desarrollo llamado R studio que se puede descargar de forma gratuita.

Dejo links:

miércoles, 16 de abril de 2014

Instalar R en Ubuntu

Como saben R es el lenguaje de programación para análisis estadístico de datos más usado en el mundo.  Estoy haciendo el curso de coursera: R Programming pero en este no dice como instalarlo en Linux. Por eso les quiero mostrar como hace:

sudo add-apt-repository "deb http://cran.rstudio.com/bin/linux/ubuntu $(lsb_release -cs)/"
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys E084DAB9
sudo apt-get update
sudo apt-get install r-base r-base-dev

Y luego podemos instalar Rstudio, que es una IDE, para hacer esto debemos descargar la del siguiente link: http://www.rstudio.com/ide/download/desktop


Moonscript


MoonScript es un lenguaje dinámico que compila a la plataforma Lua. Con este lenguaje vas a tener el poder de un potente lenguaje script y la potencia de Lua

MoonScript puede correr dentro de Lua y a la vez puede ser dinámicamente compilado y cargar los archivos dinamicamente gracias a moonloader. Lo único que necesita es que agreguemos el siguiente import: require "moonscript".

MoonScript proporciona una sintaxis limpia, como pueden ver:

export my_func
x = 2323

collection =
  height: 32434
  hats: {"tophat", "bball", "bowler"}

my_func = (a) -> x + a

print my_func 100

Dejo link:
http://moonscript.org/
http://moonscript.org/reference/

domingo, 13 de abril de 2014

Pattern matching


Pattern Matching nace del paradigma funcional aunque hoy en día lenguaje multiparadigma lo implementan como Scala o Kotlin. Pattern Matching permite definir funciones por medio de macheo de parámetros y resultados. Veamos un ejemplo en Haskell de definición de factorial:

 factorial 0 = 1
 factorial n = n * factorial (n - 1)

Para ver la diferencia entre la forma de resolver el problema sin Pattern Matching, voy a resolver lo mismo en C++

 int factorial(int n) {
       if (n == 0) {
              return 1;
       } else {
             return n * factorial(n-1);
       }
 }

Si comparamos nos ahorramos 5 lineas; pero el tema no es solo escribir menos código. Además debemos pensar: ¿Cuál les parece más legible? ¿Cuál es más simple?

Muchos lenguajes implementan Pattern Matching, al venir del paradigma funcional normalmente los lenguajes funcionales como Erlang lo implementan; vamos a hacer la función de factorial en Erlang.

 fac(0) -> 1;
 fac(N) when N > 0, is_integer(N) -> N * fac(N-1).

Se puede ver que en este caso se indica que debe ser positivo el número; si se ingresa un valor negativo lanza un error. Ojo estas restricciones también la podíamos hacer en Haskell.

 Factorial con ML se vería de la siguiente manera:

 fun fac 0 = 1
      | fac n = n * fac (n - 1)

 Otros lenguajes multiparadigma nos permiten jugar con Patter Matching como Scala:

 def fact(n: Int): Int = n match {
     case 0 => 1
     case n => n * fact(n - 1)
   }

En este caso se define fact que devolverá un entero, y que el parámetro n debe coincidir con 0 y devuelve 1 o con cualquier otro valor y devolverá n * fact(n - 1).

 Por ejemplo Kotlin permite hacer Pattern Maching por el tipo de la siguiente manera:

 when (x) {
   is Int -> print(x)
   is List<Int> -> print(x.sum())
   !is Number -> print("No es un número")
   else -> print("No puedo hacer nada")
 }

Para citar otro ejemplo, veamos desarrollar una función que indique el número que se encuentra en una posición indicada por parámetro de la secuencia de Fibonacci, y lo desarrollaremos con F# :

 let rec fib n =
     match n with
     | 0 -> 0
     | 1 -> 1
     | 2 -> 1
     | _ -> fib (n - 1) + fib (n - 2)

 Si lo comparamos con Mathematica:
 fib[0]:=0
 fib[1|2]:=1
 fib[n_]:= fib[n-1] + fib[n-2]

En Mathematica podemos utilizar el | para decir esto o aquello y el _ para indicar cualquier otro valor.

Pattern Matching es una técnica muy simple, pero muy potente. Por ejemplo necesitamos el primer elemento de una lista podemos definirla de la siguiente manera, vamos a implementarlo en Haskell:

primero :: [a] -> a
primero [] = error "¡No puedes utilizar la función primero con una lista vacía!"
primero (x:_) = x

Con (x:_) estamos diciendo que puede llegar una lista por parámetro que está conformada por un elemento y el resto. Implementemos la función cantidadDeElementos que nos indique cuantos elementos tiene una lista:

cantidadDeElementos :: (Num b) => [a] -> b
cantidadDeElementos [] = 0
cantidadDeElementos (_:xs) = 1 + cantidadDeElementos xs

Una desventaja del uso de Pattern Matching es que nuestro código se verá muy afectado ante un cambio en las estructuras. Pero la ventajas son muchísimas, para citar algunas: legibilidad de código, simplicidad, menos lineas de código, etc...

Netrunner

Ya hable de Netrunner en el post anterior, ahora ha probarlo!!

Les dejo screenshots:












sábado, 12 de abril de 2014

Netrunner, mi próximo linux!!


No sé que voy a hacer mañana, pero sé que quiero instalar Netrunner, cuanto antes.

Por qué? Porque por lo que vi es una muy buena opción. Un entorno KDE muy elegante, y no soy fan de KDE pero en Netrunner se ve su potencia, un entorno muy cuidado.

Además que es una distro basada en Ubuntu, por lo tanto basada en Debian. Y me encanta usar Debian. Y eso no es todo, hace poco anunciaron que sera una Rolling Release. Para el que no sabe Rolling Release es que para cambiar de versión debemos esperar un periodo de tiempo, sino que se va actualizando periódicamente.

Netrunner es una distro muy buena para los amantes de KDE, Debian y Rolling Release.

La voy a probar y les cuento!!


Dejo link:
http://www.netrunner-os.com/
http://en.wikipedia.org/wiki/Netrunner_(operating_system)

lunes, 7 de abril de 2014

Oracle Massive Open Online Course: Develop Java Embedded Applications Using a Raspberry Pi May 2014


Oracle ofrecerá un curso de programación de Raspberry Pi con Java.

Yo no estaba enterado que Raspberry Pi soportaba Java. La verdad es que me saco el sombrero. Raspberry Pi pinta como una gran plataforma que va a acercar el mundo de la rebotica a muchos programadores.

Y esta rebueno que Oracle ofrezca estas capacitaciones.



Dejo el link:
https://apex.oracle.com/pls/apex/f?p=44785:145:0::::P145_EVENT_ID,P145_PREV_PAGE:1841,143

domingo, 6 de abril de 2014

Show Off. Get Proof. Convince Your Boss.


No soy asiduo de hacer publicidad a empresas pero quiero recomendarles la pagina de Typesafe.

Go Typesafe es un conjunto de recursos para ayudar a convencer a sus compañeros para utilizar la plataforma reactive de Typesafe: Play Framework, Akka y Scala.

Dejo link:
http://go.typesafe.com/

viernes, 4 de abril de 2014

Roslyn el compilador Open Source de C# y Visual Basic


Microsoft ha publicado el compilador Roslyn, bajo la licencia Apache.
Roslyn representa una importante inversión de Microsoft. Microsoft ha reescrito su compilador C# y VB. NET desde cero y lo publico con licencia Open source.

Esto es un gran salto para Microsoft dado que abrió el proceso de compilación de sus lenguajes. El lanzamiento de hoy de la tecnología . ET marca un cambio importante en el pensamiento de Microsoft. La visibilidad del codigo del compilador debería conducir a mejores beneficios para todos, independientemente de su plataforma.

Dejo link: http://msdn.microsoft.com/en-us/vstudio/roslyn.aspx

miércoles, 2 de abril de 2014

Reactive Design Patterns



Reactive Design Patterns es un libro que acaba de publicar la editorial Manning. Lo interesante es que regala el primer capitulo, y es una buena idea leerlo para ver de que se trata.

Dejo el link:
http://www.manning.com/kuhn/


Try Flux Today!


Codescholl lanzo la pagina try flux que la verdad no entiendo bien. Alguien me lo puede explicar??

Dejo link:
https://www.codeschool.com/try-flux

lunes, 24 de marzo de 2014

Mixin, Mixin y más Mixin...


El mixin es una técnica para la reutilización de código. El objetivo es que una función pueda estar en diferentes clases, aunque las clases no tengan ninguna relación.

Los mixin fueron utilizados por primera vez en Flavors que era un enfoque a la orientación a objetos utilizado en Lisp Machine Lisp. La ventaja de los mixin es que fomentan la reutilización de código y evitan problemas típicos asociados con la herencia múltiple.

¿Cómo funciona? Existen diferentes formas de implementarlo dependiendo del lenguaje.

Scala

En scala existen entidades llamadas traits. Los traits son características, similares a las interfaces de java, pero pueden contener código. Código que va a ser reutilizados por las clases que utilicen esta característica. Por supuesto una clase puede utilizar varias características.

Voy a tomar el ejemplo del libro programming in scala.  Supongamos que queremos modelar la amistad entonces vamos hace un trait llamado Friend.

trait Friend {
val name : String
def listen() = println("Your friend " + name + "is listening")
}

Como se puede ver se declaro el val name, el cual debe ser proveído por la clase que vamos a mixiar. Ahora tenemos que utilizar a Friend, si la clase que utiliza este trait no extiende de ninguna clase podemos utilizar extends, por ejemplo:

class Human(val name: String) extends Friend

Human podría reescribir los métodos de Friend, por ejemplo si extendemos a Human en Man y Woman, estos también pueden reescribir estos métodos.

Cuando una clase extiende de otra clase se debe utilizar la palabra clave with. Con with podemos utilizar varios trait. Veamos la clase Dog:

class Dog(val name:String) extends Animal with Friend {
      override def listen = println(name + "'s listening quietly")
}

En el ejemplo reescribimos el método sólo para mostrar que se puede reescribir, pero si no es necesario no se debe reescribir.

Ahora podemos utilizar el trait heredado y es más podemos tipar por ese trait como lo hacemos en java con las interfaces:

val john = new Man("John" )
val sara = new Woman("Sara" )
val comet = new Dog("Comet" )

john.listen
sara.listen
comet.listen

val mansBestFriend : Friend = comet

mansBestFriend.listen

También podemos utilizar el mixin en instancias no solo en clases por ejemplo una clase gato, el gato por naturaleza no es muy amistoso:

class Cat(val name: String) extends Animal

Pero existe un gato llamado snowy que es muy amigable, entonces podemos hacer lo siguiente:

val snowy = new Cat("Snowy" ) with Friend
val friend : Friend = snowy
friend.listen

Mixin es una técnica de reutilización de código que nos provee gran flexibilidad en Scala. Veamos como se implementa en Ruby.

Ruby

En Ruby definimos módulos y podemos importar estos módulos en nuestras clases.

module Debug
   def who_am_i?
      "#{self.class.name} (\##{self.id}): #{self.to_s}"
   end
end

class Phonograph
  include Debug
  # ...
end

class EightTrack
  include Debug
  # ...
end

ph = Phonograph.new("West End Blues")
et = EightTrack.new("Surrealistic Pillow")

ph.who_am_i? #Phonograph (#935520): West End Blues
et.who_am_i?  #EightTrack (#935500): Surrealistic Pillow

Groovy 

El caso de Groovy resuelve el mixin con anotaciones o con el método mixin, es como una fusión de Java y Ruby.
 Pero como Ruby tiene la ventaja de ser un lenguaje de tipado dinámico, lo que nos da ciertas libertades.


Usemos anotaciones:

class Dog {
  def talk() {
    "Woof, woof"
  }
}


@Mixin(Dog)
class Talk {
  // other stuff here
}

Y listo! Pero a la vez groovy permite hacer mixin con instancias no solo con clases de la siguiente manera:

someoneElsesClass.mixin(Dog)

Como es dinámicamente tipado, no hay problema si hacemos:

someoneElsesClass.talk()

En Scala si queríamos hacer esto usábamos with en el constructor tipando de esta manera al objeto:

val snowy = new Cat("Snowy" ) with Friend
val friend : Friend = snowy
friend.listen

El método mixin de Groovy tiene la ventaja que se puede utilizar en cualquier momento, no como la palabra reservada de Scala with que sólo se puede utilizar en el constructor.

Dart

Dart implementa el mixin muy similar a scala, es decir tiene trait que pueden ser agregados a las instancias o a las clases. Pero además tiene interfaces, veamos un ejemplo:

interface Shape {
   num perimeter();
}

trait Rectangle implements Shape {
   final num height, width;

   Rectangle(num this.height, num this.width); // Compact constructor syntax.

   num perimeter() => 2*height + 2*width; // Short function syntax.
}

class Square extends Rectangle {
   Square(num size) : super(size, size);
}

Dart usa las interfaces como Java, pero tiene trait como Scala y estas características se pueden combinar.

Ceylon

En Ceylon existen las interfaces que al igual que Scala pueden contener código; es decir una interfase de Ceylon es similar a un trait de Scala:

shared interface Writer {
    shared formal Formatter formatter;
   
    shared formal void write(String string);
   
    shared void writeLine(String string) {
        write(string);
        write(process.newLine);
    }
   
    shared void writeFormattedLine(String formatString, Object... args) {
        writeLine( formatter.format(formatString, args) );
    }
   
}

shared class ConsoleWriter()
        satisfies Writer {
   
    formatter = StringFormatter();
   
    shared actual void write(String string) {
        writeLine(string);
    }
   
}

Hay una diferencia sutil pero importante entre los traits de Scala y las interfaces en Ceylon: en Ceylon no puedes guardar estado en las interfaces; es decir, no puedes tener atributos concretos (ni mutables ni inmutables). Solamente puedes definir atributos como "formal", para que los implemente la clase que satisfaga dicha interfaz. La única manera de tener atributos concretos en una interfaz es definirlos con getter y opcionalmente con setter, pero atributos simples no lo permite.

Como podemos ver en todos los lenguajes la idea la similar, cambia un poco la forma de implementarla.

Mixin es una característica de los lenguajes modernos, que nos brinda una forma práctica de reutilización de código.

Que implementación les gusto más?

domingo, 23 de marzo de 2014

Correr scripts sql con Hibernate

Esto no es una gran novedad pero bueno; Hibernate permite configurar un script que se ejecute cuando crea las tablas por lo tanto, deben imaginar que Hibernate debe estar configurado en hibernate.hbm2ddl.auto en create o create-drop.

Simplemente en el persistence.xml debes configurar el parámetro hibernate.hbm2ddl.import_files con los archivos sql que vas a correr separados por comas, como por ejemplo /1.sql, /2.sql, /etc.sql

     
     com.ejemplo.model.Clase1
     com.ejemplo.model.Clase2
     com.ejemplo.model.Clase3
     com.ejemplo.model.Clase4
              
   
   
  
    



Y listo, cuando Hibernate arranque va a crear las tablas y luego va a correr estos scripts. Si queres que logee tenes que agregar a la configuración de log4j los siguiente:

log4j.logger.org.hibernate.tool.hbm2ddl=DEBUG

Espero que les sirva.

Influencia de los lenguajes de programación

Una infografía de los lenguajes y sus influencias, la idea de la infografía no es saber que lenguaje influyo a otro, simplemente porque no se ve pero nos sirve para saber que lenguajes son los más influyentes, a simple vista se puede ver:

Lisp, scheme, Logo, Forth, Dylan, Smalltalk, Ruby, Python, Lua, Java, Object-C, ML, Pascal, Haskell, etc

Y que lenguaje sabes? y cual vas a aprender?