đš 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 :
đ 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 đ»âĄ