Syndication : Atom 1.0  RSS 2.0
Blogs des développeurs   »   Le blog de SpiceGuid

Catégories: Programmation fonctionnelle, Objective Caml

02/06/2010

Permalink 16:59:13, Catégories: Récapitulatif, Programmation fonctionnelle, 33 mots   French (FR) , SpiceGuid

Types Abstraits généralisés

Si vous ne l'avez pas déjà fait dépêchez-vous de visionner ou de télécharger
la vidéo conférence de Heinrich Apfelmus sur les GADTs (Generalized Algebraic Data Types).

Vous devez être identifié pour poster un commentaire.

Permalink 14:53:42, Catégories: Récapitulatif, Programmation fonctionnelle, Objective Caml, 533 mots   French (FR) , SpiceGuid

Méditation sur une calculatrice

Un exercice simple pour débutant en ocaml c'est d'écrire un interpréteur pour un petit langage simple comme par exemple une calculatrice :

type arithmetic =
   | Cst of int
   | Neg of arithmetic
   | Add of binary
   | Sub of binary
   | Mul of binary
   | Div of binary
and binary =
   arithmetic * arithmetic

Mais cet exercice anodin change complètement de nature quand on passe à un langage fortement normalisant, dans ce cas vous devez aussi prouver que le programme se termine toujours et sans accident, quelles que soient les circonstances.

» Lire la suite!

Vous devez être identifié pour poster un commentaire.

10/04/2010

Permalink 15:45:20, Catégories: Récapitulatif, Programmation fonctionnelle, Divers, 120 mots   French (FR) , SpiceGuid

Plus de logos pour Rox-Filer

Dans un précédent billet je vous expliquais comment créer un MIME pour les sources dans votre langage de programmation favori.

Un MIME (Multipurpose Internet Mail Extension) est une information système pour identifier les types de fichier et leur affecter certains attributs comme une commande par défaut ou une icône personnalisée.

Dans ce billet je vais encore plus loin en vous proposant directement un panel d'icônes taillées sur mesure pour le gestionnaire de fichiers ROX-Filer.

Bien sûr si vous semblez frappé d'injustice du fait que votre langage de programmation favori ne soit pas représenté, vous pouvez me faire une proposition que j'ajouterai pour élargir la gamme de fichiers sources personnalisables.

Vous devez être identifié pour poster un commentaire.

05/04/2010

Permalink 20:01:41, Catégories: Récapitulatif, Programmation fonctionnelle, Logiciel Libre, 149 mots   French (FR) , SpiceGuid

Raincat, le chaton craintif

Ce n'est pas la première fois que je vous parle de jeu-vidéo et de programmation fonctionnelle.
Cette fois il s'agit de Raincat, un jeu SDL écrit en Haskell, pour Windows et Linux.

Le jeu consiste à déposer les accessoires (dans la colonne à droite) sur le parcours du chaton afin que celui-ci atteigne la sortie du niveau malgré la pluie et diverses projections d'eau. Car le Raincat est réellement hydrophobe, la moindre goutte sur son pelage délicat et vous devrez recommencer le niveau.

À vrai dire ce petit puzzle ne m'a pas rendu accro. Maintenir un chaton propre et toujours au sec m'apparaît difficilement comme un enjeu ludique motivant.

Ce qui est peut être plus intéressant que le jeu en lui-même c'est le témoignage que le fossé qui séparaient les langages académiques des applications quotidiennes se comble de jours en jours.

Vous devez être identifié pour poster un commentaire.

12/03/2010

Permalink 05:23:33 pm, Categories: Récapitulatif, Programmation fonctionnelle, Objective Caml, 248 words   English (US) , SpiceGuid

OCaml Meeting 2010 à Paris le 16 Avril

Sylvain Le Gall et l'équipe organisatrice de la 3ième rencontre des programmeurs Objective-Caml vous donnent rendez-vous le 16 Avril à Paris.

Malheureusement je ne pourrai pas être présent cette année.

» Read more!

Vous devez être identifié pour poster un commentaire.

18/02/2010

Permalink 17:54:03, Catégories: Récapitulatif, Programmation fonctionnelle, Objective Caml, 1345 mots   French (FR) , SpiceGuid

Les files de priorité (les bases)

Le tas binaire est un tableau qui implémente un arbre pseudo-complet vérifiant la propriété de tas.
Un tableau est de taille fixe. Par conséquent un tas binaire est borné, on ne peut y insérer qu'un nombre fixe et limité d'éléments. Bien sûr on pourrait redimensionner le tableau dynamiquement, mais cela a un impact négatif sur le coût des opérations.
Qu'on prêche le style impératif ou le style fonctionnel est étrangé à l'affaire.
La bonne question c'est de savoir si on connait d'avance le nombre d'éléments à insérer ou non.

Si on le connait alors un tas binaire fera très bien l'affaire.
Si on ne le connait pas, alors autant opter tout de suite pour un arbre binaire, même si on veut garder un style impératif.
Ça serait exactement la même problématique avec un dictionnaire. On peut faire une recherche dichotomique dans un tableau trié. Ou alors on peut faire une recherche dans un arbre ordonnée.
Dans les deux cas l'algorithme de recherche est le même, il s'agit dune boucle qui à chaque étape découpe l'espace de recherche en deux moitiés dont une seule peut contenir l'élément recherché.
Le paradigme a bien un impact sur le programmeur mais c'est parce que le programmeur est trop attaché à la syntaxe.
En réalité le paradigme impacte plus fortement la façon de faire que la façon de penser.
L'expérience aussi est un facteur qui impacte la façon de faire.
C'est pourquoi je préfère parler de style plutôt que de paradigme.

» Lire la suite!

Vous devez être identifié pour poster un commentaire.

12/02/2010

Permalink 16:34:05, Catégories: Récapitulatif, Programmation fonctionnelle, 576 mots   French (FR) , SpiceGuid

Qu'est-ce qu'un langage fonctionnel ?



Définition




C'est comme pour un langage à objets, étant un paradigme riche il y a plusieurs définitions possibles pour un langage fonctionnel.


Une définition possible: c'est un langage qui offre les fermetures (une fonction liée à un environnement d'évaluation).
Avantage de cette définition: elle est tolérante.

Inconvénient de cette définition: elle perd de sa pertinence au fur et à mesure que la plupart des langages à objets intègrent plus ou moins cette fonctionnalité.


Une autre définition possible: c'est un langage avec un sytème de typage riche, riche au point qu'il devienne insupportable de ne pas être assisté par une forme d'inférence de type.
Avantage: c'est plus représentatif de la spécificité des langages fonctionnels modernes.

Inconvénient: ça exclut les assembleurs de langages (macro-langages) que sont les vénérables Lisp et Scheme.

» Lire la suite!

Vous devez être identifié pour poster un commentaire.

30/01/2010

Permalink 16:56:10, Catégories: Récapitulatif Linux, Récapitulatif, Linux, Objective Caml, 360 mots   French (FR) , SpiceGuid

[Linux] Personnalisez vos fichiers source

Un MIME (Multipurpose Internet Mail Extension) est une information système pour identifier les types de fichier et leur affecter certains attributs comme une commande par défaut ou une icône personnalisée.

Ce billet vous propose d'agrémenter votre station de développement Objective-Caml à l'aide d'un MIME pour vos fichiers source.
Bien sûr ça n'est qu'un exemple que vous pourrez adapter à votre application ou à votre langage de programmation favori.

» Lire la suite!

Vous devez être identifié pour poster un commentaire.

12/01/2010

Permalink 20:28:44, Catégories: Récapitulatif, Programmation fonctionnelle, Objective Caml, 587 mots   French (FR) , SpiceGuid

Qualification à l'intérieur des modules

Le billet d'aujourd'hui a pour but de faire toute la lumière sur la qualification à l'intérieur des modules Objective-Caml.

» Lire la suite!

Vous devez être identifié pour poster un commentaire.

10/11/2009

Permalink 22:09:00, Catégories: Récapitulatif .NET, Récapitulatif, Programmation fonctionnelle, 78 mots   French (FR) , SpiceGuid

[.NET] Conférence F# à l'EPITA

Gconfs, l'association de conférences de l'école EPITA organise une conférence F#, ce Jeudi 12 novembre 2009 à 21 h, cours pasteur 14,16 rue Voltaire au Kremlin-Bicêtre.

Les conférenciers sont Laurent Le Brun et un auteur d'ouvrage sur F# dont le nom n'a pas été communiqué.

Pour plus d'informations sur cet évènement consultez la page évènements de GConfs ou le forum forum news épita.

mise à jour: l'autre conférencier est Robert Pickering, auteur de Foundations of F#.

Vous devez être identifié pour poster un commentaire.

12/10/2009

Permalink 19:28:27, Catégories: Récapitulatif, Programmation fonctionnelle, Objective Caml, 546 mots   French (FR) , SpiceGuid

Déclarations et motifs

Motifs variable

Comme vous le savez sans doute le let ne permet pas seulement de déclarer une nouvelle variable par exemple ici la variable m :

  let choose = function
    | None -> None
    | Some n -> let m = minimum n n.left in Some (m.key,m.item)

Motifs simples

Il permet aussi de déconstruire une valeur selon un motif comme ici la paire (m,l) :

  let rec delete_min t = 
    match t.left with
    | None   -> t,t.right
    | Some n -> let m,l = delete_min n in m,Some {t with left = l}

» Lire la suite!

Vous devez être identifié pour poster un commentaire.

08/10/2009

Permalink 16:29:57, Catégories: Récapitulatif, Programmation fonctionnelle, Objective Caml, 1132 mots   French (FR) , SpiceGuid

The art of the Propagator

À la lecture de The Art of the Propagator je me suis laissé convaincre que l'avenir de la programmation déclarative était dans la propagation logique. L'intérêt de la propagation c'est que le calcul monodirectionnel disparaît, le calcul devient multi-directionnel, la béta-réduction devient la béta-équivalence.

Jusqu'à présent je m'étais toujours dit "et alors, quel intérêt ?".
C'est là que The Art of the Propagator apporte un argument de poids :

  • le calcul monodirectionnel suppose un temps fondamentalement linéaire, il y a un avant et un après la réduction
  • le parallélisme c'est quand le temps n'est plus linéaire
  • pourquoi chercher à recréer l'illusion du temps linéaire alors qu'il suffit de lever la restriction monodirectionnelle pour adopter le point de vue du parallélisme ?

» Lire la suite!

Vous devez être identifié pour poster un commentaire.

« Page Précédente 1 2 3 Page suivante »

Liste des blogs

Le blog de SpiceGuid

Objective-Caml et la programmation fonctionnelle :

Coq et les types dépendants :

Rechercher

<  Avril 2012  >
Lun Mar Mer Jeu Ven Sam Dim
            1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30

Syndiquez ce blog XML

Articles :

Commentaires :

 
 
 
 
Partenaires

Hébergement Web