Blog
  • Login

  • Connexion
  • Inscription
  • Blog

  • Articles
  • en
  • de

🎹 Programmation rĂ©cursive de tuyaux

le 29 septembre 2025

Dans la programmation, on commence souvent par écrire des boucles impératives. Simples, efficaces
 mais vite limitées. Prenons un exemple concret : une boucle for qui affiche les valeurs de i de 1 à 3.

for ($i = 1; $i <= 3; $i++) {
    echo $i . PHP_EOL;
}

🔁 La reprĂ©sentation en graphe 2D

On peut représenter ce for sous forme de graphe :

  • Initialisation i = 1
  • Test de condition i <= 3 ?
  • ExĂ©cution du corps de la boucle (print i)
  • IncrĂ©ment i = i + 1
  • Retour Ă  la condition tant qu’elle est vraie
  • Sortie quand la condition devient fausse

Visuellement, cela donne un cycle avec plusieurs nƓuds et flĂšches. Ce type de graphe fonctionne, mais il a un problĂšme majeur : plus le programme grossit, plus le graphe devient illisible. On se retrouve avec des dizaines de nƓuds, des flĂšches dans tous les sens
 et la lecture devient un vrai casse-tĂȘte.

📏 La version linĂ©aire : un pipe fonctionnel

Au lieu de raisonner en graphe 2D, on peut rĂ©duire la boucle Ă  une transformation linĂ©aire. On passe d’un Ă©tat initial (i = 1), on applique une fonction qui gĂšre la rĂ©cursion, et on arrive Ă  la sortie (Exit). Tout est alignĂ© verticalement comme un pipeline de donnĂ©es.

Schématiquement :

i = 1
   ↓
   Y (récursion)
   ↓
 Exit

Ici, le Y Combinator joue le rĂŽle clĂ© : il permet d’exprimer la rĂ©cursion dans un langage fonctionnel sans avoir besoin de nommer explicitement la fonction. La rĂ©cursion devient un nƓud unique dans le pipe, au lieu d’un enchevĂȘtrement de flĂšches dans un graphe.

đŸ§© Exemple en PHP avec Y Combinator

// Définition du Y Combinator
$Y = fn($F) =>
  (function ($x) use ($F) {
      return $F(function (...$args) use ($x, $F) { return $x($x)(...$args); });
  })(fn($x) => $F(function (...$args) use ($x, $F) { return $x($x)(...$args); }));

// Boucle for transformée en pipe récursif
$step = function ($state) {
    ['i'=>$i,'max'=>$max] = $state;
    if ($i > $max) return [$state, true];
    echo $i . PHP_EOL;
    return [['i'=>$i+1,'max'=>$max], false];
};

$recurse = $Y(function ($self) {
    return function ($state, $step) use ($self) {
        [$next, $done] = $step($state);
        return $done ? $next : $self($next, $step);
    };
});

$init = ['i'=>1,'max'=>3];
$recurse($init, $step);

Sortie :

1
2
3

🎯 Pourquoi c’est intĂ©ressant ?

  • LisibilitĂ© : un pipe linĂ©aire est beaucoup plus simple Ă  comprendre qu’un graphe 2D.
  • ModularitĂ© : chaque Ă©tape est une fonction pure qui peut ĂȘtre testĂ©e et rĂ©utilisĂ©e.
  • Puissance : le Y Combinator permet d’exprimer la rĂ©cursion sans dĂ©pendre de l’impĂ©ratif.
  • ÉlĂ©gance : la structure est claire, de haut en bas, comme un flux de donnĂ©es.

🔼 Conclusion

Les graphes de nƓuds sont utiles pour des cas rapides, mais ils deviennent vite des code spaghetti visuels. En adoptant une approche fonctionnelle avec des pipes et des combinators, on gagne en lisibilitĂ©, en rĂ©utilisabilitĂ© et en puissance expressive.

👉 Ne dessinez plus vos boucles comme des graphes 2D. Exprimez-les comme des pipes fonctionnels. C’est plus concis, plus clair, et ça ouvre la porte à des abstractions bien plus riches.

✹ Si tu veux aller plus loin :

  • Documentation Flow

🎁 Je propose des sĂ©ances de coaching gratuites de 30 minutes pour aider les crĂ©ateurs comme vous Ă  automatiser leurs processus et Ă  gagner du temps ⏱

👉 RĂ©servez votre sĂ©ance gratuite ici : https://www.bonzai.pro/matyo91/lp/4471/je-taide-a-automatiser-tes-process

Merci de votre lecture ! CrĂ©ons ensemble des workflows intelligents, rapides et automatisĂ©sÂ đŸ’»âšĄ

  • Plan du Site - Hello - Blog - Apps - Photos - Contact - - - - - Mentions lĂ©gales - Darkwood 2025, tous droits rĂ©servĂ©s