Machine translation

Machine language translation with apertium
കമ്പ്യൂട്ടറിന്റെ സഹായത്താല്‍ ഒരു ഭാഷയിലുള്ള ഉള്ളടക്കത്തെ മറ്റൊരു ഭാഷയിലേക്ക് പരിഭാഷപ്പെടുത്തുന്നതിനെയാണ് യാന്ത്രിക പരിഭാഷ എന്നു പറയുന്നത്. ഒരു ഭാഷയിലെ വാക്കുകള്‍ക്ക് പകരം target ഭാഷയിലെ വാക്കുകള്‍ പകരം വച്ചതുകൊണ്ടു മാത്രം പരിഭാഷ സാധ്യമല്ല, കാരണം ഓരോ ഭാഷയ്ക്കും വ്യത്യസ്തമായ വ്യാകരണമാണ്.

യാന്ത്രിക പരിഭാഷയെ പ്രധാനമായും രണ്ടായി തിരിക്കാം.


 * 1) Rule Based
 * 2) Corpus Based

Rule Based
വ്യാകരണ നിയമങ്ങളുടെ അടിസ്ഥാനമാക്കി പരിഭാഷപെടുത്തുന്നതിനെയാണ് റൂള്‍ ബേസ്ഡ് എന്നു പറയുന്നത് "Rule-based machine translation is like taking a set of dictionaries and a descriptive grammar, and trying to translate from one language you don’t know into another."

ഗുണങ്ങള്‍

 * 1) പ്രവചിക്കാവുന്ന ഫലം (predictable output)
 * 2) പ്രവചിക്കാവുന്ന തെറ്റുകള്‍(predictable errors)
 * 3) (incremental improvements)
 * 4) തെറ്റുകള്‍ എളുപ്പത്തില്‍ കണ്ടുപിടിക്കാം
 * 5) വലിയ അളവില്‍ നിലവിലുള്ള പരിഭാഷയുടെ ലഭ്യത ആവശ്യമില്ല.

ദോഷങ്ങള്‍

 * 1) Lack of fluency
 * 2) Lack of idiomaticness
 * 3) “Mechanical” output
 * 4) Development (വികസനം) കൂടുതല്‍ സമയമെടുത്തേക്കാം

Corpus Based
ലഭ്യമായ മുന്‍ പരിഭാഷകള്‍ ഉപയോഗിച്ച് word matchingങ്ങിലൂടെ പരിഭാഷപ്പെടുത്തുന്നതിനെയാണ് കോര്‍പസ് ബേസ്ഡ് പരിഭാഷ എന്നു പറയുന്നത് "Corpus-based machine translation is like taking two documents in two languages you don’t know which are translations of each other and trying to match up words. Then you use these words to build sentences which you put into Google to see if they sound likely."

ഗുണങ്ങള്‍

 * 1) Fluent output
 * 2) Idiomatic output
 * 3) No need for linguistic resources:
 * 4) dictionaries
 * 5) grammars
 * 6) linguists

ദോഷങ്ങള്‍

 * 1) Unpredictable
 * 2) Incremental improvements are hard
 * 3) Development can be time consuming

റൂള്‍ ബേസ്ഡ് പരിഭാഷയെ അടിസ്താനമാകിയുള്ള സ്വതന്ത്ര സോഫ്ട്വൈര്‍ ആണ് apertium. wikimeadia യുടെ പുതിയ പരിഭാഷ പദ്ധതിയിലും apertium ആണ് ഉപയോഗിക്കുന്നത് .ലളിതവും extensibility യുമാണ് അപെറ്ടിയത്തെ പ്രിയങ്കരമാക്കുന്നത്. 2004 ഇല്‍ സ്പൈന് വ്യവസായ വകുപ്പിന്റെ കീഴില്‍ കണ്‍സോര്ഷ്യമാണ് അപെറ്ടിയം ഉണ്ടാക്കിയത്

സ്ഥാപിക്കാന്‍/Installation
Installing the newest version from SVN

Step 1: install the prerequisites. ടെര്‍മിനല്‍ ഓപെണ്‍ ചെയ്ത് താഴെയുള്ള കോഡ് എന്റെര്‍ ചെയ്യുക sudo apt-get install subversion build-essential pkg-config gawk libxml2 libxml2-dev libxml2-utils xsltproc flex automake libtool libpcre3-dev പാസ്വെര്‍ഡ് ട്യെപ് ചെയ്ത് എന്റെര്‍ ചെയ്യുക .

Step 2: Download required packages. svn checkout https://svn.code.sf.net/p/apertium/svn/trunk/lttoolbox svn checkout https://svn.code.sf.net/p/apertium/svn/trunk/apertium svn checkout https://svn.code.sf.net/p/apertium/svn/trunk/apertium-lex-tools

Step 2: compile and install. cd lttoolbox ./autogen.sh make make install ldconfig cd apertium ./autogen.sh make make install ldconfig cd apertium-lex-tools ./autogen.sh make make install ldconfig

ഘടന



 * Deformatter


 * ഈ സ്ടെപ്പില്‍ പരിഭാഷപ്പെടുത്തേണ്ട textഇനെ ഫോര്‍മാറ്റിങ്ങുകളില്‍ നിന്നു മുക്തമാകും, ഉദാഹരണത്തിന് പരിഭാഷപെടുത്തേണ്ട text ഒരു html ഫയല്‍ ആണെങ്കില്‍ അതിലെ ടാഗ്സ് ഒഴിവാക്കും


 * Morphological analyzer
 * ഈ സ്ടെപ്പില്‍ പരിഭാഷപ്പെടുത്തേണ്ട textഇനെ സര്‍ഫസ് ഫോമുകളായി ഭാഗിക്കുകയും, ഒരോന്നിനും ഒന്നോ അതിലതികമോ ലെക്സിക്കല്‍ ഫോമുകള്‍ കണ്ടെത്തുകയും ചെയ്യും


 * Part of speech tagger
 * ഒന്നിലതികം ലെക്സിക്കല്‍ ഫോമുകളുള്ള വാക്കുക്കളില്‍ ഏറ്റവും അനുയോജ്യമായത് തിരഞെടുക്കും


 * Lexical transfer
 * Lexical Selection
 * Structural Transfer
 * Morphological generator
 * Post generator
 * Reformatter
 * ആദ്യത്തെ സ്ടെപ്പില്‍ ഒഴിവാക്കിയ ഫോര്‍മാറ്റിങ്ങ് വിവരങ്ങള്‍ വീണ്ടും ചേര്‍ക്കും

മലയാളം പരിഭാഷ
എനി നമുക്ക് അപെര്‍ടിയം ഉപയോഗിച്ച് മലയാളം പരിഭാഷ എങ്ങനെ ചെയ്യും എന്നു നോക്കം (It is difficult to handle agglutination in the following method)

morphological Analyzer
ഇതിനു നമുക്ക് മൂന്ന് നിഘണ്ടുകള്‍ വേണം
 * 1) mono lingual dictionary of malayalam
 * 2) mono lingual dictionary of malayalam
 * 3) bilingual english malayalam dictionary

ആദ്യം മലയാളം മോണൊlingual നിഘണ്ടു എങ്ങനെ ഉണ്ടാക്കും എന്നു നോക്കാം

 അആഇഈഉഊഋഌഎഏഐഒഓഔകഖഗഘങചഛജഝഞടഠഡഢണതഥദധനഩപഫബഭമയരറലളഴവശഷസഹഽാിീുൂൃൄെേൈൊോൌ്ൗൠൡൢൣൺൻര്‍ൾൿംഃ



ഇതിലെ ഒരോ ടാഗുകളും അതിന്റെ ഉപയോഗങ്ങളും
 * : ഈ ടഗിനകത്താണ് നമ്മുടെ നിഗണ്ടുവിലെ ഉള്ളടക്കം ചേര്‍ക്കേണ്ടത്
 * : ഈ ടാഗിനകതാണ് അക്ഷരങ്ങള്‍ ചേര്‍ക്കേണ്ടത്
 * : സിംബlലുകള്‍ നിര്‍വചിക്കാന്‍
 * : paradigms നിര്‍വചിക്കാന്‍
 * : വാക്കുകള്‍ നിര്‍വചിക്കാന്‍
 * : സിംബല്‍ നിര്വചിക്കാന്‍
 * :paradigms നിര്‍വചിക്കാന്‍
 *  : എന്റിറ്റി
 * : pair
 *  : left
 *  : right

note:  ടാഗിനകത്ത് വാക്കിന്റെ അവസാനം വരുന്ന മാറ്റങ്ങളും  ടാഗിനകത്ത് അതിന്റെ സിംബല്‍സുമാണ് ചേര്‍ക്കുക നമുക്കിതില്‍ മരം എന്ന വാക്ക് ചേര്‍ത്തു നോക്കാം  അആഇഈഉഊഋഌഎഏഐഒഓഔകഖഗഘങചഛജഝഞടഠഡഢണതഥദധനഩപഫബഭമയരറലളഴവശഷസഹഽാിീുൂൃൄെേൈൊോൌ്ൗൠൡൢൣൺൻര്‍ൾൿംഃ       <sdef n="voc"    c="Vocative"/> <sdef n="gen"    c="Genitive"/> <sdef n="loc"    c="Locative"/> <sdef n="sg"     c="Singular . ഏകവചനം"/> <sdef n="pl"     c="Plural . ബഹു വചനം"/> <sdef n="sp"     c="Singular / Plural . ഏകവചനം/ബഹുവചനം"/> <pardef n="മര/ം__n"> <e>      <l>ം</l>ം   </r> </e> <e>      <l>ത്തെ</l>ം   </r> </e> <e>      <l>ത്തിന്റെ</l>ം   </r> </e> <e>      <l>ത്തിന്</l>ം   </r> </e> <e>      <l>ത്തില്‍</l>ം   </r> </e> <e>      <l>ത്താല്‍</l>ം   </r> </e> <e>      <l>മേ</l>ം   </r> </e> <e>      <l>ത്തൊടു</l>ം   </r> </e> <e>      <l>ങ്ങള്‍</l>ം   </r> </e> <e>      <l>ങ്ങളെ</l>ം   </r> </e> <e>      <l>ങ്ങളുടെ</l>ം   </r> </e> <e>      <l>ങ്ങള്‍കൂ</l>ം   </r> </e> <e>      <l>ങ്ങളില്‍</l>ം   </r> </e> <e>      <l>ങ്ങളാല്‍</l>ം   </r> </e> <e>      <l>ങ്ങളേ</l>ം   </r> </e> <e>      <l>ങ്ങളോടു</l>ം   </r> </e> <section id="main" type="standard"> <e lm="മരം">മര<par n="മര/ം__n"/></e>

ഇതിനെ apertium-mal-eng.sh.dix എന്ന പേരില്‍ സേവ് ചെയ്യുക എനി നമുക്കിതിനെ അനലെസര്‍ ആയി കംബെല്‍ ചെയ്യാം ( left to right) lt-comp lr apertium-mal-eng.sh.dix mal-eng.automorf.bin

ജെനെറേടര്‍ ആയി കംബെല്‍ ചെയ്യാന്‍ (right to left) lt-comp rl apertium-mal-eng.sh.dix eng-mal.autogen.bin

ഇതിനെ ടെസ്ട് ചെയ്യാന്‍ lt-comp ട്ടൂള്‍ ഉപയോഗിക്കാം lt-proc mal-eng.automorf.bin

ശേഷം മരം എന്നെഴുതി എന്റെര്‍ പ്രെസ്സ് ചെയ്താല്‍ ഇതു പോലെയുള്ള ഔട്പുട് ലഭിക്കും മരം ^മരം/മരം<n><sg> $

കൂടുതല്‍ വിവരങ്ങള്‍ക്ക്

 * http://wiki.apertium.org
 * http://wiki.apertium.org/wiki/Apertium_New_Language_Pair_HOWTO
 * User:Tachyons