پیدا کردن آیات قرآن در متون

تغییرات پروژه از تاریخ 1393/04/01 تا حالا
![ان هذا القران یهدی للتی هی اقوم ](http://farhangi.um.ac.ir/portal/sites/default/files/images/logo%20%D8%B1%D9%86%DA%AF%DB%8C.jpg)
#مقدمه
 به دلیل به هم خوردگی متن فایل pdf آن در پایین ضمیمه شده است.

با توجه به پیشرفت تکنولوژی و ابزارهای لازم در جهت برآورد نیازهای بشر من قبیل کامپیوتر، اینترنت و ... مشکل اساسی در این مقطع زمانی با توجه به محدودیت های استفاده از این ابزارها افزونگی داده ها می باشد که مشکلات عدیده ای را به همراه دارد.
برای نمونه امکان دسترسی اطلاعات به این پایگاه عظیم داده ای گاهی دشوار و گاهی غیر ممکن به نظر می رسد.
محققان و دست اندرکاران حوزه ی فناوری اطلاعات و علوم کامپیوتر در سراسر این کره خاکی دست به کار شده و امکانات زیادی را در جهت دسترسی آسان و به طور خاص مطمئن در این زمینه فراهم کردند.
امکاناتی نظیر طبقه بندی اطلاعات بر اساس محوریت موضوعی ، محتوایی و ... در جهت جستجو و دسترسی آسان و بی دغدغه به دور از صرف هزینه گزاف و اتلاف وقت از جمله این کارها در جهت این اهداف محقق شده است.
حال چگونگی دسترسی به این اطلاعات مطرح می شود که در این مقدمه سعی شده تا مفهومی نزدیک به ذهن مخاطب ارائه گشته و روند کار به طور واضح مشخص شود.
در حوزه علوم اسلامی در سال های اخیر در جهت تسهیل کار طلاب علوم اسلامی و پیشبرد سریع تر اهداف حوزه های علوم اسلامی کتاب های ایشان که محتوای درسی و پژوهشی داشته و علی الخصوص کتب معتبر شیعه از منظر روایات ، تفاسیر و ... به نرم افزارهایی در حوزه ی دیجیتالی مبدل گردیده است.
از این رو کار با این نرم افزارها باعث تسهیل در روند پژوهشی – آموزشی شده و ارتقای سطح کمی و کیفی مطالعات را به دنبال داشته است.
حال در جهت این مهم سعی شده است تا امکانات اصلی و قطعی در امر مطالعات برای این نرم افزارها در نظر گرفته شود ؛ یکی از این امکانات جستجوی پیشرفته در متون می باشد.
این امکان را در سطوح معمولی و بسیار ساده بسیاری از نرم افزار ها پشتیبانی می کنند ، به این صورت که کاربر کلمه ای را جستجو کرده و در متن مورد نظر تمامی عباراتی که آن کلمه را دارا می باشند گشته و آن کلمه را پیدا می کند اما گاهی اوقات کاربران نیاز به دسترسی پیشرفته تری در موضوعات مختلف دارند ، به عنوان مثال کاربر می خواهد آیات قرانی موجود در متن را بررسی کند.
به این منظور نیاز به سیستم هوشمندی است که بتواند بر اساس نیاز کاربر به این مهم پاسخ دهد.

#پیشینه کار و کارهای مشابه
از آنجایی که عملیات پردازشی سیستم تشخیص آیات قرآنی در حیطه الگوریتم های تطبیق الگو (تطبیق رشته) قرار دارد در این بخش سیستم های تطبیق الگو را معرفی کرده و انواع الگوریتم ها و کاربرد های آن ها را شرح می دهیم.
تطبیق الگو
تطبیق الگو به دنبال پیدا کردن تمامی رخدادهای یک الگوی خاص در یک متن ورودی است،به طور کلی هر الگو توصیفی از یک مجموعه رشته است و هر رشته نیز از یک دنباله از نمادها تشکیل شده است.از این رو برای یک الگو علاوه بر محل وقوع الگوها تعداد وقوع الگوها نیز جستجو می شود.
الگوریتم های تطبیق الگو دو هدف عمده دارند:
1- کاهش تعداد کاراکترهایی که نیاز است مورد مقایسه قرار گیرند (در بدترین حالت و حالت متوسط)
2- کاهش زمان مورد نیاز در بدترین حالت و حالت متوسط
تطبیق رشته
یکی از مهم ترین و پرکاربردترین زمینه های تطبیق الگو است که در آن الگوها رشته هایی از کاراکترها هستند که باید در یک متن ورودی که شامل دنباله ای از رشته هاست یافت شوند.
الگوریتم های تطبیق الگو دو مرحله مختلف دارند:
1- مرحله پیش پردازش یا مطالعه الگو 
2- مرحله پردازش یا جستجوی الگو
در مرحله پیش پردازش اطلاعات کاملی درباره الگو جمع آوری شده و از این اطلاعات برای بهینه کردن تعداد مقایسه ها استفاده می شود ،حال آنکه مرحله جستجو الگو را به وسیله اطلاعاتی که در مرحله قبلی جمع آوری شده است پیدا می کند.
دسته بندی الگوریتم های تطبیق رشته
در حال حاضر الگوریتم های تطابق رشته زیادی وجود دارد که هر یک برای کاربردی مفید است،محققین از جنبه های گوناگون این الگوریتم ها را مورد مطالعه قرار داده و به همین جهت دسته بندی های متنوعی برای الگوریتم های تطبیق رشته ارایه شده است.
الف) بر اساس نیاز یک متن یا الگو به مرحله پیش پردازش
1- الگوریتم های تطبیق رشته برخط
2- الگوریتم های تطبیق رشته اندیسی
ب) بر اساس طول الگو
1- تطبیق پیشوندی
2- تطبیق پسوندی
ج) بر اساس نوع پیدا کردن
1- تطبیق رشته دقیق 
2- تطبیق رشته نسبی
د) بر اساس تعداد الگو های مورد جستجو در متن
1- تطبیق تک الگویی 
2- تطبیق چند الگویی
اشاره (!)
تطبیق رشته دقیق الگو را به طور دقیق در متن پیدا کرده و تطبیق رشته نسبی تمام الگوهای مشابه را در متن پیدا می کند.
اگر یک الگوی خاص در متن مورد جستجو قرار گیرد تطبیق تک الگویی و اگر نیاز به جستجوی بیشتر از یک الگو در متن باشد تطبیق چند الگویی (چند گانه) خواهد بود،تطبیق چند الگویی می تواند هم زمان چند الگو را در متن بیابد.
مهم ترین الگوریتم های تطبیق رشته 
Aho-Corasick ، KMP ، Boyer-Moore  (BM) ،  Horspool ،  Boyer  Moore  Horspool  (BMH) ، Zhu  Takaoka ، Quick  Search ،
Berry  and  Ravindran(BR) ، SBOM  (Set  Backward  Oracle  Matching) ، Wu – Manber ، Fast Searching ، ZTMBH ، BRBMH SOG  and …
تطبیق رشته دقیق 
الگوریتم های تطبیق رشته دقیق سعی در پیدا کردن تمام مکان های وجود (تکرار) یک الگو در یک متن ورودی دارند.
مسئله تطبیق الگوی دقیق را می توان این طور تعریف کرد:
الگوی p  با طول m  و رشته T  با طول  n   (m<=n) را در نظر می گیریم.
کار اصلی پیدا کردن تمام رخداد های p  در رشته T  است به طوری که تطابق ها باید دقیق باشند یعنی باید دقیقا همان الگو در متن پیدا شود. نحوه کار الگوریتم های تطبیق دقیق رشته بدین صورت است که از سمت راست الگو و متن شروع به جستجو می کند در مواردی که یک عدم تطابق یا تطابق کامل یافت شود با استفاده از برخی ملاحظات الگو را به سمت راست انتقال داده و همین مراحل تکرار می شود تا زمانی که الگو به پایان سمت راست متن برسد.
 تطبیق رشته نسبی
تطبیق الگوی غیر دقیق گاهی تطبیق رشته نسبی یا تطبیق با K  عدم تطابق هم نامیده می شود. در این روش متنی که به صورت تقریبی با الگو تطابق داشته باشد پیدا می شود.
تطبیق رشته نسبی به این صورت تعریف می شود:
 الگوی p  با طول m  و رشته T  با طول n   (m<=n) را در نظر می گیریم.
کار اصلی پیدا کردن تمام رخداد های زیر رشته X   درT  است که به P شبیه هستند البته برای شباهت معیاری وجود دارد مثلا گفته می شود که تفاوت زیر رشته با P ، K  کاراکتر باشد. این گونه الگوریتم ها معمولا از دو قسمت تشکیل می شوند : 
پیدا کردن تقریب مناسب برای این که بتوان بر آن تکیه کرد و بعد پیدا کردن تطبیق تقریبی الگو با قسمتی از متن.
الگوریتم های تطبیق الگوی نسبی به 4 گروه تقسیم می شوند که عبارتند از:
1- روش برنامه نویسی پویا
2- روش اتوماتا
3- روش تقارن بیتی
4- روش فیلترکردن و خودکارسازی
تطبیق تک الگویی
مسئله تطبیق تک الگویی رشته را می توان به صورت زیر تعریف کرد:
فرض کنید T  رشته بزرگی است که از n  کاراکتر تشکیل شده است و P  یک الگو با اندازه ی m  باشد.
: الگو  P = P[1]P[2]………P[m]
 : متنT = T[1]T[2]………T[n]
کاراکتر های هر دو مجموعه P  و T  به یک مجموعه متناهی از عناصر مجموعه S  تعلق دارد که m<<n  است. فرایند جستجوی تک الگویی تمام رخدادهای موجود از الگوی P  را در متن T  نمایان می کند.
تطبیق چند الگویی
مسئله تطبیق چند الگویی (چندگانه) به شکل زیر تعریف می شود:
با فرض مجموعه ای از الگوهای  P = {p1,p2,…,pn}که در آن هر pi یک الگوی عبارت منظم از مجموعه الفبای ∑ است مسئله تطبیق چندالگویی عبارت است از پیدا کردن تمام رخداد های این الگوها در مجموعه داده D  با الفبای یکسان.
الگوریتم های تطبیق چند الگویی
الگوریتم های متعددی برای تطبیق چند الگویی به کار رفته است که می توان آنها را به دو گروه کلی تقسیم کرد:
1- الگوریتم های مبتنی بر درخت
2- الگوریتم های مبتنی بر فیلترکردن
الگوریتم های مبتنی بر درخت
راه حل اصلی این الگوریتم ها ساخت درختی از الگو ها و جستجوی متن با کمک این درخت است. مشکل اصلی این الگوریتم ها این است که به همان سرعت که مجموعه الگوها بزرگ می شود درخت نیز به سرعت رشد می کند و نیاز به فضای بیشتری دارد. به همین دلیل برای مجموعه الگوهای بزرگ استفاده از این روش چندان مؤثر نیست.
الگوریتم های مبتنی بر فیلترکردن
ایده اصلی این الگوریتم ها این است که یک موقعیت در متن در نظر گرفته می شود و توسط یک فیلتر مشخص می شود که آیا در این مکان یک تطبیق با الگو وجود دارد یا نه.
تطبیق دقیق چند الگویی
الگوریتم های تطبیق دقیق چند الگویی به طور کلی به دو دسته تقسیم می شوند:
1- الگوریتم های مبتنی بر جدول انتقال
2- الگوریتم های مبتنی بر ماشین خودکار 
الگوریتم های مبتنی بر جدول انتقال از چند جدول از قبل محاسبه شده استفاده می کنند تا موقعیت مناسب بعدی را که الگو ممکن است در آن جا اتفاق بیفتد مشخص می کنند.
روش های مبتنی بر ماشین خودکار از یک نمایش مبتنی بر DFA  یا NFA  برای نشان دادن عبارات منظم استفاده می کنند. از آن جایی که نمایش NFA  تحت تاثیر مباحث ذخیره سازی است معمولا کندتر از DFA  است.
الگوریتم های تطبیق رشته
در این مجال برخی از الگوریتم های تطبیق رشته را که پایه و اساس دیگر الگوریتم ها به شمار می روند شرح می دهیم:
1- الگوریتم جستجوی رشته نیو (Naive) 
آسان ترین و ناکارآمدترین راه برای آن که یک رشته و مکان آن را در یک متن پیدا کنیم امتحان کردن یک به یک همه مکان هایی است که آن رشته می تواند قرار بگیرد.
در صورتی که متنی به طول n  به صورت T[1…n] و رشته به طول m  به صورت P[1…m] داشته باشیم که m<=n  الگوریتم نیو همه حالت های ممکن را به این صورت بررسی می کند :
در هر مرحله رشته P[1…m] با زیر رشته ای از متن T مقایسه می گردد. زیر رشته مورد نظر در مرحله اول از متن T[1…m] ، در مرحله دوم m حرف دوم از متن T[2…m+1]  و به همین ترتیب در مرحله s  ام  m حرف s  ام از متن  T[s+1…s+m] می باشد. در این مقایسه ها هر بار که دو رشته مقایسه شده یکسان باشند نشانگر یک بار رخ دادن رشته P  در متن T  است.
شبه کد جستجوی رشته نیو
procedure NaiveStringMatcher (T,P) 
begin 
n=lenght(T); 
m=lenght(P); 
for s=0 to n-m do 
if P[1...m]=T[s+1...s+m] then 
print «Pattern occurs with shift» s; 
end 
2- الگوریتم KMP 
معروف ترین الگوریتم تطبیق رشته و دارای زمانی خطی است، که سه تن از محققان (Donald Knuth, Vaughan Pratt, James H. Morris) این الگوریتم را به طور مجزا ایجاد نمودند.
این الگوریتم در میان رشته S  وجود کلمه W  را بررسی می کند که برای این کار محل عدم تطابق کلمه را زیر نظر می گیرد تا با استفاده از آن بتواند اطلاعاتی را درباره مکان تطابق احتمالی بعدی به دست آورد. به طوری که وقتی یک عدم تطابق اتفاق می افتد خود کلمه اطلاعات کافی را در بر دارد تا محلی را که مطابقت بعدی ممکن است از آن جا شروع شود با آزمایش دوباره حروف تطبیق داده شده قبلی تعیین کند.
الگوریتم جستجوی KMP 
While m+i is less than the length of S, do: 
If W[i] = S[m + i], 
If i equals the (length of W)-1, 
Return m 
Let i ←i + 1 
otherwise, 
let m ←m + i - T[i], 
if T[i] is greater than -1, 
let i ←T[i] 
else
let i ←0
اگر به این نقطه رسیدیم نتوانسته ایم تمام طول S  را  با موقعیت جستجو کنیم
Return the length of S
جدول تطابق جزئی (عمل شکست)
هدف از ساختن این جدول آن است که الگوریتم هیچ کاراکتری از S  را بیش از یک بار مطابقت ندهد.

مثالی از جدول تطابق جزئی الگوریتم KMP

(http://www.uploadax.com/images/72518545826998356990.bmp)



الگوریتم kmp_table
Let T[0] ←-1, T[1] ←0 
While pos is less than the length of W, do: 
(first case: the substring continues) 
If W[pos - 1] = W[cnd], 
Let cnd ←cnd + 1, T[pos] ←cnd, pos ←pos + 1 
(second case: it doesn't, but we can fall back) 
otherwise, if cnd > 0, let cnd ←T[cnd] 
(third case: we have run out of candidates. Note cnd = 0) 
otherwise, let T[pos] ←0, pos ←pos + 1
3- الگوریتم Boyer-Moore
این الگوریتم مبتنی بر تطبیق دقیق تک الگویی است. این الگوریتم الگو و متن را از راست به چپ مقایسه می کند. در مواردی که یک عدم تطابق یا تطابق کامل اتفاق بیفتد الگوریتم از دو تابع انتقال استفاده می کند تا مکان شروع مقایسه بعدی را محاسبه کند. توابع انتقال الگوریتم بویر -  مور که برای کم کردن تعداد مقایسه ها به کار می روند عبارتند از:
•   Bad Character  
•   Good Suffix
Bad Characteri (I
در این حالت تابع occ را داریم که برای هر کاراکتر موجود در الفبا اندیس سمت راست ترین موقعیت رخداد آن کاراکتر را در الگو محاسبه می کند و اگر آن کاراکتر در الگو نباشد مقدار 1- را برای آن کاراکتر تخصیص می دهد.
تابع bmInitocc تابع رخداد را برای الگوی P  محاسبه می کند.
void bmInitocc() 
{ 
char a; 
int j; 
for (a=0; a<alphabetsize; a++) 
occ[a]=-1; 
for (j=0; j<m; j++) 
{ 
a=p[j]; 
occ[a]=j; 
} 
}
 Good Suffix (II
در این روش از یک آرایه به نام s  استفاده می شود که مقدار هر درایه آن (s[i]) مقدار انتقال الگو است. اگر یک عدم تطابق در موقعیت  i-1رخ دهد. برای مشخص کردن مقدار انتقال دو حالت به وجود می آید:
حالت 1 : قسمت تطابق یافته از الگو در جای دیگری از الگو رخ داده باشد.
حالت 2 : فقط قسمتی از قسمت تطابق یافته در جای دیگری از الگو رخ داده باشد.
(http://www.uploadax.com/images/63554025687579014093.bmp)

مرحله جستجو
در مرحله جستجو الگو ها از چپ به راست با متن مقایسه می شوند. بعد از یک تطابق کامل الگو میزان انتقال برابر با بیشترین مقادیری است که از توابع good-suffix و bad-character  به دست آمده است.
Boyer-Moore searching algorithm 
void bmSearch() 
{ 
int i=0, j; 
while (i<=n-m) 
{ 
j=m-1; 
while (j>=0 && p[j]==t[i+j]) j--; 
if (j<0) 
{ 
report(i); 
i+=s[0]; 
} 
else 
i+=Math.max(s[j+1], j-occ[t[i+j]]);
} 
}
4- الگوریتم Boyer Moore Horspool	
این الگوریتم نسخه ساده شده الگوریتم بویر- مور است. این الگوریتم مقایسه ها را از سمت راست ترین کاراکتر شروع کرده و الگو را به راست حرکت می دهد. در مواردی که عدم تطابق یا تطابق کامل وجود داشته باشد این الگوریتم فقط از تابع انتقال Horspool  bad استفاده می کند.
5- الگوریتم Aho-Corasick
بسیاری از الگوریتم های تطابق رشته همانند الگوریتم KMP یا Boyer Moore برای جست و جوی یک رشته الگو در میان یک متن استفاده می شوند و مکان تکرار آن را در آن متن مشخص می کنند. ولی در برخی کاربردها نیاز به پیدا کردن بیش از یک رشته الگو در داخل یک متن داریم. الگوریتم آهوکوراسیک (AC) یک الگوریتم تطابق رشته ای چندگانه (تطابق چند الگویی) است که توسط آلفرد وی آهو و مارگارت جی کوراسیک ارایه شده است.
6- الگوریتم جستجوی Rabin – Karp 
این الگوریتم برای پیدا کردن مجموعه ای از رشته ها (الگوها) در یک متن از درهم سازی استفاده می کند. این کار در دو مرحله پیش پردازش و تطابق انجام می گیرد. این الگوریتم می تواند با سرعت بالا جمله ای را در بین مقالات مختلف بدون در نظر گرفتن بزرگی و کوچکی و اعراب جستجو کند.
ایده اصلی در الگوریتم رابین – کارپ این است که این الگوریتم سعی دارد با به کارگیری تابع درهم سازی سرعت مقایسه رشته الگو و زیر رشته های متن را افزایش داده و از این طریق زمان اجرا را بهبود بخشد.
تابع درهم سازی
یک تابع درهم سازی تابعی است که مجموعه بزرگی از داده ها را به مجموعه کوچکتری از داده ها نگاشت می کند. در این جا تابع درهم سازی هر رشته را به یک مقدار عددی که به آن مقدار درهم سازی می گویند تبدیل می کند. برای مثال اگر تابع را برابر طول رشته تعریف کنیم  hash("hello")=5 و hash("cat ")=3  خواهد بود.
الگوریتم رابین – کارپ به جای مقایسه حرف به حرف دو رشته مقادیر درهم سازی آنان را مقایسه می کند.
شبه کد الگوریتم Rabin – Karp
procedure Rabin-Karp-Matcher (T,P,d,q) 
begin 
n = lenght(T); 
m = lenght(P); 
h = d^(m-1) mod q; 
p = 0; 
t = 0; 
for i = 1 to m do // Preprocessing 
p = (d*p + P[i]) mod q; 
t = (d*t + T[i]) mod q; 
for s = 0 to n-m do // Matching 
if p = t then 
if P[1...m] = T[s+1...s+m] then 
print «Pattern occurs with shift» s; 
if s < n-m then 
t = ( d * (t - T[s+1]*h ) + T[s+m+1] ) mod q; 
end
روش های اندیسی
الگوریتم های مبتنی بر اندیس یک نوع از الگوریتم های سریع تطبیق رشته مبتنی بر پیش پردازش متن هستند ، اساس این روش ها بر اندیس گذاری متن و الگو است.
7- الگوریتم SKIP SEARCH
در این الگوریتم دو جدول اندیس یکی برای الگو و دیگری برای رشته ورودی تعریف شده و جستجو از طریق مقایسه اندیس های این جداول انجام می شود.
شبه کد الگوریتم SKIP SEARCH
ورودی: رشته S  شامل n  کاراکتر و یک الگوی P شامل m کاراکتر
خروجی: تعداد رخدادهای و مکان های الگوی P در رشته S  

Algorithm: 
N=length of the string, M=length of the pattern. 
S= String ,P=Pattern 
Struct bucket { 
int *a; //for storing the index of letters. 
int count; //store total no occurrences of the} 
Str_buck[4], Ptr_buck[4] //for storing the indexes of the letters A,C,T and G 
Index //index of the letter chosen with minimum count. 
1) Pre-Processing Phase 
//Store the index of the pattern 
1.Loop for i=1 to i=N 
Str_buck[A,C,T,G].a[i]=i ;
Str_buck[A…T].cout+=1; 
//Store the index of the pattern 
2.Loop for i=1 to i=M 
Ptr_buck[A,C,T,G].a[i]=i ; 
Ptr_buck[A…T].cout+=1; 
3. Find Index for which 
((Str_buck[A..T].count)*(Str_buck[A…T].count) is minimum; 
Assign , 
mini_scount=Str_buck[Index].count mini_pcount=Ptr_buck[Index].count 
2) Searching Phase 
LOOP1 i=1 to i=mini_scount 
q=S[Index].a[i] 
LOOP2 j=1 to j=mini_pcount 
IF (q>=Previous Pattern Index + Position of jth Char in Pattern) 
t=Str_buck[index].a[index]-Ptr_buck[index].a[index]; 
//t store the starting position from where it starts comparison in the string. 
LOOP3 k=1 to k=M 
Compare (S[t++],P[k]) until a mismatch 
occurs or Match Occurs. 
PRINT “Starting Index of the string for the Matched Pattern”. 
END LOOP3 
END LOOP3 
END LOOP1
جدول اندیس های حروف موجود در الگو
(http://www.uploadax.com/images/02286088333229486734.bmp)


مانند الگو اندیس های تمامی مکان های رخداد کاراکترها در رشته ورودی نیز در جدول اندیس ذخیره می شود. بعد از تشکیل این دو جدول یک کاراکتر انتخاب شده و مرحله جستجو آغاز می شود.
جدول اندیس های حروف موجود در رشته ورودی
(http://www.uploadax.com/images/16733399178656057302.bmp)



با توجه به جداول بالا حرف G  انتخاب می شود چون کمترین مقدار حاصل ضرب را دارد 4*1=4 این کاراکتر به عنوان کاراکتر انتخاب شده به مرحله بعدی (جستجو) فرستاده می شود. اگر دو کاراکتر مقدار حاصل ضرب یکسانی داشته باشند کاراکتری انتخاب می شود که مقدار کمتری در جدول اندیس رشته ورودی داشته باشد.
8- الگوریتم K-PARTITIONS
ایده اصلی این الگوریتم تقسیم کردن الگو و رشته ورودی به بخش هایی با اندازه K و مقایسه ترتیبی کاراکتر های هر بخش به جای تمامی کاراکتر هاست تا بتوان از این طریق تعداد مقایسه ها را کاهش داد.
شبه کد الگوریتم K-PARTITIONS
ورودی: رشته S  شامل n  کاراکتر و یک الگوی P شامل m کاراکتر
خروجی: تعداد رخدادهای و مکان های الگوی P در رشته S  
IKPMPM Algorithm
Step 1: Integer arrays indexTab[4][n], charIndex[4] 
Integer found:=1, n_occ:=0, n_cmp:=1, boxes; 
Step 2:  FOR i:=0;i<n;i:=i+1 
indexTab[(S[i]-64)%5][charIndex[(S[i]-64)%5]++]:=i; 
End FOR 
Step 3:FOR i:=0;i<chatIndex[(P[0]-64)%5]; i:=i+1 
found:=1; 
IF i+m-1 > n-1 
found:=0 
End IF 
boxes:=⎡m/BOXSIZE⎤
FOR k:=0;k<BOXSIZE;k:=k+1 
Step 4:FOR j:=0;j<BOXSIZE*boxes;j:=j+BOXSIZE 
IF k+j < m 
n_cmp:=n_cmp+1 
IF P[k+j]=S[i+j+k] 
DO NOTHING 
End IF 
ELSE 
found:=0 
End ELSE 
End IF 
End FOR 
End FOR 
Step 5:   IF found:=1 
n_occ:=n_occ+1 
PRINT “Pattern Found At Location i,Occurrence no is: n_occ” 
End IF 
End FOR
تذکر(!)
با بررسی دو الگوریتم ارایه شده مبتنی بر اندیس در می یابیم که این گونه روش های اندیسی برای مسایل تطبیق الگو که که در آن ها تعداد الفبا کوچک است (مانند تطبیق رشته در دنباله DNA بدن انسان که الفبای آن تنها دارای 4 کاراکتر {A,C,G,T} است) کارامد است.
9- الگوریتم Commentz-Walter
این الگوریتم توابع فیلتر کردن الگوریتم های تطبیق تک الگویی مثل الگوریتم Boyer- Moore  را با یک اتوماتای پسوندی ترکیب می کند تا محل های رخداد الگوهای چندگانه را در متن ورودی جستجو کند.
10- الگوریتم Wu-Manber
این الگوریتم از عمومیت بخشیدن الگوریتم Horspool به دست آمده است و یک نوع ساده از الگوریتم  Boyer- Moore است که فقط از تابع انتقال bad- character  برای تطابق چند الگویی استفاده می کند.
11- الگوریتم Fast Searching
این الگوریتم نوعی از الگوریتم Boyer- Moore است که کاراکتر های الگو و متن را از راست به چپ ب هم مقایسه می کند. در مواردی که عدم تطابق فقط در کاراکتر آخر وجود داشته باشد و یا به تطابق کامل برسیم از تابع bad- character استفاده می کند در غیر این صورت از تابع good suffix  استفاده می کند. این الگوریتم برای الگوهای خیلی کوتاه بازده خوبی دارد.
12- الگوریتم Quick Search
در این الگوریتم جستجو و مقایسه از انتهای رشته شروع شده و تا ابتدا ادامه می یابد. وقتی که یک عدم تطابق یافت شود الگوریتم محل بعدی را که جستجو باید از آن جا آغاز شود مشخص می کند. این الگوریتم برای الگوهای کوتاه با تعداد الفبای بالا بسیار مناسب است.
13- الگوریتم Bitap 
الگوریتم بایتپ الگوریتمی برای تشخیص تطابق تقریبی دو رشته است. این الگوریتم مشخص می کند که در متن ورودی زیر رشته ای وجود دارد که تقریبا با الگوی مورد نظر داده شده برابر باشد.
در ادامه یک پیاده سازی کلی از الگوریتم بایتپ برای جستجوی دقیق الگو در متن به زبان سی ارایه شده است:
#include <stdlib.h> 
#include <string.h> 
typedef char BIT; /* needs only to hold the values 0 and 1 */ 
const char *bitap_search(const char *text, const char *pattern) 
{ 
const char *result = NULL; 
int m = strlen(pattern); 
BIT *R; 
int i, k; 
if (pattern[0] == '\0') return text; 
/* Initialize the bit array R */ 
R = malloc((m+1) * sizeof *R); 
R[0] = 1; 
for (k=1; k <= m; ++k) 
R[k] = 0; 
for (i=0; text[i] != '\0'; ++i) { 
/* Update the bit array. */ 
for (k=m; k >= 1; --k) 
R[k] = R[k-1] && (text[i] == pattern[k-1]); 
if (R[m]) { 
result = (text+i - m) + 1; 
break; 
} 
} 
free(R); 
return result; 
}
توجه کنید در پیاده سازی کلی برای تبدیل شرط (text[i] == pattern[k-1]) به یک عملگر دودویی ، نیاز به یک ماسک دودویی CHAR_MAX داریم:
#include <string.h> 
#include <limits.h> 
const char *bitap_bitwise_search(const char *text, const char *pattern) 
{ 
int m = strlen(pattern); 
unsigned long R; 
unsigned long pattern_mask[CHAR_MAX+1]; 
int i; 
if (pattern[0] == '\0') return text; 
if (m > 31) return "The pattern is too long!"; 
/* Initialize the bit array R */ 
R = ~1; 
/* Initialize the pattern bitmasks */ 
for (i=0; i <= CHAR_MAX; ++i) 
pattern_mask[i] = ~0; 
for (i=0; i < m; ++i) 
pattern_mask[pattern[i]] &= ~(1UL << i); 
for (i=0; text[i] != '\0'; ++i) { 
/* Update the bit array */ 
R |= pattern_mask[text[i]]; 
R <<= 1; 
if (0 == (R & (1UL << m))) 
return (text + i - m) + 1; 
} 
return NULL; 
}
در ادامه پیاده سازی الگوریتم تطبیق نسبی بایتپ ارایه شده است. این الگوریتم اولین زیر رشته ای که حداکثر k  خطا در بر دارد برخواهد گرداند:
#include <stdlib.h> 
#include <string.h> 
#include <limits.h> 
const char *bitap_fuzzy_bitwise_search(const char *text, const char *pattern, intk) 
{ 
const char *result = NULL; 
int m = strlen(pattern); 
unsigned long *R; 
unsigned long pattern_mask[CHAR_MAX+1]; 
int i, d; 
if (pattern[0] == '\0') return text; 
if (m > 31) return "The pattern is too long!"; 
/* Initialize the bit array R */ 
R = malloc((k+1) * sizeof *R); 
for (i=0; i <= k; ++i) 
R[i] = ~1; 
/* Initialize the pattern bitmasks */ 
for (i=0; i <= CHAR_MAX; ++i) 
pattern_mask[i] = ~0; 
for (i=0; i < m; ++i) 
pattern_mask[pattern[i]] &= ~(1UL << i); 
for (i=0; text[i] != '\0'; ++i) { 
/* Update the bit arrays */ 
unsigned long old_Rd1 = R[0]; 
R[0] |= pattern_mask[text[i]]; 
R[0] <<= 1; 
for (d=1; d <= k; ++d) { 
unsigned long tmp = R[d]; 
/* Substitution is all we care about */ 
R[d] = (old_Rd1 & (R[d] | pattern_mask[text[i]])) << 1; 
old_Rd1 = tmp; 
} 
if (0== (R[k] & (1UL << m))) { 
result = (text+i - m) + 1; 
break; 
} 
} 
free(R); 
return result; 
}
14- الگوریتم Needleman Wunsch
از این الگوریتم در بیوانفورماتیک استفاده می شود، در حقیقت این الگوریتم نمونه ای از برنامه نویسی پویا است.
15- الگوریتم Smith Waterman
یک الگوریتم معروف برای اجرای هم تراز کردن دنباله های محلی است و به جای جستجو در کل دنباله ها قطعه هایی از همه طول های ممکن را مقایسه می کند و اندازه گیری شباهت را بهینه می کند.
جدول مقایسه الگوریتم های تطبیق رشته
(http://www.uploadax.com/images/23023200135545536724.bmp)


کاربردهای مختلف الگوریتم ها
• ویرایشگر متن کتابخانه دیجیتال و موتورهای جستجو
• کاربردهای چند رسانه ای و زیست شناسی محاسباتی
• آزمایش های پزشکی
• تشخیص نفوذ در شبکه
پژوهش های مشابه قرآنی
1- موتور های جستجو در زمینه تشخیص وجود یک آیه در متن
2- روشی برای طبقه بندی قرآن براساس ترتیب زمانی سوره
3- روشی برای طبقه بندی قرآن براساس مراحل مختلف زندگانی پیامبر مکرم اسلام (ص)
4- یک طبقه بندی آماری برای آیه های قرآن
5- یک چارچوب کارآمد به نام DataQuest برای مدل کردن و بازیابی دانش از منابع دانش توزیع شده مربوط به قرآن
6- حاشیه نویسی قرآن کریم برای متن کاوی
7- سیستم تشخیص خودکار گفتار مستقل از گوینده برای قرآن 
#چارچوب پیشنهادی

سیستم هوشمند تشخیص خودکار آیات قرآنی
 الگوریتم سیستم هوشمند تشخیص خودکار آیات قرآنی در حیطه الگوریتم های تطبیق رشته دقیق قرار دارد چرا که می بایست عباراتی که تطبیق کامل با آیات قرآنی دارند جستجو شوند از طرفی چون بیش از یک الگو (تمامی کلمات قرآن) را در متن جستجو می کنیم باید یک الگوریتم تطبیق چند الگویی پیاده سازی کنیم.
پیشنهاد ما یک الگوریتم تطبیق رشته دقیق مبتنی بر اندیس گذاری می باشد.
تطبیق چند الگویی در مورد آیات قرآن کریم 
این سیستم از جهات زیر با سیستم های تطابق دقیق چند الگویی متمایز است:
1- جستجوی الگوهای متوالی
2- شکل های متفاوت برای یک الگو
3- حجم بسیار بزرگ مجموعه داده الگو در مقایسه با دیگر الگوریتم ها
4- پیاده سازی سیستم تطابق دقیق چند الگویی مشخصا برای قرآن
جستجوی الگوهای متوالی
یکی از مسائل منحصر به فرد در این سیستم که الگوریتم آن را پیچیده تر از سایر روش های جستجوی تطابق چند الگویی می سازد این است که علاوه بر یافتن الگوها توالی الگوها نیز یکی از شروط جستجوی الگوست. یعنی اگر کلمه ای از متن با الگویی تطابق داشت کلمه بعدی در متن باید با الگوی بعدی در بانک الگو تطابق داشته باشد تا بتوان قطعاتی از آیات را در متن تشخیص داد. بنابراین مسئله از جستجوی الگو به جستجوی الگوهای متوالی تغییر می یابد.
شکل های متفاوت برای یک الگو
یک کلمه در قرآن ممکن است رسم الخط های مختلفی داشته باشد (زیرا املاهای مختلفی برای نوشتن برخی از کلمات قرآنی وجود دارد) این بدین معنی است که ممکن است یک الگو به شکل های مختلفی ظاهر شود اما تمامی این رسم الخط های متفاوت یک کلمه باید به عنوان یک الگو تشخیص داده شوند.
حجم بسیار بزرگ مجموعه داده الگو در مقایسه با دیگر الگوریتم ها
قرآن کریم دارای بیش از 84000 کلمه است که هر کدام خود یک الگو را تشکیل می دهند علاوه بر آن در این موتور جستجو از تمامی رسم الخط های قرآنی موجود پشتیبانی می شود و این مسئله حجم مجموعه الگو ها را چهار برابر افزایش می دهد.
الگوریتم سیستم تشخیص هوشمند آیات قرآنی دارای 5 مرحله می باشد :
1- ساخت بانک قرآنی
2- پردازش اولیه بر روی متن ورودی 
3- شناسایی کلمات قرآنی
4- جستجوی توالی الگوها و تشخیص آیه
5-  آدرس دهی و برجسته سازی آیات قرآنی درون متن اصلی  
ساخت بانک های قرآنی
این مرحله ابتدایی ترین مرحله کار است که بانک های مورد نیاز سیستم را ایجاد می کنیم. برخی از بانک های مورد نیاز عبارت است از:
بانک قرآن
بانک رسم الخط های متفاوت
بانک عبارات تک کلمه ای و دو کلمه ای
بانک عبارات سه کلمه ای

بانک قرآنی
برای ساختن بانک قرآنی که اصلی ترین بانک اطلاعاتی سیستم است متن کامل قرآن را به صورت کلمه به کلمه و پشت سر هم در جدولی ذخیره می کنیم تا به هر کلمه از قرآن به صورت منحصر به فرد اندیسی تعلق یابد. هدف از این اندیس گذاری یکتا با علم به تکراری بودن بسیاری از کلمات قرآن در ادامه الگوریتم مشخص می شود.
بانک رسم الخط های متفاوت
از جمله رسم الخط های موجود در بین مسلمانان :
ایرانی (طاهر خوشنویس)
ترکی (حامد الآمدی)
هندی
مصری (عثمان طه)
در جدول زیر مثالی از تفاوت کتابت این رسم الخط ها ارایه شده است.
(http://www.uploadax.com/images/62509715524574747508.bmp)

بانک عبارات تک کلمه ای و دو کلمه ای
برای سنجش ارزش این عبارات دو معیار تعریف می کنیم :
فراوانی عبارت موجود در متن
تعداد قرآن بودن عبارت مورد نظر در متن
در زیر تصویری از بانک های تک کلمه ای و دو کلمه ای ارایه شده است:

(http://www.uploadax.com/images/99176875254590887885.bmp)

(http://www.uploadax.com/images/40554429025353245636.bmp)

بانک عبارات سه کلمه ای
برخلاف آن چه در مورد عبارات تک کلمه ای و دو کلمه ای ذکر شد برخی عبارات قرآنی مانند {و ان کان ، و فی ذلک} و ... وجود دارند که علی رغم آن که سه کلمه پیاپی آن مشابه با برخی از بخش های قرآن است ولی استفاده آن در متون غیر قرآنی به حدی است که قرآن بودن آن را توجیه نمی کند. در زیر تصویری از بانک سه کلمه ای آورده شده است:

(http://www.uploadax.com/images/28114545271640106456.bmp)

پردازش اولیه بر روی متن ورودی
در این مرحله ابتدا کاراکترهای اضافه از قبیل علایم ویرایشی اعراب و ... از متن حذف می شوند و برای هریک از کلمات باقی مانده ی متن ورودی اندیسی در نظر گرفته می شود تا جایگاهشان در متن مشخص باشد.
شناسایی کلمات قرآنی 
در این مرحله تک تک کلمات متن به ترتیب چینش در متن با الگوهای موجود در بانک الگو مقایسه می شود. و اندیس الگوهایی که با کلمه مورد نظر تطابق دارند در آرایه ای ذخیره می شود. پس هر کلمه از متن به یک آرایه از اعداد نگاشته می شود.
(http://www.uploadax.com/images/46623554196368432043.bmp)

جستجوی توالی و تشخیص آیه 
با استفاده از جستجو بر روی اندیس ها به دنبال یک توالی اندیسی در بین کلمات قرآنی می گردیم چرا که در مرحله اول بانک قرآنی را به گونه ای تشکیل دادیم که تمامی کلمات یک آیه دارای اندیس های پشت سرهم هستند پس هر توالی اندیسی تشخیص یک آیه را می دهد. در این مرحله بلندترین رشته تطبیق یافته شده به عنوان آیه تشخیص داده شده برگردانده می شود.
(http://www.uploadax.com/images/13302185484186640613.bmp)

کمی تأمل(!)
چون آرایه های مربوط به کلمات از ابتدا مرتب می شوند پس برای پیدا کردن بلندترین دنباله اعداد پشت سر هم از جستجوی دودویی استفاده می کنیم که سریع ترین جستجو در بین الگوریتم های جستجو است.
حال اگر طول الگوی پیدا شده کمتر از 4 کلمه باشد باید از بانک های یک کلمه دو کلمه و سه کلمه ای استفاده کرد ،در این مرحله اگر طول الگوی پیدا شده سه کلمه باشد عبارت پیدا شده در بانک سه کلمه جستجو می شود اگر نتیجه جستجو مثبت باشد الگو به عنوان قرآن اعلام نمی شود ولی  اگر نتیجه جستجو منفی باشد الگو به عنوان قرآن اعلام می شود. اگر طول الگوی پیدا شده 1 یا 2 کلمه باشد عبارت مورد نظر در بانک های یک یا دو کلمه ای جستجو می شود. اگر نتیجه جستجو مثبت باشد الگو به عنوان قرآن اعلام می شود ولی  اگر نتیجه جستجو منفی باشد الگو به عنوان قرآن اعلام نمی شود.
آدرس دهی و برجسته سازی آیات قرآنی 
در این مرحله با استفاده از اندیس الگو ها آیات قرآنی بازیابی شده و با استفاده از اندیس کلمات در رشته ورودی مکان حضور آیات قرآنی در متن نیز مشخص شده و به گونه ای برجسته می شود.

#مجموعه داده ها
برای انجام بررسی نتایج از دو منبع استفاده شده است:
منابعی که آیات قرآنی در آن بسیار به چشم می خورد
منابعی که آیات قرآنی کمتری دارد اما کلمات قرآنی در آن زیاد است

# معیار های ارزیابی
این سیستم جزو سیستم های بازیابی تشخیص اطلاعات است نه بازیابی داده معین ، چرا که ما با مسائلی من جمله اختلاف رسم الخط ها ، اختلاف قرائات و ... روبرو هستیم
پس باید پردازش بیشتری و پیچیده تری روی سیستم انجام گیرد زیرا  بازیابی اطلاعات برخلاف بازیابی داده ها با ابهاماتی رو به رو است بنابراین باید هر چه بیشتر اطلاعات را مدل کنیم تا ابهام در درک اطلاعات توسط سیستم کم شود
در این سیستم همانند سیستم بازیابی اطلاعات معیار صحت ، دقت و معیار F معیار های اصلی ارزیابی اند


معیار صحت تشخیص یک آیه
تعداد کلماتی که به درستی به عنوان قرآن تشخیص داده شده اند نسبت به تعداد کل کلمات قرآنی موجود در متن 

معیار دقت تشخیص یک آیه
 تعداد کلماتی که به درستی به عنوان قرآن تشخیص داده شده اند نسبت به تعداد کل کلماتی که آیه تشخیص داده شده اند

معیار F
میانگین هارمونیک صحت و دقت و دارای تأثیرات هم زمان هر دو معیار

# نتایج آزمایش ها
متنی که توسط این سیستم هوشمند بررسی می شود برای هر کلمه در آن دو حالت پیش می آید که دو معیار ارزیابی در مورد آن است :

بر اساس کلماتی که قرآن اعلام شده اند 
بر اساس کلماتی که قرآن اعلام نشده اند

جداول زیر نتایج آزمایش ها را نشان می دهد:
(http://www.uploadax.com/images/67855949070959668706.bmp)
(http://www.uploadax.com/images/84723399126212734033.bmp)
 
#کارهای آینده 
•	ایجاد سیستم های هوشمند مکمل جستجو با استفاده از متون جستجوی تکمیلی کمکی نظیر:
{قال تعالی، قوله عز و جل} و... که در اطراف متون قرآنی مشاهده می شوند
•	تشخیص هوشمند اختلاف قرائات و رسم الخط ها
•	اعراب گذاری هوشمند آیات قرآنی
•	انتخاب و یا هشدار هوشمند آدرس صحیح از میان آدرس های مشترک
•	ایجاد ارتباط میان متون خاص و عباراتی که تشابه معنایی با آن ها دارند

در پایان باید خاطر نشان کنم به دلیل به هم خوردگی متن فایل pdf آن در پایین ضمیمه شده است.

#مراجع

[1]  Tai,  X.,  Ren,  F.  Kita,  K.,  “An  Information  Retrieval  Model  based  on  Vector  Space  Method  by 
Supervised Learning”, Information Processing & Management, 2001. 
[2]  Alaa H. AL-Hamami, Mohammad A. AL-Hamami, Soukaena  H. Hashem,  “A strategy to compromise 
handwritten  documents  processing  and  retrieving  using  association  rules  mining”,  Ubiquitous 
Computing and Communication (UbiCC) Journal, Volume6: Issue 3, pp. 901-906, 2011.
[3]  A.  Christy,  P.  Thambidurai,  “Extracting  the  information  the  information  contained  in  electronic 
documents: a pattern matching algorithm for text mining”, journal of computer applications, Vol- 1, 
No.2, pp 18-21, Apirl-June 2008. 
[4]  Witten, I. H., Don, K. J., Dewsnip, M. and Tablan, V. () “Text mining in a digital library.” International 
Journal on Digital Libraries 4(1), pp. 56-59, 2004.
[5]  Sharma, N., “Discovering knowledge with text mining”, M.S. Thesis, Texas A&M University, 2005. 
[6]  Usama Fayyad, Gregory Piatetsky-Shapiro, and Padhraic Smyth, “From  Data Mining to Knowledge 
Discovery  in  Databases”,  American  Association  for Artificial Intelligence.  All rights reserved. 0738-4602,1996.
[7]  Liddy, E. D., “Text mining”,Bulletin of the American Society for Information Science, 27 (1) :pp. 13-14, 2000. 
[8]  J.Froelich,  S.Ananyan,  and  D.L  Olson,  "Business  Inteligence  Through  Text  Mini.",  Business 
Intelligence Journal, Vol.10, No. 1, pp. 43-50, April 2006. 
[9]  Raymond  J.  Mooney  and  Un  Yong  Nahm,  ”Text  Mining  with  Information  Extraction”, 
Multilingualism  and  Electronic  Language  Management: Proceedings  of  the  4th  International  MIDP 
Colloquium,  Bloemfontein,  South  Africa,  Daelemans,  W.,  du  Plessis,  T.,  Snyman,  C.  and  Teck,  L. 
(Eds.) pp.141-160, Van Schaik Pub., South Africa, 2005. 
[10]  Robert R. Korfhage,"Information  Storage  and  Retrieval", ISBN: 978-0-471-14338-3, Hardcover 368 
pages, June 1997. 
[11]  Bi Kun, Gu Nai-jie, Tu Kun, Liu Xiao-hu, and Liu Gang , “A Practical Distributed String Matching 
Algorithm  Architecture  and  Implementation”, World  Academy  of  Science,  Engineering  and 
Technology 10, 2005. 
[12]  Kuo-Kun Tseng, Ying-Dar Lin,Tsern-Huei Lee and Yuan-Cheng Lai,  “A Parallel Automaton String 
Matching  with  Pre-Hashing  and  Root-Indexing  Techniques  for  Content  Filtering  Coprocessor”,
Proceedings  of  the16th  International  Conference  on  Application-Specific  Systems,  Architecture  and 
Processors (ASAP’05),1063-6862/05, IEEE 2005. 
[13]  Raju  Bhukya,  DVLN  Somayajulu  ; “Index  based  multiple  pattern  matching  algorithm  using  DNA 
sequence  and  pattern  count”,  International  Journal  of  Information  Technology  and Knowledge 
Management, Volume 4, No. 2, pp. 431-441, July-December 2011. 
[14]  Raju Bhukya, DVLN Somayajulu, “Exact Multiple Pattern Matching Algorithm using DNASequence 
and Pattern Pair”.  International Journal of Computer Applications (0975 – 8887). Volume 17– No.8, 
March 2011. 
[15]  Raju Bhukya, DVLN Somayajulu,  "An Index based Forward Backward Multiple Pattern Matching 
Algorithm ", World Academy of Science, Engineering and Technology 66, pp. 1527-1537, 2010. 
[16]  Ramakrishnan Kandhan, Nikhil Teletia, Jignesh M. Patel, “SigMatch: Fast and Scalable Multi-Pattern 
Matching”, Vol. 3, No. 1, Proceedings of the 36th International Conference on Very Large Data Bases, 
Singapore, September 2010. 
[17]  Changsheng  Miao  Sch.  of  Inf.  Sci.  &  Eng.,  Northeastern  Univ.,  Shenyang,  China, "Filtering  Based 
Multiple  String  Matching  Algorithm  Combining  q-Grams  and  BNDM ",  Fourth  International 
Conference on Genetic and Evolutionary Computing (ICGEC), pp. 582 - 585, Shenzhen , 15 Dec. 2010. 
[18]  S. Fide and S. Jenks,  “ A Survey of String Matching Approaches in Hardware”, Department of 
Electrical Engineering and Computer Science University of California, Irvine, USA. 2008. 
[19]  Awsan Abdulrahman Hasan, Nur’Aini Abdul Rashid,  "Hybrid Exact String Matching Algorithm for 
Intrusion Detection System ", PP. 181-185, ICCIT, 2012. 
[20]  Raju  Bhukya,  DVLN  Somayajulu,  "Index  Based  Sequential  Multiple  Pattern  Matching  Algorithm 
Using Pair Indexing ",International Conference on Life Science and Technology IPCBEE vol.3, pp. 
1100-104, IACSIT Press, Singapore, 2011. 
[21]  Raju Bhukya, DVLN Somayajulu,"An even odd multiple pattern matching algorithm ",  International 
Journal  of  Engineering  Science  and  Technology  (IJEST),  ISSN  :  0975-5462  Vol.  3  No.  3,  pp. 
2118,2126, March 2011. 
[22]  TAN Jianlong, LIU Xia, LIU Yanbing, LIU Ping, “Speeding up Pattern Matching by Optimal Partial 
String  Extraction”,  the  First  International  Workshop  on  Security  in  Computers,  Networking  and 
Communications, 978-1-4244-9920-5/11, IEEE 2011. 
[23]  Raju  Bhukya,  DVLN  Somayajulu,  "An  Index  Based  Sequential  Multiple  Pattern  Matching 
Algorithm",International Conference on Bioscience, Biochemistry and Bioinformatics IPCBEE vol.5, 
pp. 322-326, IACSIT Press, Singapore, 2011. 
[24]  Raju  Bhukya,  Balram  Parmer,  Anand  Kulkarni,  "An  Index  Based  Skip  Search  Multiple  Pattern 
Matching Algorithm ", International Journal on Computer Science and Engineering (IJCSE), ISSN : 
0975-3397 Vol. 3 No. 4, pp. 1510-1517, Apr 2011. 
[25]  Vidya  SaiKrishna,  Akhtar  Rasool,  and  Nilay  Khare,  "String  Matching  and  its  Applications  in 
Diversified Fields", IJCSI International Journal of Computer Science Issues, Vol. 9, Issue 1, No 1, pp. 
219-226, ISSN (Online): 1694-0814 , January 2012. 
[26]  Prasad  J.C  and  K.S.M.Panicker, “String  Searching  Algorithm  Implementation-Performance  Study 
with Two Cluster Configuration”,  International Journal of Computer Science & Communication, Vol. 
1, No. 2, pp. 271-275, July-December 2010. 
[27]  Nimisha  Singla,  Deepak  Garg,  "String  Matching  Algorithms  and  their  Applicability  in  various 
Applications",  International  Journal  of  Soft  Computing  and  Engineering  (IJSCE)  ISSN:  2231-2307, 
Volume-I, Issue-6, January 2012. 
[28]  A Fadel Klaib, Z Zainol, N Hashimah Ahamed, R Ahmad, and W Hussin, “Application of Exact String 
Matching Algorithms towards SMILES Representation of Chemical Structure”,  World Academy of 
Science, Engineering and Technology 34, 2007. 
[29]  Panagiotis  D.  Michailidis,  Konstantinos  G.  Margaritis,  "Flexible  Approximate  String  Matching 
Application  on  a  Heterogeneous  Distributed  Environment",  Proceedings  of  the  International 
Conference  on  Parallel  and  Distributed  Processing  Techniques  and  Applications,  PDPTA  '03,  Las 
Vegas, Nevada, USA, Volume 1; , June 23 - 26, 2003.
[30]  Charalampos  S.  Kouzinopoulos,  Panagiotis  D.  Michailidis  and  Konstantinos  G.  Margaritis,  “Parallel 
Processing  of  Multiple  Pattern  Matching  Algorithms  for  Biological  Sequences:  Methods  and 
Performance Results”, In: Bioinformatics - Computational Biology and Modeling,  pp. 161-182, ISBN 
979-953-307-280-6, 2011. 
[31]  Leena  Salmela, “Multi-Pattern  String  Matching  with  Very  Large  Pattern  Sets”.  ACM  Journal  of 
Experimental Algorithmic, Volume 11, November 1st 2007. 
[32]  Iulian Moraru, David G. Andersen,  “Exact Pattern Matching with Feed-Forward Bloom Filters”.  by 
SIAM, 2011.
[33]  Scarpazza, D.P.; Villa, O.; Petrini, F., “High-speed  string  searching  against  large  dictionaries  on 
the  Cell/B.E.   Processor”.  Parallel  and  Distributed  Processing,  IPDPS  2008. IEEE  International 
Symposium on. ISSN: 1530-2075, pp. 1 – 12., Miami,FL, 14-18 April 2008. 
[34]  Donald Knuth; James H. Morris, Jr, Vaughan Pratt, "Fast pattern matching in strings". SIAM Journal 
on Computing 6 (2): PP. 323–350, 1977. 
[35]  Awsan  Abdulrahman  Hasan   and  Nur  Aini  Abdul  Rashid, “Hash  -  Boyer-Moore  -  Horspool  String 
Matching  Algorithm  for  Intrusion  Detection  System”, International  Conference  on  Computer 
Networks and Communication Systems (CNCS 2012) IPCSIT vol.35(2012) IACSIT Press, Singapore, 
2012. 
[36]  http://www.iti.fh-flensburg.de/lang/algorithmen/pattern/bmen.htm. 
[37]  Cheng-Hung Lin, Sheng-Yu Tsai, Chen-Hsiung Liu, Shih-Chieh Chang, Jyuo-Min Shyu, “Accelerating 
String  Matching  Using  Multi-threaded  Algorithm  on  GPU”,  978-1-4244-5637-6/10/$26.00,   IEEE, 
2010. 
[38]  Pekka  Kilpel  ¨ainen,  “Biosequence  Algorithms,  Lecture  4:  Set  Matching  and  Aho-Corasick 
Algorithm”, University of Kuopio Department of Computer Science spring 2005. 
[39]  Thomas  H.  Cormen;  Charles  E.  Leiserson;  Ronald  L.  Rivest;  Clifford  Stein,  "The  Rabin–Karp 
algorithm".  Introduction  to  Algorithms (2nd  edition  ed.).  Cambridge,  Massachusetts:  MIT  Press. 
pp. 911–916. ISBN 978-0262032933, 2001. 
[40]  Raju  Bhukya,  DVLN  Somayajulu,  “An  Index  Based  K-Partitions  Multiple  Pattern  Matching 
Algorithm”,  Proc.  of  Int.  Conf.  on  Advances  in  Computer  Science 2010  ACEEE,  DOI: 
02.ACS.2010.01.194, PP. 83-87, 2010. 
[41]  R.  Baeza-Yates  and  G.  Navarro,  "A  faster  algorithm  for  approximate  string  matching",  In  Dan 
Hirchsberg and Gene Myers, editors ,Combinatorial Pattern Matching (CPM'96), LNCS 1075, pages 1–
23, Irvine, CA, June 1996. 
[42]  G.  Myers.  "A  fast  bit-vector  algorithm  for  approximate  string  matching  based  on  dynamic 
programming", Journal of the ACM 46(3), pp. 395-415, May 1999.
[43]  Bálint  Dömölki,  "A  universal  compiler  system  based  on  production  rules",  BIT  Numerical 
Mathematics, 8(4), pp 262–275, 1968. 
[44]  Raja  Jamilah  Raja  Yusof,  Roziati  Zainuddin,  Mohd.  Sapiyan  Baba  and  Zulkifli  Mohd.  Yusoff, 
“Quranic  words  stemming”, The  Arabian  Journal  for  Science  and  Engineering, Volume  35,  Number 
2C, December 2010. 
[45]  Mohamadou  Nassourou,  “A  Knowledge-based  Hybrid  Statistical  Classifier  for Reconstructing  the 
Chronology  of  the  Quran”,  Department  of  Computer  Philology  &  Modern  German Literature 
University of Würzburg Am Hubland D - 97074 Würzburg. 
[46]  Mohamadou Nassourou, “Using Machine Learning Algorithms for Categorizing Quranic Chapters by 
Major  Phases  of  Prophet  Mohammad’s  Messengership”  ,  Department  of  Computer  Philology  & 
Modern German Literature University of Würzburg Am Hubland D - 97074 Würzburg. 
[47]  Mohammed  Naji  Al-Kabi,  Ghassan  Kanaan,  Riyad  Al-Shalabi,  “Statistical  Classifier  of  the  Holy 
Quran Verses (Fatiha and Yaseen Chapters)”, Journal of Applied Sciences 5 (3): 580-583, ISSN1812-5654, 2005. 
[48]  Qurat ul Ain, Amna Basharat, “Ontology driven Information Extraction from the Holy Qur’an related 
Documents”,  26th  IEEEP  Students’  Seminar  2011  Pakistan  Navy  Engineering  College  National 
University of Sciences & Technology, 2011. 
[49]  Abdul-Baquee M. Sharaf, “The Qur'an Annotation for Text Mining”, Supervisor: Dr. Eric Atwell, first 
year transfer report, December 2009. 
[50]  Zaidi  Razak,  Noor  Jamaliah  Ibrahim,  Mohd  Yamani  Idna  Idris,  Emran  Mohd  Tamil,  Mohd  Yakub, 
Zulkifli  Mohd  Yusoff  and  Noor  Naemah  Abdul  Rahman,  “Quranic  Verse  Recitation  Recognition 
Module  for  Support  in  j-QAF  Learning:  A  Review”,  IJCSNS  International  Journal  of  Computer 
Science and Network Security, VOL.8 No.8, August 2008. 
[51]  Ehab  Mourtaga,  Ahmad  Sharieh,  and  Mousa  Abdallah,  “Speaker  Independent  Quranic  Recognizer 
Based  on  Maximum  Likelihood  Linear  Regression”,  World  Academy  of  Science,  Engineering  and 
Technology 36, pp. 61-67, 2007. 
[52]  Hammo, B., Sleit, A; El-Haj, M., "Effectiveness of Query Expansion in searching the Holy Quran". In 
Proceeding of the Second International Conference on Arabic Language Processing CITALA'07, pages 
1-10, Rabat, Morocco, CITALA, 2007. 
  
[53] جستجوی هوشمند عبارات قرآنی در متون دیجیتال ، محمد حبیب زاده بیژنی

[54] رده بندی متون فارسی با استفاده از روش های آماری ، محمد حسین الهی منش – دکتر بهروز مینایی

[55]  برچسب گذاری ادات سخن متون فارسی به کمک مدل مخفی مارکوف ، محمد حسین الهی منش – دکتر بهروز مینایی

[56] امکان سنجی تولید سامانه هوشمند تشخیص آیات قرآن در متون فارسی تفسیری 

[57] برخی مسائل در طراحی موتور جستجوی قرآنی وب محمدی نصیر ، مجتبی

# پیوندهای مفید
* [دریافت متن قرآن کریم](http://tanzil.net/)
* [متن عربی و فارسی المیزان که برای تست مفید است](http://zolal.sobhe.ir/#almizan_ar/2_1)
* [سورس کد](http://uplod.ir/q0g2wji1gpd7/quran.rar.htm)
* [فایل متن](http://uplod.ir/o08mxusajn6q/New_Microsoft_Word_Do_ent.pdf.htm)