تشخیص موجودیت‌های نام‌دار در متن

تغییرات پروژه از تاریخ 1394/02/27 تا تاریخ 1394/04/10
`...`**به نام یگانه نام‌دار عالم**
# چکیده
موجودیت‌های نام‌دار در زبان به مجموعه‌ای از اسامی مانند نام افراد،  سازمان‌ها، مکان‌ها،  و... می‌باشد. شناسایی موجودیت‌های نام‌دار در متن  مسئله پیدا کردن این موجودیت‌ها از متن خام و همچنین شناسایی نوع موجودیت  است.

برای مثال: آدولف بورن، طراح، کاریکاتوریست و نقاش در شهر بودجویس از جمهوری چک به دنیا آمد.

> آدولف B-PERSON بورن I-PERSON ، کاریکاتوریست و نقاش در شهر بودجویس B-LOCATION از جمهوری B-LOCATION چک I-LOCATION به دنیا آمد .

در این پژوهش روش‌های تضحیص خودکار موجودیت‌های نام‌دار در متن معرفی  شده و یکی از آن‌ها برای زبان فارسی پیاده‌سازی و آزمایش خواهد شد.

#  مقدمه

**مسئله چیست؟**
موجودیت‌های نام‌دار عبارتند از کلماتی که در جهان واقع مصداق و عینیت دارند. به طور مثال میتوانند یک شخص مثل ابوعلی سینا باشد و یا نام یک مکان مثل شهر تهران.
به طور دقیق‌تر:
> به کلمه و یا عبارتی گفته می‌شود که برای ارجاع به نمونه‌های یک مقوله‌ی مشخص مانند شخص، شرکت یا مؤسسه، تاریخ، بیماری، گونه‌ای باکتری و سایر بکار می رود. [4]

اما مسئله این است که موجودیت‌های نام‌دار از یک سند الکترونیکی به صورت خودکار توسط ماشین بیرون کشیده شوند و در دسته‌های معنایی موردنظر و مربوط به خودشان قرار داده شوند. البته این که سیستم چه نوع موجودیتی را تشخیص دهد و یا به بیان دیگر دسته‌های معنایی مورد نظرش چه باشند بستگی به زمینه کاربردی سیستم دارد.

**چه کاربردهایی دارد؟**
حجم فراوان اطلاعات موجود در اسناد الکترونیکی بر روی صفحات وب می‌تواند پاسخگوی بسیاری از سوالاتی که در هر زمینه‌ای پرسیده می‌شوند باشد. تشخیص و گروه‌بندی موجودیت‌های نام‌دار با کمک به تسریع و دقیق‌تر کردن جستجوهای معنادار، ترجمه ی خودکار مفاهیم متن، کشف ارجاعات در متن و بسیاری دیگر از زمینه‌های مربوط به پردازش زبان‌های طبیعی، ما را در ارزیابی اطلاعات و یافتن پاسخ سؤالات پرسیده شده یاری می رساند.[4]

#  کارهای مرتبط
در دیگر کارهای انجام شده در این زمینه؛بیشتر روش‌های آماری به عنوان روش اصلی استفاده شده‌اند و روش‌های دیگر به صورت مکمل و جهت بهبود نتیجه بکار رفته‌اند. در ذیل به معرفی مختصر این روش‌ها می‌پردازیم.

**روش‌های آماری:**
در این روش هدف تخمین‌زدن احتمال وقوع a  با محتوای b است ((P(a,b) . که محتوا در مسائل مربوط به پردازش زبان طبیعی کلمات است که بستگی به نوع مسئله می‌تواند یک کلمه یا عبارتی چندکلمه‌ای باشد.
ابتدا با متن هایی که به وسیله‌ی انسان به شیوه‌ی شروع – داخل – خارج برچسب‌گذاری شده‌اند، ماشین را آموزش می‌دهیم. با یادگیری از طریق این داده‌ها ماشین به تشخیص خودکار موجودیت‌های نام‌دار در متن می‌پردازد.

مثالی از یک جمله برچسب‌زده شده توسط روش شروع-داخل-خارج:

    American Airlines, a unit of AMR Corp., immediately matched the move, spokesman Tim Wagner said.
    American          B-ORG
    Airlines          I-ORG
    a                 O
    unit              O
    of                O
    AMR               B-ORG
    Corp              I-ORG
    .                 O
    immediately       O
    matched           O
    the               O
    move              O
    spokesman         O
    Tim               B-PERS
    Wagner            I-PERS
    said              O
    .                 O

برای یادگیری ماشین از متن‌های ورودی از راه‌های مختلفی استفاده می‌شود، از جمله روش پنهان مارکوف، روش به‌هم‌ریختگی بیشینه و روش CRFs .

**روش مبتنی بر مدل پنهان مارکوف: **
این الگوریتم برای برچسب‌زنی یک دنباله از اشیا استفاده می‌شود، در این روش ابتدا دنباله‌ای از اشیا دیده می‌شود و چون مقوله‌ای که باید اشیا دیده شده را برحسب آن برچسب‌زنی کرد از دید ماشین پنهان است به آن مدل پنهان می‌گوییم.

**روش‌های بر مبنای قاعده:**
در این روش موجودیت های اسمی را با استفاده از مؤلفه هایی که در ظاهر این عبارات ممکن است موجود باشد تشخیص میدهند. برای مثال در زبان انگلیسی دو حرف بزرگ در مجاور هم احتمالا یک اسم خواهد بود و یا عباراتی که در آن ها کلمات و یا حروفی از قبیل Dr. ویا Mr.  شروع میگردد و یا به حروفی از قبیل MD خاتمه می یابد احتمالا اسم یک شخص خواهد بود. (NER-Report) 

**روش مبتنی بر عبارات با قاعده:**
در این روش می توان موجودیت هایی را که ساختاری ثابت و منظم دارند تشخیص داد. به طور مثال عبارت باقاعده ی زیر را می توان برا تشخیص ایمیل استفاده کرد:

[`A-Za-z0-9](([_\.\-]?[a-zA-Z0-9]+)*)@([A-Za-z0-9]+)(([\.\-]?[a-zA-Z0-9]+)*)\.([A-Za-z]{2,})`
تاریخ شماره تلفن کدپستی از جمله دیگر مواردی هستند که با این روش میتوان آن ها را تشخیص داد.

#  آزمایش‌ها‌های بر مبنای قاعده:**
در این روش موجودیت های اسمی را با استفاده از مؤلفه هایی که در ظاهر این عبارات ممکن است موجود باشد تشخیص میدهند. برای مثال در زبان انگلیسی 
دو حرف بزرگ در مجاور هم احتمالا یک اسم خواهد بود و یا عباراتی که در آن ها کلمات و یا حروفی از قبیل Dr. ویا Mr.  شروع میگردد و یا به حروفی از قبیل MD خاتمه می یابد احتمالا اسم یک شخص خواهد بود. (NER-Report) 
یکی از راه های بدست آوردن قواعد در کلمات و یا جملات استفاده از عبارات با قاعده است. عبارات با قاعده به ما کمک میکند تا  موجودیت هایی که ساختاری ثابت و منظم دارند تشخیص داده شوند.  به طور مثال عبارت باقاعده ی زیر را می توان برای تشخیص ایمیل استفاده کرد:

    [`A-Za-z0-9](([_\.\-]?[a-zA-Z0-9]+)*)@([A-Za-z0-9]+)(([\.\-]?[a-zA-Z0-9]+)*)\.([A-Za-z]{2,})`

تاریخ شماره تلفن کدپستی از جمله دیگر مواردی هستند که با این روش میتوان آن ها را تشخیص داد.

**روش مبتنی بر مدل پنهان مارکوف:**
مدل پنهان مارکوف در ریاضی به شکل زیر تعریف می شود:
   
    λ = (A, B, π)
A: پارامتر نشان دهنده احتمال انتقال بین دو وضعیت
B: احتمال انتشار
π:احتمال شروع با هر  وضعیت
در این روش که یکی از روش های آماری است ابتدا با استفاده از فرمول ها و الگوریتم هایی که در ادامه معرفی می شوند پارامترهای معرفی شده در تعریف این روش را بدست می آوریم. سپس با استفاده از الگوریتم ویتربی  ترتیبی از برچسب گذاری ها را با بالاترین احتمال تولید میکنیم.

مراحل استفاده از روش مدل پنهان مارکوف:

1. آماده سازی داده های از قبل برچسب گذاری شده:در این گام  متنی به عنوان نمونه به وسیله انسان برچسب گذاری میشود.
2. محاسبه پارامترهای این مدل:

start probability(π) = (Number of sentences start with particular tag)/(Total number of sentences in corpus)
Input: Annotated Text File
Output: Start Probability vector
Algorithm:
	for each starting tag
			find frequency of that tag as starting tag
	calculate π

Transition probability(A) = (Total number of sequences from Ti to Tj)/(Total number of Ti)
Input: Annotated  text file
Output: Transition probability matrix
Algorithm:
	For each tag in states(Ti)
			For each other tag in states(Tj)
						Find frequency of tag sequence Ti Tj
			Calculate A
		
Emission probability(B) = (Total number of occurrence of  word as a tag)/(Total occurrence of that tag)
Input: Annotated Text file
Output: Emission probability matrix
Algorithm:
For each unique word Wi in Annotated corpus
	Find frequency of word Wi as a particular tag Ti
	Divide frequency by frequency of that tag Ti
	
3. حال پارامترهای بدست آمده را با الگوریتم ویتربی روی متنی که میخواهیم پردازش شود اعمال میکنیم و برچسب گذاری منطبق بر موجودیت ها را بدست می آوریم.
 
**الگوریتم ویتربی:**
فرض کنید یک سری حالت داریم که وضعیت آن ها نامعلوم است. این الگوریتم با کمک گرفتن از پارامترهای بدست آمده از مدل پنهان مارکوف محتمل ترین ترتیب از وضعیت ها را برای این سری از حالات ارایه میدهد. به این صورت که با در نظر گرفتن یک گراف و داشتن احتمال انتقال بین گره ها که همان پارامترهای مارکوف هستند تگ هر کلمه وضعیت گرهی است که به هنگام بررسی آن کلمه در آن گره قرار داریم. اول متن با گره شروع در گراف آغاز میشود. بنابر احتمالات آغازین به گره بعدی میرویم. کلمه اول و گره کنونی را بررسی کرده یک تگ پیشنهاد میشود. بعد به گره بعدی رفته و با کلمه بعد آن را بررسی میکنیم. 

#  آزمایش‌ها

روش انتخاب شده در این پروژه استفاده از روش های مبتنی بر قاعده و مدل مارکوف به همراه هم هست. که ابتدا هر یک را به صورت جدا گانه پیاده سازی کرده و سپس آن ها را ترکیب می کنیم.
پیاده سازی آزمایش های مختلف این پروژه در آدرس زیر قرار گرفته است:
[پروژه تشخیص موجودیت های نامدار در متن فارسی](https://github.com/Mohammad-Eslahi-Sani/Farsi-Named-Entity-Recognition)

**آزمایش اول: استفاده از روشهای ساده**
*مراحل تئوری:*
+ کلمات دریافتی را به فعل و اسم و حرف دسته بندی میکنیم؛ اسم ها را برای مرحله بعد کاندید میکنیم.
+ قواعد از پیش طراحی شده را به روی اسامی اعمال میکنیم؛ برای تعدادی از اسم ها تگ پیشنهاد خواهد شد.
+ با مطابقت دادن اسامی با آموزه های قبلی ماشین تگ های بیشتری برای اسامی پیشنهاد می شوند.
+ تمامی تگ ها ذخیره و نمایش داده میشوند تا در مراحل بعدی تصمیم بگیریم که چگونه تگ بهتر را تشخیص بدهیم.

**مرحله اول:**
برای این مرحله از ماژول هضم استفاده میکنیم. جمله ای را از ورودی گرفته و آن را تگ گذاری میکنیم.

	#! -- encoding: utf-8
    from __future__ import unicode_literals
    from hazm import *
    
    normalizer = Normalizer()
    out_file = open('out.txt','w')
    s = 'این یک متن فارسی است. که به سختی پردازش می شود.'
    out_file.write('\n')
    out_file.write(s.encode('utf8'))
    out_file.write('\n')
    s = normalizer.normalize(s)
    tagger = POSTagger(model='resources/postagger.model')
    a = tagger.tag(word_tokenize(s))
    for i in a:
    	for j in i:
    		out_file.write(j.encode('utf8'))
    		out_file.write('\t')
    	out_file.write('\n')
    in_file.close()
    out_file.close()
پاسخ بدست آمده در فایل خروجی به شکل زیر است:
این یک متن فارسی است. که به سختی پردازش می شود.
 

		    این PRO	
		    یک NUM	
    متن      Ne	
    فارسی      N	
    است      V	
    .      PUNC	
    که      CONJ	
    به      P	
    سختی      N	
    پردازش      N	
    می‌شود      V	
    .      PUNC

بدین ترتیب جمله ورودی تگ گذاری می شود و جملاتی که تگ آن ها N است برای مرحله بعد کاندید میشوند.

**مرحله دوم:**
قواعدی را طراحی میکنیم سپس به روی اسامی اعمال میکنیم.

#  کارهای آینده**آزمایش دوم: مدل پنهان مارکوف ٰ**
**مرحله اول:**
با استفاده از یک متن که از قبل تگ گذاری شده و الگوریتمی که در قسمت توضیح روش مدل پنهان مارکوف آمد پارامترهای مارکوف را بدست می آوریم.
**مرحله دوم:**
الگوریتم ویتربی روی متن اعمال شده و برای هر کلمه تگی پیشنهاد میشود.

**آزمایش سوم: استفاده ترتیبی از روش های مبتنی بر قاعده و مدل مارکوف**
در این آزمایش ابتدا با استفاده از قواعد که در آزمایش اول توضیح داده شدند یک مجموعه پیشنهادی تگ گذاری برای متن داده میشود. سپس در استفاده از مدل مارکوف این تگ ها را در نظر میگیرم. به این صورت که در برخورد با کلماتی که از قبل تگ گذاری شده اند به گره مربوط به آن ها پرش کرده و از مارکوف برای بررسی کلمه بعدی و رفتن به گره بعدی استفاده میکنیم.

#  کارهای آینده
**استفاده ترکیبی از روش های مبتنی برقاعده و مدل مارکوف**
 برای بهبود و افزایش کارایی میتوان قواعد را به عنوان گره به گراف حاصل از مدل مارکوف اضافه کرد.. در این صورت با مشاهده این قواعد به گره مربوط به آن ها رفته  و سپس با بررسی احتمالات برای کلمات تگ پیشنهاد می شود.
استفاده از دیکشنری جامع تر و قوانین دقیق تر و بیشتر نتایج کار را بهبود می بخشند.

#  مراجع

1.  Jurafsky, Daniel, and James H. Martin. 2009. Speech and Language  Processing: An Introduction to Natural Language Processing, Speech  Recognition, and Computational Linguistics. 2nd edition. Prentice-Hall.
2.  Nadeau, David, and Satoshi Sekine. "A survey of named entity  recognition and classification." Lingvisticae Investigationes 30.1  (2007): 3-26.
3.  M. Asgari Bidhendi, et al., "Extracting person names from ancient  Islamic Arabic texts", in Proceedings of LREC-Rel, pp. 1-6, 2012.
4.  پونه سادات مرتضوی، مهرنوش شمس فرد، "شناسایی موجودیت های نام دار در  متون فارسی"، پانزدهمین کنفرانس بین المللی سالانه انجمن کامپیوتر ایران،  1388
5. شهناز پناهی, فرهاد عابدینی, "روشی جدید برای استخراج موجودیت های نام دار", اولین همایش منطقه ای رویکرد های نوین در مهندسی کامپیوتر و فناوری اطلاعات, ۱۳۹۰

#  پیوندهای مفید

+ [تشخیص موجودیت‌های نام‌دار، پروژه درس هوش مصنوعی نیمسال دوم ۸۹-۸۸ دانشگاه علم و صنعت](http://bayanbox.ir/id/6189680504542343855?download)
+ [تشخیص موجودیت‌های اسمی در متن، پروژه درس هوش مصنوعی نیمسال اول ۹۲-۹۱ دانشگاه علم و صنعت](http://bayanbox.ir/id/1685090304266467232?download)
+ [سیستم شناسایی و طبقه بندی اسامی در متون فارسی](http://www.sid.ir/FA/VEWSSID/J_pdf/35213891306.pdf)
+ [پردازش زبان فارسی در پایتون](http://www.sobhe.ir/hazm)
+ [کتابخانه ابزار یادگیری ماشین برای پایتون](http://scikit-learn.org/stable/)
+ [Named Entity Recognition with NLTK](http://nltk.org/book/ch07.html#named_entity_recognition_index_term)
+ [Stanford Named Entity Recognizer(NER)](http://nlp.stanford.edu/software/CRF-NER.shtml)