<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.apertium.org/w/index.php?action=history&amp;feed=atom&amp;title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin</id>
	<title>Création d&#039;une nouvelle paire avec Matxin - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.apertium.org/w/index.php?action=history&amp;feed=atom&amp;title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin"/>
	<link rel="alternate" type="text/html" href="https://wiki.apertium.org/w/index.php?title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin&amp;action=history"/>
	<updated>2026-05-06T21:11:19Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.34.1</generator>
	<entry>
		<id>https://wiki.apertium.org/w/index.php?title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin&amp;diff=50562&amp;oldid=prev</id>
		<title>Bech: Lien page anglaise</title>
		<link rel="alternate" type="text/html" href="https://wiki.apertium.org/w/index.php?title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin&amp;diff=50562&amp;oldid=prev"/>
		<updated>2014-10-08T07:18:54Z</updated>

		<summary type="html">&lt;p&gt;Lien page anglaise&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #222; text-align: center;&quot;&gt;Revision as of 07:18, 8 October 2014&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-empty diff-side-deleted&quot;&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-addedline diff-side-added&quot;&gt;&lt;div&gt;[[Matxin New Language Pair HOWTO|In English]]&lt;/div&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
  &lt;td colspan=&quot;2&quot; class=&quot;diff-empty diff-side-deleted&quot;&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-addedline diff-side-added&quot;&gt;&lt;br /&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
  &lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-context diff-side-deleted&quot;&gt;&lt;div&gt;Cette page prétend donner un cheminement pas à pas sur la manière de créer un nouveau traducteur avec la plate-forme [[Matxin (français)|Matxin]]. &lt;/div&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-context diff-side-added&quot;&gt;&lt;div&gt;Cette page prétend donner un cheminement pas à pas sur la manière de créer un nouveau traducteur avec la plate-forme [[Matxin (français)|Matxin]]. &lt;/div&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
  &lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-context diff-side-deleted&quot;&gt;&lt;br /&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;
  &lt;td class=&quot;diff-context diff-side-added&quot;&gt;&lt;br /&gt;&lt;/td&gt;
&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Bech</name></author>
		
	</entry>
	<entry>
		<id>https://wiki.apertium.org/w/index.php?title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin&amp;diff=37068&amp;oldid=prev</id>
		<title>Bech: Fin de la tradiction</title>
		<link rel="alternate" type="text/html" href="https://wiki.apertium.org/w/index.php?title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin&amp;diff=37068&amp;oldid=prev"/>
		<updated>2012-11-11T00:09:22Z</updated>

		<summary type="html">&lt;p&gt;Fin de la tradiction&lt;/p&gt;
&lt;a href=&quot;//wiki.apertium.org/w/index.php?title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin&amp;amp;diff=37068&amp;amp;oldid=36355&quot;&gt;Show changes&lt;/a&gt;</summary>
		<author><name>Bech</name></author>
		
	</entry>
	<entry>
		<id>https://wiki.apertium.org/w/index.php?title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin&amp;diff=36355&amp;oldid=prev</id>
		<title>Bech: Création page (début de traduction)</title>
		<link rel="alternate" type="text/html" href="https://wiki.apertium.org/w/index.php?title=Cr%C3%A9ation_d%27une_nouvelle_paire_avec_Matxin&amp;diff=36355&amp;oldid=prev"/>
		<updated>2012-09-01T20:21:04Z</updated>

		<summary type="html">&lt;p&gt;Création page (début de traduction)&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Cette page prétend donner un cheminement pas à pas sur la manière de créer un nouveau traducteur avec la plate-forme [[Matxin]]. &lt;br /&gt;
&lt;br /&gt;
== Pré requis ==&lt;br /&gt;
&lt;br /&gt;
Article principal : [[Matxin (français)]]&lt;br /&gt;
&lt;br /&gt;
Cette page ne donne pas des instructions sur l&amp;#039;installation de [[Matxin (français)|Matxin]], mais présume que les paquets suivants sont correctement installés.&lt;br /&gt;
&lt;br /&gt;
* [[lttoolbox (français)|Lttoolbox]] (depuis SVN) &lt;br /&gt;
* [[Matxin (français)|Matxin]] (depuis SVN)&lt;br /&gt;
* un éditeur de texte&lt;br /&gt;
&lt;br /&gt;
et au choix :&lt;br /&gt;
* [[Freeling]] (depuis SVN) et les outils &amp;lt;code&amp;gt;fl-*&amp;lt;/code&amp;gt; pour Freeling (pour le moment ceux-ci peuvent être trouvés dans &amp;lt;code&amp;gt;apertium-tools/freeling&amp;lt;/code&amp;gt; dans [[SVN|apertium SVN (lien non direct)]]), si vous prévoyez d&amp;#039;utiliser FreeLing pour les étapes d&amp;#039;analyse/tagging/dépendance&lt;br /&gt;
ou&lt;br /&gt;
* [[vislcg3]] (depuis SVN), si vous prévoyez d&amp;#039;utiliser lttoolbox/apertium-tagger et [[Contraintes grammaticales|Constraint Grammar]] pour les étapes d&amp;#039;analyse/tagging/dépendance&lt;br /&gt;
&lt;br /&gt;
== Aperçu ==&lt;br /&gt;
&lt;br /&gt;
Comme mentionné au début, cette page prétend donner un guide pas à pas pour créer une nouvelle paire de langues avec [[Matxin]] depuis le début. Aucune connaissance en programmation n&amp;#039;est requise, tout ce qu&amp;#039;on a besoin de définir est quelques dictionnaires et grammaires. La plate-forme Matxin est décrite en détail dans [[Documentation de Matxin (lien non direct ?)]] et sur la [http://matxin.sourceforge.net page Matxin de sourceforge]. Cette page se concentrera seulement sur la création d&amp;#039;une  nouvelle paire de langues, et évitera les problèmes théoriques et méthodologiques.&lt;br /&gt;
&lt;br /&gt;
La paire de langue pour le tutoriel sera breton vers anglais. Elle a été choisie puisque les deux langues ont un ordre de mot assez divergent (le breton est assez libre, permettant VSO, OVS et SVO, là où l&amp;#039;anglais est assez uniformément SVO) ce qui peut montrer quelques avantages que Matxin a sur Apertium. La phrase que nous allons utiliser pour ce propos est :&lt;br /&gt;
&lt;br /&gt;
:&amp;#039;&amp;#039;Ur yezh indezeuropek eo ar brezhoneg.&amp;#039;&amp;#039;&lt;br /&gt;
:[&amp;lt;sub&amp;gt;{{sc|compl}}&amp;lt;/sub&amp;gt; A language indo-european] [&amp;lt;sub&amp;gt;{{sc|verb}}&amp;lt;/sub&amp;gt; is] [&amp;lt;sub&amp;gt;{{sc|subj}}&amp;lt;/sub&amp;gt; the breton].&lt;br /&gt;
:Breton is an Indo-European language.&lt;br /&gt;
&lt;br /&gt;
Il y a deux problèmes principaux avec le transfert dans ce cas, le premier est de ré-ordonner, &amp;lt;code&amp;gt;OVS → SVO&amp;lt;/code&amp;gt;, le second est d&amp;#039;enlever l&amp;#039;article défini précédant un nom de langue &amp;lt;code&amp;gt;ar brezhoneg → Breton&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
== Pour commencer ==&lt;br /&gt;
&lt;br /&gt;
Ce HOWTO suppose que l&amp;#039;utilisateur est familier avec les bases de la plate-forme Apertium, si ce n&amp;#039;est pas le cas, veuillez regarder les pages : [[Lttoolbox (français)]], [[Dictionnaire bilingue]] et [[Créer une nouvelle paire de langues]].&lt;br /&gt;
&lt;br /&gt;
Pour les étapes d&amp;#039;analyse/désambiguïsation/dépendance, il y a deux options principales ouvertes :&lt;br /&gt;
# utiliser l&amp;#039;outil Apertium [[Lttoolbox (français)|lttoolbox]] pour la désambiguïsation morphologique, [[Contraintes grammaticales|Constraint Grammar]] pour la désambiguïsation basée sur les règles et le marquage syntaxique, [[apertium-tagger (français)]] pour la désambiguïsation statistique et finalement Constraint Grammar pour l&amp;#039;analyse des dépendances&lt;br /&gt;
# utiliser [[FreeLing]] pour toutes ces étapes.&lt;br /&gt;
&lt;br /&gt;
Typiquement le choix reposera sur quelles ressources sont disponibles, et les forces et faiblesses de chacun de ces outils.&lt;br /&gt;
&lt;br /&gt;
== Analyse avec Apertium et Constraint Grammar ==&lt;br /&gt;
&lt;br /&gt;
(à écrire...)&lt;br /&gt;
&lt;br /&gt;
== Analyse avec FreeLing ==&lt;br /&gt;
&lt;br /&gt;
Le processus d&amp;#039;analyse dans Matxin est fait par [[Freeling]], une suite libre d&amp;#039;analyseurs de langues. L&amp;#039;analyse est faite en quatre étapes, nécessitant quatre (ou plus) ensembles ou fichiers séparés. Le premier est le dictionnaire morphologique, lequel est principalement une liste de formes complète (ex: [[Speling format (français)]]) compilée dans un format BerkeleyDB. Il y a ensuite des fichiers pour la désambiguïsation des catégories de mots et pour spécifier les règles de fragmentation et de dépendances. Il y a deux autres étapes qui viennent avant l&amp;#039;analyse morphologique, la tokenisation et le découpage des phrases, mais pour les propos de ce tutoriel elles seront considérées le long de l&amp;#039;analyse morphologique.&lt;br /&gt;
&lt;br /&gt;
Normalement un programme unique est utilisé pour faire toutes les différentes étapes d&amp;#039;analyses, prendre en entrée du texte brut ou déformatté, et envoyer en sortie une analyse de dépendances, le comportement de ce programme est contrôlé par un fichier appelé &amp;lt;code&amp;gt;config.cfg&amp;lt;/code&amp;gt;. Dans Matxin ce programme s&amp;#039;appelle &amp;lt;code&amp;gt;Analyzer&amp;lt;/code&amp;gt;, toutefois dans les étapes suivantes, on va utiliser des outils séparés et laisser créer le fichier config jusqu&amp;#039;à la dernière minute comme il peut devenir compliqué.&lt;br /&gt;
&lt;br /&gt;
Comme compagnon la lecture de cette section de la [http://garraf.epsevg.upc.es/freeling/index.php?option=com_content&amp;amp;task=view&amp;amp;id=18&amp;amp;Itemid=47 documentation Freeling] est hautement recommandée. Ce tutoriel saute des caractéristiques de Freeling qui ne sont pas nécessaires pour faire un système de traduction automatique  de base avec Matxin, et notez qu&amp;#039;il est également possible d&amp;#039;utiliser d&amp;#039;autres analyseurs comme entrée dans les parties fragmentation / dépendance analyse de Freeling, pour plus d&amp;#039;information voir [[Freeling|ici]].&lt;br /&gt;
&lt;br /&gt;
=== Morphologique ===&lt;br /&gt;
&lt;br /&gt;
Afin de créer votre analyseur morphologique dans Freeling vous avez besoin principalement de faire une liste de formes complète. S&amp;#039;il y a déjà un dictionnaire Apertium pour la langue, vous pouvez utiliser les scripts dans [[SVN|apertium SVN]] (module &amp;lt;code&amp;gt;apertium-tools/freeling&amp;lt;/code&amp;gt;) pour générer un dictionnaire depuis le début, sinon, construisez-la quand même depuis le début, ou construisez un dictionnaire dans [[Lttoolbox (français)|lttoolbox]] et ensuite générez la liste. &lt;br /&gt;
&lt;br /&gt;
Pour le but de cet exercice, vous pouvez juste taper (??) dans un petit dictionnaire à la main. On appellera le dictionnaire &amp;lt;code&amp;gt;matxin-br-en.br.dicc&amp;lt;/code&amp;gt;, et il contiendra&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
ul un DI0CN0 &lt;br /&gt;
un un DI0CN0 &lt;br /&gt;
ur un DI0CN0 &lt;br /&gt;
yezhoù yezh NCFPV0 &lt;br /&gt;
yezh yezh NCFSV0 yezh AQ0CN0&lt;br /&gt;
indezeuropek indezeuropek AQ0CN0 &lt;br /&gt;
eo bezañ VMIP3S0 &lt;br /&gt;
al an DA0CN0 &lt;br /&gt;
ar an DA0CN0 &lt;br /&gt;
an an DA0CN0&lt;br /&gt;
brezhoneg brezhoneg NCMSV0 &lt;br /&gt;
prezhoneg brezhoneg NCMSV0 &lt;br /&gt;
vrezhoneg brezhoneg NCMSV0 &lt;br /&gt;
. . Fp&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Le fichier est séparé par des espaces avec trois colonnes ou plus. La première est pour le [[forme de surface]] du mot, les colonnes suivantes sont pour une liste de lemmes et de [[Balisage des mots|balises de mots]].&lt;br /&gt;
&lt;br /&gt;
Après avoir keyed (??) ceci, on peut le compiler au format BerkeleyDB en utilisant l&amp;#039;outil &amp;lt;code&amp;gt;indexdict&amp;lt;/code&amp;gt; des utilitaires Freeling. Il est bon de noter que Freeling supporte seulement actuellement l&amp;#039;encodage &amp;lt;code&amp;gt;latin1&amp;lt;/code&amp;gt; des caractères, donc si vous travaillez en UTF-8, convertissez le dictionnaire à latin1 d&amp;#039;abord.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ cat matxin-br-en.br.dicc | iconv -f utf-8 -t latin1 | indexdict br-en.br.db&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Maintenant vous devriez avoir deux fichiers, &amp;lt;code&amp;gt;matxin-br-en.br.dicc&amp;lt;/code&amp;gt;, qui est le dictionnaire source, et &amp;lt;code&amp;gt;br-en.br.db&amp;lt;/code&amp;gt; qui est le dictionnaire dans le format BerkeleyDB. On ne peut toutefois pas utiliser cet analyseur sans spécifier un tokeniseur et un splitter. Ces fichiers définissent comment les mots et les phrases seront tokenisées. Pour l&amp;#039;instant on va utiliser un fichier de configuration minimal pour le splitter, donc écrire ce qui suit dans le fichier &amp;lt;code&amp;gt;matxin-br-en.spt.dat&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;SentenceEnd&amp;gt;&lt;br /&gt;
. 0&lt;br /&gt;
&amp;lt;/SentenceEnd&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Bien sûr, d&amp;#039;autre ponctuation de fin de phrase comme &amp;#039;?&amp;#039; et &amp;#039;!&amp;#039; pourrait aussi être ajouté ici. Et maintenant pour le tokeniseur de mot, on va écrire dans &amp;lt;code&amp;gt;matxin-br-en.tok.dat&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;Macros&amp;gt;&lt;br /&gt;
ALPHANUM   [^\]&amp;lt;&amp;gt;[(\.,&amp;quot;;:?!&amp;#039;`)^@~|}{_/\\+=&amp;amp;$#*+%\s\-]&lt;br /&gt;
OTHERS     [\]&amp;lt;&amp;gt;[(\.,&amp;quot;;:?!&amp;#039;`)^@~|}{_/\\+=&amp;amp;$#*+%\-]&lt;br /&gt;
&amp;lt;/Macros&amp;gt;&lt;br /&gt;
&amp;lt;RegExps&amp;gt;&lt;br /&gt;
WORD             0  {ALPHANUM}+&lt;br /&gt;
OTHERS_C         0  {OTHERS}+&lt;br /&gt;
&amp;lt;/RegExps&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Les macros définissent des expressions régulières qui sont utilisées pour tokeniser l&amp;#039;entrée en mots et ponctuation. L&amp;#039;expression régulière &amp;lt;code&amp;gt;WORD&amp;lt;/code&amp;gt; est définie comme une séquence d&amp;#039;un &amp;lt;code&amp;gt;ALPHANUM&amp;lt;/code&amp;gt; ou plus qui à son tour est défini comme n&amp;#039;importe quoi sauf un caractère de ponctuation.&lt;br /&gt;
&lt;br /&gt;
Donc maintenant si on veut analyser morphologiquement une phrase, nous faisons juste :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ echo &amp;quot;Ur yezh eo ar brezhoneg.&amp;quot; | fl-morph matxin-br-en.tok.dat matxin-br-en.spt.dat br-en.br.db  | iconv -f latin1&lt;br /&gt;
Ur un DI0CN0 -1   -1&lt;br /&gt;
yezh yezh NCFSV0 -1 yezh AQ0CN0 -1&lt;br /&gt;
eo bezañ VMIP3S0 -1   -1&lt;br /&gt;
ar an DA0CN0 -1   -1&lt;br /&gt;
brezhoneg brezhoneg NCMSV0 -1   -1&lt;br /&gt;
. . Fp -1&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Le &amp;lt;code&amp;gt;-1&amp;lt;/code&amp;gt; après chaque analyse est la probabilité &amp;#039;&amp;#039;a priori&amp;#039;&amp;#039; de l&amp;#039;analyse et est calculé à partir d&amp;#039;un corpus balisé au préalable. Comme on n&amp;#039;a pas de corpus balisé au préalable, ceci est désactivé.&lt;br /&gt;
&lt;br /&gt;
=== Désambiguïsation des catégories ===&lt;br /&gt;
&lt;br /&gt;
Après avoir travaillé sur l&amp;#039;analyse morphologique, l&amp;#039;étape suivante est de créer un tagger de parties de discours. Freeling offre diverses façons de le faire, celles basées HMM et celles basées Relax Constraint Grammar (RelaxCG) sont toutes deux supportées. On va démontrer comment créer un tagger RelaxCG puisque c&amp;#039;est plus facile et que ça ne requiert pas d&amp;#039;entraînement de tagger.&lt;br /&gt;
&lt;br /&gt;
Notre tagger sera très simple puisqu&amp;#039;on a seulement une ambiguïté, &amp;#039;&amp;#039;yezh&amp;#039;&amp;#039; &amp;#039;langue&amp;#039; peut être un nom ou un adjectif. Comme les adjectifs se mettent après le nom en Breton, on va mettre un très faible poids pour les adjectifs après les déterminants,&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
SETS&lt;br /&gt;
&lt;br /&gt;
CONSTRAINTS&lt;br /&gt;
&lt;br /&gt;
%% après un déterminant faible poids pour l&amp;#039;adjectif&lt;br /&gt;
-8.0 AQ*  (-1 D*);&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Le fichier (qu&amp;#039;on appellera &amp;lt;code&amp;gt;matxin-br-en.br.relax&amp;lt;/code&amp;gt; est fait de deux sections, la première &amp;lt;code&amp;gt;SETS&amp;lt;/code&amp;gt; définit les ensembles de balises ou lemmes, vraiment (?) comme les taggers &amp;lt;code&amp;gt;LIST&amp;lt;/code&amp;gt; et &amp;lt;code&amp;gt;SET&amp;lt;/code&amp;gt; dans VISL [[Constraint Grammar]]. La deuxième section définit une série de contraintes de poids, dans le format &amp;#039;poids&amp;#039;, suivi par un espace, suivi par la balise suivi par un autre espace and et ensuite le contexte. Le contexte est défini comme une série de positions relatives à la balise en question. &lt;br /&gt;
&lt;br /&gt;
Donc, en utilisant ce fichier on devrait être capables d&amp;#039;obtenir une sortie désambiguïsée :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ echo &amp;quot;Ur yezh eo ar brezhoneg.&amp;quot; | fl-morph matxin-br-en.tok.dat matxin-br-en.spt.dat br-en.br.db  | \&lt;br /&gt;
    fl-tagger matxin-br-en.br.relax | iconv -f latin1&lt;br /&gt;
Ur un DI0CN0 -1&lt;br /&gt;
yezh yezh NCFSV0 -1&lt;br /&gt;
eo bezañ VMIP3S0 -1&lt;br /&gt;
ar an DA0CN0 -1&lt;br /&gt;
brezhoneg brezhoneg NCMSV0 -1&lt;br /&gt;
. . Fp -1&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Fragmentation ===&lt;br /&gt;
&lt;br /&gt;
Donc, après le balisage la prochaine étape est l&amp;#039;analyse du fragment. C&amp;#039;est un peu comme la fragmentation disponible dans Apertium (voir [[Fragmentation]]), toutefois aucun transfert n&amp;#039;est réalisé, on groupe juste des mots dans des fragments. La grammaire est assez familière, le côté gauche montre le non-terminal, et le côté droit peut être aussi bien un terminal (dans le cas d&amp;#039;une balise, ex: &amp;lt;code&amp;gt;NCM*&amp;lt;/code&amp;gt;) ou un non-terminal (dans le cas de &amp;lt;code&amp;gt;n-m&amp;lt;/code&amp;gt;). Cette grammaire extrêmement simple va fragmenter l&amp;#039;entrée balisée en constituants (groupe nominal &amp;lt;code&amp;gt;sn&amp;lt;/code&amp;gt; et &amp;lt;code&amp;gt;verb-eo&amp;lt;/code&amp;gt;) pour une utilisation ultérieure par l&amp;#039;analyseur de dépendance. Ça devrait être assez direct, &amp;lt;code&amp;gt;|&amp;lt;/code&amp;gt; est une opération ou, et &amp;lt;code&amp;gt;+&amp;lt;/code&amp;gt; marque le gouverneur (??), ou la tête du fragment. La fin de chaque règle est marqué avec un point &amp;lt;code&amp;gt;.&amp;lt;/code&amp;gt; et les commentaires ils sont placés avec &amp;lt;code&amp;gt;%&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
n-m ==&amp;gt; NCM* .&lt;br /&gt;
n-f ==&amp;gt; NCF* .&lt;br /&gt;
&lt;br /&gt;
adj ==&amp;gt; AQ* .&lt;br /&gt;
&lt;br /&gt;
def ==&amp;gt; DA0CN0 .&lt;br /&gt;
indef ==&amp;gt; DI0CN0 .&lt;br /&gt;
&lt;br /&gt;
verb-eo ==&amp;gt; VMIP3S0(eo).  %% Un type de fragment spécifique pour la forme &amp;#039;eo&amp;#039; de bezañ&lt;br /&gt;
verb ==&amp;gt; VL* .&lt;br /&gt;
&lt;br /&gt;
punt ==&amp;gt; Fp .&lt;br /&gt;
&lt;br /&gt;
sn ==&amp;gt; def, +n-f, adj | def, +n-f | +n-f, adj | +n-f .&lt;br /&gt;
sn ==&amp;gt; def, +n-m, adj | def, +n-m | +n-m, adj | +n-m .&lt;br /&gt;
sn ==&amp;gt; indef, +n-m, adj | indef, +n-m | +n-m, adj | +n-m .&lt;br /&gt;
sn ==&amp;gt; indef, +n-f, adj | indef, +n-f | +n-f, adj | +n-f .&lt;br /&gt;
&lt;br /&gt;
@START S.&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
La directive &amp;lt;code&amp;gt;@START&amp;lt;/code&amp;gt; indique que le noeud de début de la phrase devrait être étiqueté &amp;lt;code&amp;gt;S&amp;lt;/code&amp;gt;. Donc, la sortie de cette grammaire sera :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ echo &amp;quot;Ur yezh indezeuropek eo ar brezhoneg.&amp;quot; | fl-morph matxin-br-en.tok.dat matxin-br-en.spt.dat br-en.br.db  | \&lt;br /&gt;
 fl-tagger matxin-br-en.br.relax  | fl-chunker matxin-br-en.br.gram | iconv -f latin1&lt;br /&gt;
S_[&lt;br /&gt;
  sn_[&lt;br /&gt;
    indef_[&lt;br /&gt;
      +(Ur un DI0CN0)&lt;br /&gt;
    ]&lt;br /&gt;
    +n-f_[&lt;br /&gt;
      +(yezh yezh NCFSV0)&lt;br /&gt;
    ]&lt;br /&gt;
    adj_[&lt;br /&gt;
      +(indezeuropek indezeuropek AQ0CN0)&lt;br /&gt;
    ]&lt;br /&gt;
  ]&lt;br /&gt;
  verb-eo_[&lt;br /&gt;
    +(eo bezañ VMIP3S0)&lt;br /&gt;
  ]&lt;br /&gt;
  sn_[&lt;br /&gt;
    def_[&lt;br /&gt;
      +(ar an DA0CN0)&lt;br /&gt;
    ]&lt;br /&gt;
    +n-m_[&lt;br /&gt;
      +(brezhoneg brezhoneg NCMSV0)&lt;br /&gt;
    ]&lt;br /&gt;
  ]&lt;br /&gt;
  punt_[&lt;br /&gt;
    +(. . Fp)&lt;br /&gt;
  ]&lt;br /&gt;
]&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Notez que la phrase est fragmentée en &amp;lt;code&amp;gt;sn verb-eo sn&amp;lt;/code&amp;gt;. Ça peut valoir la peine de jouer un peu avec la grammaire pour obtenir un meilleur ressenti pour ça.&lt;br /&gt;
&lt;br /&gt;
=== Analyse des dépendances ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape est de créer une grammaire de dépendance. La grammaire de dépendance décrit et étiquette les dépendances entre constituants. Elle est constituée de deux sections principales, &amp;lt;code&amp;gt;&amp;lt;GRPAR&amp;gt;&amp;lt;/code&amp;gt; qui arrange l&amp;#039;analyse fournie par le fragmenteur. Dans l&amp;#039;exemple, le verbe est déplacé au début de la phrase, avant le complément, et &amp;lt;code&amp;gt;&amp;lt;GRLAB&amp;gt;&amp;lt;/code&amp;gt; qui étiquette les parties de l&amp;#039;analyse.&lt;br /&gt;
&lt;br /&gt;
Notez qu&amp;#039;en breton, les phrases avec &amp;#039;&amp;#039;eo&amp;#039;&amp;#039; (une forme de &amp;#039;&amp;#039;bezañ&amp;#039;&amp;#039; &amp;#039;être&amp;#039;) a toujours la structure Objet&amp;amp;mdash;Verbe&amp;amp;mdash;Sujet, et donc nécessite une attention spéciale. Ainsi on étiquette le côté gauche comme le prédicat complément et le côté droit comme le sujet.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;GRPAR&amp;gt;&lt;br /&gt;
&lt;br /&gt;
1 - - (sn,verb-eo) top_right RELABEL -  % (Ur yezh keltiek (eo))&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/GRPAR&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;GRLAB&amp;gt;&lt;br /&gt;
&lt;br /&gt;
verb-eo attr-pred d.label=sn d.side=left p.label=verb-eo %% Étiquette dépendant de la gauche du verb-eo comme attr-pred&lt;br /&gt;
verb-eo ncsubj d.label=sn d.side=right p.label=verb-eo %% Étiquette dépendant de la droite du verb-eo comme ncsubj&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/GRLAB&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Dans la grammaire ci-dessus, &amp;lt;code&amp;gt;d.side&amp;lt;/code&amp;gt; indique le côté du dépendant, et &amp;lt;code&amp;gt;p.label&amp;lt;/code&amp;gt; indique l&amp;#039;étiquette du parent. Ce fichier est documenté de manière compréhensible dans la section [http://garraf.epsevg.upc.es/freeling/doc/userman/html/node28.html Dependency parser rule file] dans la documentation Freeling. &lt;br /&gt;
&lt;br /&gt;
On va mettre le fichier dans &amp;lt;code&amp;gt;matxin-br-en.br.dep&amp;lt;/code&amp;gt;, et la sortie résultante de l&amp;#039;analyse est :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ echo &amp;quot;Ur yezh indezeuropek eo ar brezhoneg.&amp;quot; | fl-morph matxin-br-en.tok.dat matxin-br-en.spt.dat br-en.br.db  | \&lt;br /&gt;
    fl-tagger matxin-br-en.br.relax | fl-parser matxin-br-en.br.gram matxin-br-en.br.dep | iconv -f latin1&lt;br /&gt;
verb-eo/top/(eo bezañ VMIP3S0) [&lt;br /&gt;
  sn/attr-pred/(yezh yezh NCFSV0) [&lt;br /&gt;
    indef/modnorule/(Ur un DI0CN0)&lt;br /&gt;
    adj/modnorule/(indezeuropek indezeuropek AQ0CN0)&lt;br /&gt;
  ]&lt;br /&gt;
  sn/ncsubj/(brezhoneg brezhoneg NCMSV0) [&lt;br /&gt;
    def/modnorule/(ar an DA0CN0)&lt;br /&gt;
  ]&lt;br /&gt;
  punt/modnomatch/(. . Fp)&lt;br /&gt;
]&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Fichier de configuration ===&lt;br /&gt;
&lt;br /&gt;
Donc maintenant nous avons une étape d&amp;#039;analyse qui fonctionne plus ou moins bien, il nous faut obtenir cette analyse dans une forme que peut être utilisé par Matxin. Ceci impliquera d&amp;#039;écrire un fichier de configuration qui spécifie tous les modules qu&amp;#039;on a utilisé auparavant (?) à un endroit. Ci dessous voici un fichier de configuration minimal pour les modules que nous avons utilisé ci-dessus. Toutes les options sont obligatoires, si une est omise, des messages d&amp;#039;error critiques peuvent se produire, donc le mieux est juste de copier et coller ceci, changer les chemins et ensuite y ajouter as we go along (???). &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
#### Langue&lt;br /&gt;
Lang=br&lt;br /&gt;
&lt;br /&gt;
## Les formats d&amp;#039;entrée/sortie valides sont : plain, token, splitted, morfo, tagged, parsed&lt;br /&gt;
InputFormat=plain&lt;br /&gt;
OutputFormat=dep&lt;br /&gt;
&lt;br /&gt;
# Considérer chaque passage à la ligne comme une fin de phrase&lt;br /&gt;
AlwaysFlush=no&lt;br /&gt;
&lt;br /&gt;
# Options tokeniser&lt;br /&gt;
TokenizerFile=&amp;quot;/home/fran/MATXIN/source/matxin-br-en/matxin-br-en.tok.dat&amp;quot;&lt;br /&gt;
&lt;br /&gt;
# Options splitter (découpeur)&lt;br /&gt;
SplitterFile=&amp;quot;/home/fran/MATXIN/source/matxin-br-en/matxin-br-en.spt.dat&amp;quot;&lt;br /&gt;
&lt;br /&gt;
# Options d&amp;#039;analyse morphologique&lt;br /&gt;
SuffixFile=&amp;quot;&amp;quot;&lt;br /&gt;
SuffixAnalysis=no&lt;br /&gt;
MultiwordsDetection=no&lt;br /&gt;
LocutionsFile=&amp;quot;&amp;quot;&lt;br /&gt;
DecimalPoint=&amp;quot;.&amp;quot;&lt;br /&gt;
ThousandPoint=&amp;quot;,&amp;quot;&lt;br /&gt;
QuantitiesFile=&amp;quot;&amp;quot;&lt;br /&gt;
NumbersDetection=no&lt;br /&gt;
PunctuationDetection=no&lt;br /&gt;
PunctuationFile=&amp;quot;&amp;quot;&lt;br /&gt;
DatesDetection=no&lt;br /&gt;
QuantitiesDetection=no&lt;br /&gt;
DictionarySearch=yes&lt;br /&gt;
DictionaryFile=/home/fran/MATXIN/source/matxin-br-en/br-en.br.db&lt;br /&gt;
ProbabilityAssignment=no&lt;br /&gt;
ProbabilityFile=&amp;quot;&amp;quot;&lt;br /&gt;
&lt;br /&gt;
# Options NER&lt;br /&gt;
NERecognition=none&lt;br /&gt;
NPDataFile=&amp;quot;&amp;quot;&lt;br /&gt;
&lt;br /&gt;
# Options Tagger&lt;br /&gt;
Tagger=relax&lt;br /&gt;
TaggerRelaxFile=/home/fran/MATXIN/source/matxin-br-en/matxin-br-en.br.relax&lt;br /&gt;
TaggerRelaxMaxIter=500&lt;br /&gt;
TaggerRelaxScaleFactor=670.0&lt;br /&gt;
TaggerRelaxEpsilon=0.001&lt;br /&gt;
TaggerRetokenize=no&lt;br /&gt;
TaggerForceSelect=tagger&lt;br /&gt;
&lt;br /&gt;
# Options Parser&lt;br /&gt;
GrammarFile=/home/fran/MATXIN/source/matxin-br-en/matxin-br-en.br.gram&lt;br /&gt;
&lt;br /&gt;
# Options dépendence parser&lt;br /&gt;
DepParser=txala&lt;br /&gt;
DepTxalaFile=/home/fran/MATXIN/source/matxin-br-en/matxin-br-en.br.dep&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Quand on a installé le fichier de configuration on peur utiliser le programme &amp;lt;code&amp;gt;Analyzer&amp;lt;/code&amp;gt; du paquet Matxin. La sortie finale de &amp;lt;code&amp;gt;Analyzer&amp;lt;/code&amp;gt; sera :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ echo &amp;quot;Ur yezh indezeuropek eo ar brezhoneg.&amp;quot; | Analyzer -f matxin-br-en.br-en.cfg  | iconv -f latin1&lt;br /&gt;
&lt;br /&gt;
&amp;lt;?xml version=&amp;#039;1.0&amp;#039; encoding=&amp;#039;UTF-8&amp;#039; ?&amp;gt;&lt;br /&gt;
&amp;lt;corpus&amp;gt;&lt;br /&gt;
&amp;lt;SENTENCE ord=&amp;#039;1&amp;#039; alloc=&amp;#039;0&amp;#039;&amp;gt;&lt;br /&gt;
&amp;lt;CHUNK ord=&amp;#039;2&amp;#039; alloc=&amp;#039;21&amp;#039; type=&amp;#039;verb-eo&amp;#039; si=&amp;#039;top&amp;#039;&amp;gt;&lt;br /&gt;
  &amp;lt;NODE ord=&amp;#039;4&amp;#039; alloc=&amp;#039;21&amp;#039; form=&amp;#039;eo&amp;#039; lem=&amp;#039;bezañ&amp;#039; mi=&amp;#039;VMIP3S0&amp;#039;&amp;gt;&lt;br /&gt;
  &amp;lt;/NODE&amp;gt;&lt;br /&gt;
  &amp;lt;CHUNK ord=&amp;#039;1&amp;#039; alloc=&amp;#039;0&amp;#039; type=&amp;#039;sn&amp;#039; si=&amp;#039;attr-pred&amp;#039;&amp;gt;&lt;br /&gt;
    &amp;lt;NODE ord=&amp;#039;2&amp;#039; alloc=&amp;#039;3&amp;#039; form=&amp;#039;yezh&amp;#039; lem=&amp;#039;yezh&amp;#039; mi=&amp;#039;NCFSV0&amp;#039;&amp;gt;&lt;br /&gt;
      &amp;lt;NODE ord=&amp;#039;1&amp;#039; alloc=&amp;#039;0&amp;#039; form=&amp;#039;Ur&amp;#039; lem=&amp;#039;un&amp;#039; mi=&amp;#039;DI0CN0&amp;#039;&amp;gt;&lt;br /&gt;
      &amp;lt;/NODE&amp;gt;&lt;br /&gt;
      &amp;lt;NODE ord=&amp;#039;3&amp;#039; alloc=&amp;#039;8&amp;#039; form=&amp;#039;indezeuropek&amp;#039; lem=&amp;#039;indezeuropek&amp;#039; mi=&amp;#039;AQ0CN0&amp;#039;&amp;gt;&lt;br /&gt;
      &amp;lt;/NODE&amp;gt;&lt;br /&gt;
    &amp;lt;/NODE&amp;gt;&lt;br /&gt;
  &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
  &amp;lt;CHUNK ord=&amp;#039;3&amp;#039; alloc=&amp;#039;24&amp;#039; type=&amp;#039;sn&amp;#039; si=&amp;#039;ncsubj&amp;#039;&amp;gt;&lt;br /&gt;
    &amp;lt;NODE ord=&amp;#039;6&amp;#039; alloc=&amp;#039;27&amp;#039; form=&amp;#039;brezhoneg&amp;#039; lem=&amp;#039;brezhoneg&amp;#039; mi=&amp;#039;NCMSV0&amp;#039;&amp;gt;&lt;br /&gt;
      &amp;lt;NODE ord=&amp;#039;5&amp;#039; alloc=&amp;#039;24&amp;#039; form=&amp;#039;ar&amp;#039; lem=&amp;#039;an&amp;#039; mi=&amp;#039;DA0CN0&amp;#039;&amp;gt;&lt;br /&gt;
      &amp;lt;/NODE&amp;gt;&lt;br /&gt;
    &amp;lt;/NODE&amp;gt;&lt;br /&gt;
  &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
  &amp;lt;CHUNK ord=&amp;#039;4&amp;#039; alloc=&amp;#039;36&amp;#039; type=&amp;#039;punt&amp;#039; si=&amp;#039;modnomatch&amp;#039;&amp;gt;&lt;br /&gt;
    &amp;lt;NODE ord=&amp;#039;7&amp;#039; alloc=&amp;#039;36&amp;#039; form=&amp;#039;.&amp;#039; lem=&amp;#039;.&amp;#039; mi=&amp;#039;Fp&amp;#039;&amp;gt;&lt;br /&gt;
    &amp;lt;/NODE&amp;gt;&lt;br /&gt;
  &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
&amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
&amp;lt;/SENTENCE&amp;gt;&lt;br /&gt;
&amp;lt;/corpus&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
ce qui est une représentation XML (voir [[Documentation of Matxin]]) de l&amp;#039;analyse des dépendances qu&amp;#039;on a vu précédemment.&lt;br /&gt;
&lt;br /&gt;
== Transfert ==&lt;br /&gt;
&lt;br /&gt;
=== Transfert lexical ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape dans le processus est le transfert lexical, il prend les formes lexicales de la langue source et retourne les formes lexicales de la langue cible. Il y a trois fichiers impliqués dans le transfert lexical :&lt;br /&gt;
&lt;br /&gt;
* Le dictionnaire bilingue (&amp;lt;code&amp;gt;matxin-br-en.br-en.dix&amp;lt;/code&amp;gt;), qui utilise le familier format de dictionnaire [[Lttoolbox (français)|lttoolbox]], bien que légèrement différent comme résultat des  [[Parole tags|balises de parole]]&lt;br /&gt;
* Le dictionnaire de sémantique des noms (&amp;lt;code&amp;gt;matxin-br-en.br.sem_info&amp;lt;/code&amp;gt;), un fichier avec des tabulations comme séparateur&lt;br /&gt;
* Le dictionnaire de type de fragment (&amp;lt;code&amp;gt;matxin-br-en.br.chunk_type&amp;lt;/code&amp;gt;), un fichier avec des tabulations comme séparateur&lt;br /&gt;
&lt;br /&gt;
Le module qui réalise le transfert lexical s&amp;#039;appelle &amp;lt;code&amp;gt;LT&amp;lt;/code&amp;gt;, et le format des dictionnaires décrit ci-dessus sera expliqué en bas.&lt;br /&gt;
&lt;br /&gt;
==== Dictionnaire bilingue ====&lt;br /&gt;
&lt;br /&gt;
Le format de base du dictionnaire bilingue est le même que dans Apertium,&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;dictionary&amp;gt;&lt;br /&gt;
  &amp;lt;alphabet/&amp;gt;&lt;br /&gt;
  &amp;lt;sdefs&amp;gt;&lt;br /&gt;
    &amp;lt;sdef n=&amp;quot;mi&amp;quot;     c=&amp;quot;Information morphologique&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;sdef n=&amp;quot;parol&amp;quot;  c=&amp;quot;style de balise PAROLE&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/sdefs&amp;gt;&lt;br /&gt;
  &amp;lt;section id=&amp;quot;main&amp;quot; type=&amp;quot;standard&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
  &amp;lt;/section&amp;gt;&lt;br /&gt;
&amp;lt;/dictionary&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Contrairement à Apertium où les symboles sont utilisés pour supporter l&amp;#039;information morphologique (ex: &amp;lt;code&amp;gt;&amp;lt;sdef n=&amp;quot;adj&amp;quot;/&amp;gt;&amp;lt;/code&amp;gt; et &amp;lt;code&amp;gt;&amp;lt;s n=&amp;quot;adj&amp;quot;/&amp;gt;&amp;lt;/code&amp;gt; pour les adjectifs), dans Matxin les symboles sont utilisés pour définir les attributs de l&amp;#039;élément noeud. Par exemple, &amp;lt;code&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;&amp;lt;/code&amp;gt; fabrique un attribut dans le noeud appelé &amp;lt;code&amp;gt;parol&amp;lt;/code&amp;gt; avec la valeur des balises qui suivent. Les balises suivantes sont habituellement entourées de crochets &amp;lt;code&amp;gt;[]&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
Donc, pour transférer la balise de parole d&amp;#039;un nom féminin singulier (&amp;lt;code&amp;gt;NCFSV0&amp;lt;/code&amp;gt;) en Breton dans la représentation appropriée en anglais pour le reste des étapes de transfert, ex: nom singulier sans genre &amp;lt;code&amp;gt; parol=&amp;quot;NC&amp;quot; mi=&amp;quot;[NUMS]&amp;quot; &amp;lt;/code&amp;gt;, on peut utiliser l&amp;#039;entrée suivante dans le dictionnaire bilingue :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
      &amp;lt;e&amp;gt;&amp;lt;p&amp;gt;&amp;lt;l&amp;gt;yezh&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NCFSV0&amp;lt;/l&amp;gt;&amp;lt;r&amp;gt;language&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NC&amp;lt;s n=&amp;quot;mi&amp;quot;/&amp;gt;[NUMS]&amp;lt;/r&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;/e&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
ce qui donnera en sortie&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
      &amp;lt;NODE ref=&amp;quot;2&amp;quot; alloc=&amp;quot;3&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;language&amp;quot; parol=&amp;quot;NC&amp;quot; mi=&amp;quot;[NUMS]&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
par le module de transfert lexical. Comme ces modèles sont répétés fréquemment, typiquement ils sont mis dans des paradigmes, mais au lieu d&amp;#039;être des paradigmes morphologiques, comme dans Apertium, ce sont des paradigmes de transfert lexical, donc par exemple pour les noms on peur avoir :&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
    &amp;lt;pardef n=&amp;quot;NC_STD&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;e&amp;gt;&amp;lt;p&amp;gt;&amp;lt;l&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NCFSV0&amp;lt;/l&amp;gt;&amp;lt;r&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NC&amp;lt;s n=&amp;quot;mi&amp;quot;/&amp;gt;[NUMS]&amp;lt;/r&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;/e&amp;gt;&lt;br /&gt;
      &amp;lt;e&amp;gt;&amp;lt;p&amp;gt;&amp;lt;l&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NCFPV0&amp;lt;/l&amp;gt;&amp;lt;r&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NC&amp;lt;s n=&amp;quot;mi&amp;quot;/&amp;gt;[NUMP]&amp;lt;/r&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;/e&amp;gt;&lt;br /&gt;
      &amp;lt;e&amp;gt;&amp;lt;p&amp;gt;&amp;lt;l&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NCMSV0&amp;lt;/l&amp;gt;&amp;lt;r&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NC&amp;lt;s n=&amp;quot;mi&amp;quot;/&amp;gt;[NUMS]&amp;lt;/r&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;/e&amp;gt;&lt;br /&gt;
      &amp;lt;e&amp;gt;&amp;lt;p&amp;gt;&amp;lt;l&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NCMPV0&amp;lt;/l&amp;gt;&amp;lt;r&amp;gt;&amp;lt;s n=&amp;quot;parol&amp;quot;/&amp;gt;NC&amp;lt;s n=&amp;quot;mi&amp;quot;/&amp;gt;[NUMP]&amp;lt;/r&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;/e&amp;gt;&lt;br /&gt;
    &amp;lt;/pardef&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Transferring both feminine and masculine singular and plural nouns in Breton to their English equivalents. The corresponding entries for our two nouns in the main section would be,&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
    &amp;lt;e&amp;gt;&amp;lt;p&amp;gt;&amp;lt;l&amp;gt;yezh&amp;lt;/l&amp;gt;&amp;lt;r&amp;gt;language&amp;lt;/r&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;par n=&amp;quot;NC_STD&amp;quot;/&amp;gt;&amp;lt;/e&amp;gt;&lt;br /&gt;
    &amp;lt;e&amp;gt;&amp;lt;p&amp;gt;&amp;lt;l&amp;gt;brezhoneg&amp;lt;/l&amp;gt;&amp;lt;r&amp;gt;Breton&amp;lt;/r&amp;gt;&amp;lt;/p&amp;gt;&amp;lt;par n=&amp;quot;NC_STD&amp;quot;/&amp;gt;&amp;lt;/e&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Using the information for nouns and the XML generated after lexical transfer below you should be able to create a full dictionnaire bilingue for our test phrase.&lt;br /&gt;
&lt;br /&gt;
==== Noun semantic dictionary ====&lt;br /&gt;
&lt;br /&gt;
The noun semantic dictionary is a simple file which allows basic semantic tagging of lemmas. The works somewhat like lists in Apertium transfer files, and allows the categorisation of nouns into semantic classes, for example &amp;#039;&amp;#039;language&amp;#039;&amp;#039;, &amp;#039;&amp;#039;animacy&amp;#039;&amp;#039;, &amp;#039;&amp;#039;material&amp;#039;&amp;#039;, &amp;#039;&amp;#039;communication medium&amp;#039;&amp;#039; etc. The file is a tab separated list of lemma and semantic tag, for example for our phrase we might want to tag &amp;#039;&amp;#039;brezhoneg&amp;#039;&amp;#039; &amp;#039;Breton&amp;#039; as &amp;lt;code&amp;gt;[HZK]&amp;lt;/code&amp;gt; (an abbreviation of &amp;#039;&amp;#039;hizkuntzak&amp;#039;&amp;#039; &amp;#039;languages&amp;#039;).&lt;br /&gt;
&lt;br /&gt;
So make the file &amp;lt;code&amp;gt;matxin-br-en.br.sem_info&amp;lt;/code&amp;gt; with the following contents:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
##[HZK]: Languages / Yezhoù (hizkuntzak)&lt;br /&gt;
&lt;br /&gt;
brezhoneg [HZK+]&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
You can add other languages such as &amp;#039;&amp;#039;euskareg&amp;#039;&amp;#039; &amp;#039;Basque&amp;#039; and &amp;#039;&amp;#039;kembraeg&amp;#039;&amp;#039; &amp;#039;Welsh&amp;#039;. The symbol &amp;lt;code&amp;gt;+&amp;lt;/code&amp;gt; means that this feature is positive, the feature can also be followed by &amp;lt;code&amp;gt;-&amp;lt;/code&amp;gt; for negative or &amp;lt;code&amp;gt;?&amp;lt;/code&amp;gt; for uncertain. The lexical transfer module doesn&amp;#039;t seem to use this information directly, but it needs the file to be in place.&lt;br /&gt;
&lt;br /&gt;
==== Chunk-type transfer dictionary ====&lt;br /&gt;
&lt;br /&gt;
The final dictionary required for the lexical transfer stage is the chunk-type transfer dictionary. This transfers chunk types (e.g. &amp;lt;code&amp;gt;sn&amp;lt;/code&amp;gt; &amp;#039;&amp;#039;sintagma nominal&amp;#039;&amp;#039; &amp;#039;Noun phrase&amp;#039; and &amp;lt;code&amp;gt;sp&amp;lt;/code&amp;gt; &amp;#039;&amp;#039;sintagma preposicional&amp;#039;&amp;#039; &amp;#039;Prepositional phrase&amp;#039;) into the target language chunk types. As we maintain the same chunk types between languages we can just have an empty file for this. Although it is probably worth adding a comment with the format, for example make a file called &amp;lt;code&amp;gt;matxin-br-en.br-en.chunk_type&amp;lt;/code&amp;gt; with the following contents,&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
#Category (SL)	#Category (TL)	#Description (SL)	#Description (TL)&lt;br /&gt;
sn	        sn	        #Noun phrase             Noun phrase&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Fichier de configuration ====&lt;br /&gt;
&lt;br /&gt;
Now we come to editting the configuration file, we open the file, add the following options at the bottom of the file and save it.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
# Transfer options &lt;br /&gt;
&lt;br /&gt;
TransDictFile=/home/fran/MATXIN/source/matxin-br-en/br-en.autobil.bin&lt;br /&gt;
ChunkTypeDict=/home/fran/MATXIN/source/matxin-br-en/matxin-br-en.br-en.chunk_type&lt;br /&gt;
NounSemFile=/home/fran/MATXIN/source/matxin-br-en/matxin-br-en.br.sem_info&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== Output of lexical transfer ====&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ echo &amp;quot;Ur yezh indezeuropek eo ar brezhoneg.&amp;quot; | Analyzer -f matxin-br-en.br-en.cfg  | iconv -f latin1 | \ &lt;br /&gt;
    LT -f matxin-br-en.br-en.cfg&lt;br /&gt;
&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;corpus&amp;gt;&lt;br /&gt;
  &amp;lt;SENTENCE ref=&amp;quot;1&amp;quot; alloc=&amp;quot;0&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;CHUNK ref=&amp;quot;2&amp;quot; type=&amp;quot;verb-eo&amp;quot; alloc=&amp;quot;21&amp;quot; si=&amp;quot;top&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;NODE ref=&amp;quot;4&amp;quot; alloc=&amp;quot;21&amp;quot; slem=&amp;quot;bezañ&amp;quot; smi=&amp;quot;VMIP3S0&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;be&amp;quot; parol=&amp;quot;VM&amp;quot; mi=&amp;quot;[IND][PRES][P3][NUMS]&amp;quot;/&amp;gt;&lt;br /&gt;
      &amp;lt;CHUNK ref=&amp;quot;1&amp;quot; type=&amp;quot;sn&amp;quot; alloc=&amp;quot;0&amp;quot; si=&amp;quot;attr-pred&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;NODE ref=&amp;quot;2&amp;quot; alloc=&amp;quot;3&amp;quot; slem=&amp;quot;yezh&amp;quot; smi=&amp;quot;NCFSV0&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;language&amp;quot; parol=&amp;quot;NC&amp;quot; mi=&amp;quot;[NUMS]&amp;quot;&amp;gt;&lt;br /&gt;
          &amp;lt;NODE ref=&amp;quot;1&amp;quot; alloc=&amp;quot;0&amp;quot; slem=&amp;quot;un&amp;quot; smi=&amp;quot;DI0CN0&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;a&amp;quot; parol=&amp;quot;DI&amp;quot;/&amp;gt;&lt;br /&gt;
          &amp;lt;NODE ref=&amp;quot;3&amp;quot; alloc=&amp;quot;8&amp;quot; slem=&amp;quot;indezeuropek&amp;quot; smi=&amp;quot;AQ0CN0&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;Indo-European&amp;quot; parol=&amp;quot;AQ&amp;quot; mi=&amp;quot;[PST]&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/NODE&amp;gt;&lt;br /&gt;
      &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
      &amp;lt;CHUNK ref=&amp;quot;3&amp;quot; type=&amp;quot;sn&amp;quot; alloc=&amp;quot;24&amp;quot; si=&amp;quot;ncsubj&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;NODE ref=&amp;quot;6&amp;quot; alloc=&amp;quot;27&amp;quot; slem=&amp;quot;brezhoneg&amp;quot; smi=&amp;quot;NCMSV0&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;Breton&amp;quot; parol=&amp;quot;NC&amp;quot; mi=&amp;quot;[NUMS]&amp;quot;&amp;gt;&lt;br /&gt;
          &amp;lt;NODE ref=&amp;quot;5&amp;quot; alloc=&amp;quot;24&amp;quot; slem=&amp;quot;an&amp;quot; smi=&amp;quot;DA0CN0&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;the&amp;quot; parol=&amp;quot;DA&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/NODE&amp;gt;&lt;br /&gt;
      &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
      &amp;lt;CHUNK ref=&amp;quot;4&amp;quot; type=&amp;quot;punt&amp;quot; alloc=&amp;quot;36&amp;quot; si=&amp;quot;modnomatch&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;NODE ref=&amp;quot;7&amp;quot; alloc=&amp;quot;36&amp;quot; slem=&amp;quot;.&amp;quot; smi=&amp;quot;Fp&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;.&amp;quot; parol=&amp;quot;Fp&amp;quot;/&amp;gt;&lt;br /&gt;
      &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
    &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
  &amp;lt;/SENTENCE&amp;gt;&lt;br /&gt;
&amp;lt;/corpus&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Note: The above output has been post-processed by &amp;lt;code&amp;gt;xmllint --format -&amp;lt;/code&amp;gt; to give more human readable formatting.&lt;br /&gt;
&lt;br /&gt;
=== Intra-chunk transfer ===&lt;br /&gt;
&lt;br /&gt;
The purpose of the intra-chunk transfer is to move information from nodes in a chunk to the chunk, for example to do concordance between a subject noun phrase and the verb in a verb phrase. We&amp;#039;re just going to copy the morphological information straight over, so make a file called &amp;lt;code&amp;gt;matxin-br-en.br-en.intra1&amp;lt;/code&amp;gt; and put the following in.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
#    1/2     3/4      5&lt;br /&gt;
mi!=&amp;#039;&amp;#039;/mi	/mi	no-overwrite&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
The file is tab and forward-slash separated and has five columns:&lt;br /&gt;
&lt;br /&gt;
# Node specification: Defines which nodes to take information from, in this case &amp;lt;code&amp;gt;mi!=&amp;lt;nowiki&amp;gt;&amp;#039;&amp;#039;&amp;lt;/nowiki&amp;gt;&amp;lt;/code&amp;gt; where the morphological information is non-null.&lt;br /&gt;
# Source attribute: Which source attribute to copy, in this case the morphological information.&lt;br /&gt;
# Chunk condition: Restricts the chunk to which the information can be moved. In this case there is no restriction, but for example, you might want to only move the information when the subject is a common noun, in which case &amp;lt;code&amp;gt;si=&amp;#039;ncsubj&amp;#039;&amp;lt;/code&amp;gt; would do the trick.&lt;br /&gt;
# Destination attribute: The attribute in which the information should be put.&lt;br /&gt;
# Write mode: Can be one of three, either &amp;#039;&amp;#039;no-overwrite&amp;#039;&amp;#039; (do not overwrite previous information), &amp;#039;&amp;#039;overwrite&amp;#039;&amp;#039; (overwrite previous information), &amp;#039;&amp;#039;concat&amp;#039;&amp;#039; (concatenate information to any previously existing).&lt;br /&gt;
&lt;br /&gt;
After you&amp;#039;ve made the file, add the details to the bottom of the configuration file as follows,&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
IntraMoveFile=/home/fran/MATXIN/source/matxin-br-en/matxin-br-en.br-en.intra1&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
After this has been added, we&amp;#039;re ready to run the intra-chunk syntactic transfer module. This is done with the &amp;lt;code&amp;gt;ST_intra&amp;lt;/code&amp;gt; program, which can be called as follows:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
$ echo &amp;quot;Ur yezh indezeuropek eo ar brezhoneg.&amp;quot; | Analyzer -f matxin-br-en.br-en.cfg  | iconv -f latin1 | LT -f matxin-br-en.br-en.cfg \&lt;br /&gt;
    ST_intra -f matxin-br-en.br-en.cfg&lt;br /&gt;
&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;UTF-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;corpus&amp;gt;&lt;br /&gt;
  &amp;lt;SENTENCE ref=&amp;quot;1&amp;quot; alloc=&amp;quot;0&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;CHUNK ref=&amp;quot;2&amp;quot; type=&amp;quot;verb-eo&amp;quot; alloc=&amp;quot;21&amp;quot; si=&amp;quot;top&amp;quot; mi=&amp;quot;[IND][PRES][P3][NUMS]&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;NODE ref=&amp;quot;4&amp;quot; alloc=&amp;quot;21&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;be&amp;quot; parol=&amp;quot;VM&amp;quot; mi=&amp;quot;[IND][PRES][P3][NUMS]&amp;quot; /&amp;gt;&lt;br /&gt;
      &amp;lt;CHUNK ref=&amp;quot;1&amp;quot; type=&amp;quot;sn&amp;quot; alloc=&amp;quot;0&amp;quot; si=&amp;quot;attr-pred&amp;quot; mi=&amp;quot;[NUMS]&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;NODE ref=&amp;quot;2&amp;quot; alloc=&amp;quot;3&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;language&amp;quot; parol=&amp;quot;NC&amp;quot; mi=&amp;quot;[NUMS]&amp;quot;&amp;gt;&lt;br /&gt;
          &amp;lt;NODE ref=&amp;quot;1&amp;quot; alloc=&amp;quot;0&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;a&amp;quot; parol=&amp;quot;DI&amp;quot;/&amp;gt;&lt;br /&gt;
          &amp;lt;NODE ref=&amp;quot;3&amp;quot; alloc=&amp;quot;8&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;Indo-European&amp;quot; parol=&amp;quot;AQ&amp;quot; mi=&amp;quot;[PST]&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/NODE&amp;gt;&lt;br /&gt;
      &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
      &amp;lt;CHUNK ref=&amp;quot;3&amp;quot; type=&amp;quot;sn&amp;quot; alloc=&amp;quot;24&amp;quot; si=&amp;quot;ncsubj&amp;quot; mi=&amp;quot;[NUMS]&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;NODE ref=&amp;quot;6&amp;quot; alloc=&amp;quot;27&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;Breton&amp;quot; parol=&amp;quot;NC&amp;quot; mi=&amp;quot;[NUMS]&amp;quot;&amp;gt;&lt;br /&gt;
          &amp;lt;NODE ref=&amp;quot;5&amp;quot; alloc=&amp;quot;24&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;the&amp;quot; parol=&amp;quot;DA&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/NODE&amp;gt;&lt;br /&gt;
      &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
      &amp;lt;CHUNK ref=&amp;quot;4&amp;quot; type=&amp;quot;punt&amp;quot; alloc=&amp;quot;36&amp;quot; si=&amp;quot;modnomatch&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;NODE ref=&amp;quot;7&amp;quot; alloc=&amp;quot;36&amp;quot; UpCase=&amp;quot;none&amp;quot; lem=&amp;quot;.&amp;quot; parol=&amp;quot;Fp&amp;quot;/&amp;gt;&lt;br /&gt;
      &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
    &amp;lt;/CHUNK&amp;gt;&lt;br /&gt;
  &amp;lt;/SENTENCE&amp;gt;&lt;br /&gt;
&amp;lt;/corpus&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
The morphological information has been moved from the node head of the chunk to the chunk itself.&lt;br /&gt;
&lt;br /&gt;
=== Inter-chunk transfer ===&lt;br /&gt;
&lt;br /&gt;
The next stage is similar to the previous stage, but deals with movement between chunks themselves. In our example we don&amp;#039;t need to use this.&lt;br /&gt;
&lt;br /&gt;
== Generation ==&lt;br /&gt;
&lt;br /&gt;
=== Intra-chunk ===&lt;br /&gt;
&lt;br /&gt;
As Breton and English differ in the internal structure of noun phrases, the next thing we want to do is transfer the Breton structure into English, this will involve changing {{sc|det nom adj}} to {{sc|det adj nom}}. Another intra-chunk process we want to take care of is the removal of the definite article before a noun which has the semantic tag for language (&amp;lt;code&amp;gt;[HZK+]&amp;lt;/code&amp;gt;).&lt;br /&gt;
&lt;br /&gt;
[[Category:Matxin]]&lt;br /&gt;
[[Category:Documentation]]&lt;br /&gt;
[[Category:HOWTO]]&lt;br /&gt;
[[Category:Documentation en français]]&lt;/div&gt;</summary>
		<author><name>Bech</name></author>
		
	</entry>
</feed>