lilypond-user-fr
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Problème de compilation


From: Nicolas Sceaux
Subject: Re: Problème de compilation
Date: Mon, 8 Sep 2008 21:24:35 +0200

Le 8 sept. 08 à 15:59, Philippe Hezaine a écrit :

Bonjour à tous,

Voulant regrouper dans un fascicule un bon nombre de partitions, je me lance dans le "book-titling.ily" que Nicolas Sceaux a posté il y a quelques temps sur la liste. Après avoir personnalisé certains paramètres et effectué plusieurs tests plus ou moins volumineux (jusqu'à 20 pages), tout me semble alors parfait. Donc je compile le projet actuel que Lilypond évalue à une soixantaine de pages... et la compilation s'embourbe en un marathon interminable (jusqu'à 2h sans résultats).
Je suis sur Gentoo en version 2.11.56. avec 512 Mo de mémoire vive.
Ayant lancé un "top" pendant la compilation, j'ai crois alors qu'il s'agit d'un problème avec la mémoire: en fait, au bout d'un certain temps Lilypond semble passer une partie de la mémoire en swap et c'est à partir de ce moment là que les choses s'éternisent. Ayant l'occasion de pouvoir compiler le même fichier sur une Gentoo 64 bits avec 1Go de mémoire, le problème persiste encore. Plus qu'intrigué par un problème que je n'ai jamais connu avec Lilypond, je lui fais alors compiler, comme je l'ai souvent fait pour des mises à jour, un répertoire entier de fichiers ly avec la commande:
  lilypond *.ly
Et là le problème est le même. Si le répertoire est assez chargé, Lily démarre sur les chapeaux de roues, puis continue son bonhomme de chemin
jusqu'à une certaine limite où le problème précédent ressurgit.
Je suis totalement incapable de dire de quoi il s'agit.
Le code Scheme ne me semble pas en cause. Il compile déjà au moins vingt pages sans problèmes.
Alors? Une erreur de ma part? La mémoire? La compilation Gentoo? ...?


512 Mo, même 1 Go c'est un peu jeune pour des gros projets. Quand je compile des gros bouquins, LilyPond peut prendre à lui seul ~1Go. Donc la ram est certainement un problème dans ton cas. Mais il arrive que même avec beaucoup de ram, une compilation ne finisse pas : à partir d'un certain volume de pièces, la compilation peut s'embourber au niveau du calcul de sauts de lignes et de
pages.

Comme je rencontre également ce problème, j'ai écrit un algo moins complexe (et qui traite mieux les passages textuels). Son avantage est que la compilation finit très rapidement. Son désavantage est que le résultat n'est pas des plus
gracieux. Autre possibilité, essayer avec l'ancien algo.

%% Utilisation de l'algo "minimal-breaking", qui est idiot mais fait son travail
\paper { #(define page-breaking ly:minimal-breaking) }

%% Utilisation de l'ancien algo : plus long, mêmes sauts de lignes, mais meilleurs
%% sauts de pages, par contre pas de stretch vertical
\paper { #(define page-breaking optimal-page-breaks) }

Donc à l'heure actuelle, tu as le choix entre ces deux possibilités pour tenter de résoudre logiciellement ton problème. Il faut essayer pour voir ce qui convient
le mieux.

De façon à pouvoir utiliser l'algo qui donne le meilleur résultat ET qui finit, j'ai implémenté dans LilyPond un moyen de découper le bouquin en parties, et ainsi l'algo est appliqué sur un sous-ensemble, plus petit, et donc la compilation finit. Cette nouvelle fonctionnalité marche nickel chez moi, mais je ne l'ai pas encore "poussé" dans la référence git. J'ai pu compiler des gros bouquins, avec
le bel algo. Ca marche de la façon suivante :

\bookpart {
  %% ... pièces de l'acte 1
}
%% ici ça met nécessairement un saut de page
\bookpart {
  %% ... pièces de l'acte 2
}

Quand j'aurai un peu de temps, je réenverrai un patch à faire relire par une bonne âme, et si c'est accepté, ce sera un jour dans une version officielle de
LilyPond.

Nicolas





reply via email to

[Prev in Thread] Current Thread [Next in Thread]