Skip to content

Latest commit

 

History

History
132 lines (86 loc) · 3.32 KB

README.md

File metadata and controls

132 lines (86 loc) · 3.32 KB

00 - Paradigmas de la Programación

Temas Vistos

  • ¿Qué es un paradigma de programación?
  • Declaratividad
  • Expresividad
  • Abstracción
  • Efecto colateral o de lado
  • Paradigma Funcional

Paradigma Funcional

Durante este paradigma se trabajara con el lenguaje Haskell.

La guia de ejercicios con la que se guiara la catedra sera la presente en Mumumki

Conceptos basicos

Este paradigma esta fuertemente orientado a describir construcciones en lugar de tratar de explicar los pasos a seguir para obtener un resultado. Podemos pensarlo como una calculadora: consiste en modelar la misma, que en particular es extensible; uno puede programar sus propios "botones".

Funcion: es una relacion entre elementos de dos conjuntos y que cumple con existencia y unicidad. El hecho de que una funcion es una relacion implica que no es una secuencia de pasos, solo vincula el dominio con la imagen, entre los efectos de esto se encuentra la imposibilidad de pisar el valor de los parametros. Una funcion solo servira entonces par dar un resultado; por ello es necesario conocer el dominio y su imagen.

Simetria de la igualdad: al igual que en matematicas, colocar un igual entre dos expresiones siginifica que la primera expresion es equivalente, lo mismo que la consiguiente al simbolo igual. Por lo tanto entenderemos que se podra "reemplazar" por ese valor.

Pattern Matching: dada una cadena de tokens chequearle en busqueda de un patron, de manera de definir ciertos behaviours para determinados inputs

Comenzando con Haskel

Setup

Utilizaremos Glasgow Haskell Compiler, sin stack y a travez de una interfaz interactiva.

sudo apt-get install haskell-platform

Abrimos GHCi

ghci

Luego compilaremos nuestro archivo .hs

> :l myfile.hs

Primer Ejemplo

nombreCompleto nombre apellido = apellido ++ ", " ++ nombre

Esto nos dice que las expresiones son equivalentes.

Por consola obtendriamos

> nombreCompleto "Tito" "Puente"
"Puente, Tito"

Aplicacion

Las funciones por default se aplicaran

De manera infija para funciones nombradas con simbolos operarios

 > 2 * 3
 6

Y de manera prefija para funciones con un determinado nombre

> multiplicar 2 3
6

Sin embargo podemos "castear" su aplicacion de manera que

> (*) 2 3
6
> 2 `multiplicar` 3
6

Pattern Matching en Haskell

Esta tecnica permite definir un behaviour para un valor (patron) especifico.

Consiste en especificar patrones, chequear si el parametro recibido cumple, y en el caso que si se realiza esa funcion especifica, sino sigue buscando; si no hay un comportamiento "default" al llamarla dara error.

Supongamos la funcion nroSuerte

nroSuerte 7 = "7 Es el numero de la suerte."
nroSuerte n = "No es tu dia de suerte."

Donde, en la consola interactiva obtendriamos:

> nroSuerte 7
"7 Es el numero de la suerte."

> nroSuerte 1243
"No es tu dia de suerte."

Tengamos presente la funcion factorial definida como

n! = 1 x ... x (n-1) x n

En Haskell

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

Al igual que en la definicion formal, para n = 0 hay un valor predefinido. A esto se llama pattern matching.