In my last post I noted that I couldn’t find the word “ကြွက်”(mouse in our language) even though it was clearly there in the spelling book. I was wondering if that was due to Google wrongly converting that word when it ran the OCR with Google Docs. Then I had some doubts on LibreOffice’s conversion of the text file output from Google to PDF. However, I noticed that when Google OCR went wrong, it showed up in the text output. For example, the word “ကစော့ပင်” from the original Spelling Book came out as “ကရော့ပင်”. After second thought, I suspected that difficulties might due to the application of text search function developed for the English language to an entirely different kind of language like ours.
In this exercise, I would use regex (Regular expression) to accurately search text in the Myanmar Spelling Book to find out if the OCR operation, PDF conversion, or the text search functions were at fault. The workflow would be, (i) create a text string containing the word(s) to be searched, and run search with regex, (i) import the spelling book PDF file into R, (iii) split the text of the spelling book to group the terms as they appear in the original book, (iv) do text search, (v) convert the spelling book text into a corpus using the Quanteda package, (v) kwic analysis with Quanteda.
Create text string and run search
z <- c("ကြိမ်ဖန်များစွာ", "(ကြ ိမ်)", "ကြိမ်လုံး", "ရမထာကြိမ်", "ရမင်းပင်", "ရမန်ခံ", "(ကြ ွက်)", "ကြွက်", " အကြိမ်ကြိမ်အဖန်ဖန်")
cat(z)
ကြိမ်ဖန်များစွာ (ကြ ိမ်) ကြိမ်လုံး ရမထာကြိမ် ရမင်းပင် ရမန်ခံ (ကြ ွက်) ကြွက် အကြိမ်ကြိမ်အဖန်ဖန်
cat(grep("ကြ ိမ်",z,value = TRUE))
(ကြ ိမ်)
cat(grep("ကြိမ်",z,value = TRUE))
ကြိမ်ဖန်များစွာ ကြိမ်လုံး ရမထာကြိမ် အကြိမ်ကြိမ်အဖန်ဖန်
cat(grep("ကြ",z,value = TRUE))
ကြိမ်ဖန်များစွာ (ကြ ိမ်) ကြိမ်လုံး ရမထာကြိမ် (ကြ ွက်) ကြွက် အကြိမ်ကြိမ်အဖန်ဖန်
Import the spelling book data
library(readtext)
rt_pdf <- readtext("C:/DATA/othSOFTWARE/searchable-PDF/mySPELL-book/LR-ocrPDF/MyanSpellBook(OCR)-ver0.pdf")
Search the verifying words “ကြိမ်” and “ကြ ိမ်”
y <- strsplit(corp_MyaSpell, "\n")
z <- unlist(y)
utf8::utf8_print(grep("ကြိမ်", z, value = TRUE))
MyanSpellBook(OCR)-ver0.pdf218
"ကျောင်းခေါ်ကြိမ် ကျောင်းသင်္ခမ်း ကျောင်းအမ"
MyanSpellBook(OCR)-ver0.pdf366
"ကြိမ်ဖန်များစွာ"
MyanSpellBook(OCR)-ver0.pdf370
"ကြိမ် (တစ်၊ နှစ်) ကြိမ်ကြိုက် ကြိမ်ခြင်း ကြိမ်ခြမ်းတံစဉ်း ကြိမ်ဒဏ် ကြိမ်ပိုက်တော ကြိမ်ပင် ကြိမ်ပျစ်ပင် ကြိမ်ဖန်များ…"
MyanSpellBook(OCR)-ver0.pdf371
"ကြိမ်လုံး ကြိမ်လုံး"
MyanSpellBook(OCR)-ver0.pdf372
"ကြိမ်းမောင်း ကြိမ်းဝါး"
MyanSpellBook(OCR)-ver0.pdf2540
"ဖန်-(ဝါ- ) ဖန်(ကြိမ်-) ဖန်ခါးပင် ဖန်ခုန်ကစား ဖန်ခွက် ဖန်ဆင်း ဖန်တလီဖန်တလာ ဖန်တီဖန်တွတ် ဖန်တီး ဖန်တွတ်တွတ် ဖန်…"
MyanSpellBook(OCR)-ver0.pdf3081
"မျောက် မျောက်(သတ္တဝါ) မျောက်ကြိမ်ပင် မျောက်ခါးပတ်ပင် မျက်ခုံညင်းပင် မျောက်ချောပင် မျောက်အိုးဝါး မျေ…"
MyanSpellBook(OCR)-ver0.pdf3141
"မြင်းကောင်းခွာလိပ် မြင်းကျား မြင်းကြိမ် မြင်းခံ မြင်းခုံ(ထိုင်ခုံရှည်) မြင်းခုံတိုင် မြင်းစခုံနီပင် မြင်းဇောင်း …"
MyanSpellBook(OCR)-ver0.pdf3397
"ရနယ်(အခြင် ~) ရဗနှီးဗန်း) ရမထာကြိမ်"
MyanSpellBook(OCR)-ver0.pdf3954
"ဝက်ကြိမ်ပင် ဝက်ကြွပ်ပင် ဝက်ခုတ်လယ် ဝက်ချေးပနဲပင် ဝက်ချုပ်နာ ဝက်ခြံ(လှည်း ~) ဝက်ခြံတင်းတိပ် ဝက်ပုတ် ဝက်ဖရုံပင်"
MyanSpellBook(OCR)-ver0.pdf4281
"အကြတ်နေ့ (သင်္ကြန် ~) အကြိတ်အနယ် အကြပ်တပ်သား အကြပ်အဆင့် အကြမ်းဖျင်း အကြိမ်ကြိမ်အဖန်ဖန် အကွင်းအခြည်"
utf8::utf8_print(grep("ကြ ိမ်", z, value = TRUE))
character(0)
Create corpus
library(quanteda)
corp_MyaSpell <- corpus(rt_pdf)
summary(corp_MyaSpell)
library(quanteda)
corp_MyaSpell <- corpus(rt_pdf)
summary(corp_MyaSpell)
Corpus consisting of 1 document, showing 1 document:
Text Types Tokens Sentences
MyanSpellBook(OCR)-ver0.pdf 12262 24707 292
Run Key Words in Context (kwic)
spelltoks <- tokens(corp_MyaSpell, "fastestword")
utf8::utf8_print(sapply(data.frame(kwic(spelltoks, "ကြိမ်",window = 2, valuetype = "regex")),paste0))
docname from to
[1,] "MyanSpellBook(OCR)-ver0.pdf" "747" "747"
[2,] "MyanSpellBook(OCR)-ver0.pdf" "1108" "1108"
[3,] "MyanSpellBook(OCR)-ver0.pdf" "1124" "1124"
[4,] "MyanSpellBook(OCR)-ver0.pdf" "1127" "1127"
[5,] "MyanSpellBook(OCR)-ver0.pdf" "1128" "1128"
[6,] "MyanSpellBook(OCR)-ver0.pdf" "1129" "1129"
[7,] "MyanSpellBook(OCR)-ver0.pdf" "1130" "1130"
[8,] "MyanSpellBook(OCR)-ver0.pdf" "1131" "1131"
[9,] "MyanSpellBook(OCR)-ver0.pdf" "1132" "1132"
[10,] "MyanSpellBook(OCR)-ver0.pdf" "1133" "1133"
[11,] "MyanSpellBook(OCR)-ver0.pdf" "1134" "1134"
[12,] "MyanSpellBook(OCR)-ver0.pdf" "1135" "1135"
[13,] "MyanSpellBook(OCR)-ver0.pdf" "1136" "1136"
[14,] "MyanSpellBook(OCR)-ver0.pdf" "6425" "6425"
[15,] "MyanSpellBook(OCR)-ver0.pdf" "7532" "7532"
[16,] "MyanSpellBook(OCR)-ver0.pdf" "7736" "7736"
[17,] "MyanSpellBook(OCR)-ver0.pdf" "8370" "8370"
[18,] "MyanSpellBook(OCR)-ver0.pdf" "9780" "9780"
[19,] "MyanSpellBook(OCR)-ver0.pdf" "10589" "10589"
pre
[1,] "ကျောင်း-(ထိန်း-) ကျောင်း-(ဝမ်း)"
[2,] "ကြပ်ထုပ်ထိုး ကြပ်ပူတိုက်"
[3,] "ကြမ်းပိုးကောင် ကြမ်းပိုးတေလေ"
[4,] "(တစ်၊ နှစ်)"
[5,] "နှစ်) ကြိမ်ကြိုက်"
[6,] "ကြိမ်ကြိုက် ကြိမ်ခြင်း"
[7,] "ကြိမ်ခြင်း ကြိမ်ခြမ်းတံစဉ်း"
[8,] "ကြိမ်ခြမ်းတံစဉ်း ကြိမ်ဒဏ်"
[9,] "ကြိမ်ဒဏ် ကြိမ်ပိုက်တော"
[10,] "ကြိမ်ပိုက်တော ကြိမ်ပင်"
[11,] "ကြိမ်ပင် ကြိမ်ပျစ်ပင်"
[12,] "ကြိမ်ပျစ်ပင် ကြိမ်ဖန်များစွာ\nကြိမ်လုံး"
[13,] "ကြိမ်ဖန်များစွာ\nကြိမ်လုံး ကြိမ်လုံး\nကြိမ်းမောင်း"
[14,] "(ဖုဿရထား)\nဖန်-(ဝါ- )"
[15,] "မျက်ဝန်း\n\nမျောက် မျောက်(သတ္တဝါ)"
[16,] "မြင်း(သတ္တဝါ)\nမြောင်း\nမြင်းကောင်းခွာလိပ် မြင်းကျား"
[17,] "~) ရဗနှီးဗန်း)"
[18,] "ဝံသာနု\nဝံ့-(ရဲ ~)"
[19,] "အကြပ်အဆင့် အကြမ်းဖျင်း"
keyword
[1,] "ကျောင်းကန်\nကျဉ်နီကျဉ်နက်\nကျောင်းခေါ်ကြိမ်"
[2,] "ကြပ်မတ်\nကြမ်\nကြမ္မာငင်\nကြိမ်ဖန်များစွာ\nကြမ်း\nကြမ်း(အခင်း)"
[3,] "ကြမ်းပြင်\nကြိမ်"
[4,] "ကြိမ်ကြိုက်"
[5,] "ကြိမ်ခြင်း"
[6,] "ကြိမ်ခြမ်းတံစဉ်း"
[7,] "ကြိမ်ဒဏ်"
[8,] "ကြိမ်ပိုက်တော"
[9,] "ကြိမ်ပင်"
[10,] "ကြိမ်ပျစ်ပင်"
[11,] "ကြိမ်ဖန်များစွာ\nကြိမ်လုံး"
[12,] "ကြိမ်လုံး\nကြိမ်းမောင်း"
[13,] "ကြိမ်းဝါး\nကြုံ"
[14,] "ဖန်(ကြိမ်-)"
[15,] "မျောက်ကြိမ်ပင်"
[16,] "မြင်းကြိမ်"
[17,] "ရမထာကြိမ်\nရမင်းပင်\nရမန်ခံ"
[18,] "ဝံ့စား\nဝက်\nဝက်ကြိမ်ပင်"
[19,] "အကြိမ်ကြိမ်အဖန်ဖန်"
post pattern
[1,] "ကျောင်းသင်္ခမ်း ကျောင်းအမ\nကျိုင်း" "ကြိမ်"
[2,] "ကြမ်းကြားလေကြား ကြမ်းကြော်" "ကြိမ်"
[3,] "(တစ်၊ နှစ်)" "ကြိမ်"
[4,] "ကြိမ်ခြင်း ကြိမ်ခြမ်းတံစဉ်း" "ကြိမ်"
[5,] "ကြိမ်ခြမ်းတံစဉ်း ကြိမ်ဒဏ်" "ကြိမ်"
[6,] "ကြိမ်ဒဏ် ကြိမ်ပိုက်တော" "ကြိမ်"
[7,] "ကြိမ်ပိုက်တော ကြိမ်ပင်" "ကြိမ်"
[8,] "ကြိမ်ပင် ကြိမ်ပျစ်ပင်" "ကြိမ်"
[9,] "ကြိမ်ပျစ်ပင် ကြိမ်ဖန်များစွာ\nကြိမ်လုံး" "ကြိမ်"
[10,] "ကြိမ်ဖန်များစွာ\nကြိမ်လုံး ကြိမ်လုံး\nကြိမ်းမောင်း" "ကြိမ်"
[11,] "ကြိမ်လုံး\nကြိမ်းမောင်း ကြိမ်းဝါး\nကြုံ" "ကြိမ်"
[12,] "ကြိမ်းဝါး\nကြုံ -(ပိန်-)" "ကြိမ်"
[13,] "-(ပိန်-) ကြုံ" "ကြိမ်"
[14,] "ဖန်ခါးပင် ဖန်ခုန်ကစား" "ကြိမ်"
[15,] "မျောက်ခါးပတ်ပင် မျက်ခုံညင်းပင်" "ကြိမ်"
[16,] "မြင်းခံ မြင်းခုံ(ထိုင်ခုံရှည်)" "ကြိမ်"
[17,] "ရမယ်ရှာ ရလဒ်(သင်္ချာသုံး)" "ကြိမ်"
[18,] "ဝက်ကြွပ်ပင် ဝက်ခုတ်လယ်" "ကြိမ်"
[19,] "အကွင်းအခြည်\nအကွပ်အထိန်း အကျွေးအမွေး" "ကြိမ်"
utf8::utf8_print(sapply(data.frame(kwic(spelltoks, "ကြွက်",window = 2, valuetype = "regex")),paste0))
docname from to
[1,] "MyanSpellBook(OCR)-ver0.pdf" "523" "523"
[2,] "MyanSpellBook(OCR)-ver0.pdf" "1287" "1287"
[3,] "MyanSpellBook(OCR)-ver0.pdf" "1288" "1288"
[4,] "MyanSpellBook(OCR)-ver0.pdf" "1289" "1289"
[5,] "MyanSpellBook(OCR)-ver0.pdf" "1290" "1290"
[6,] "MyanSpellBook(OCR)-ver0.pdf" "1291" "1291"
[7,] "MyanSpellBook(OCR)-ver0.pdf" "1292" "1292"
[8,] "MyanSpellBook(OCR)-ver0.pdf" "1293" "1293"
[9,] "MyanSpellBook(OCR)-ver0.pdf" "1294" "1294"
[10,] "MyanSpellBook(OCR)-ver0.pdf" "1295" "1295"
[11,] "MyanSpellBook(OCR)-ver0.pdf" "7160" "7160"
pre keyword
[1,] "ကယ်ချွတ် ကယ်ပေါက်" "ကယ်လောင်းကြွက်\nကိုယ်"
[2,] "ကြွေးဆပ်\nကြွေးဆယ်မြိချ\nကြွေးဆယ်မြီချ ကြွေးမြီချ" "ကြွေးရင့်\nကြွက်"
[3,] "ကြွေးမြီချ ကြွေးရင့်\nကြွက်" "ကြွက်စုတ်"
[4,] "ကြွေးရင့်\nကြွက် ကြွက်စုတ်" "ကြွက်တက်"
[5,] "ကြွက်စုတ် ကြွက်တက်" "ကြွက်နားပေါင်းပင်"
[6,] "ကြွက်တက် ကြွက်နားပေါင်းပင်" "ကြွက်နို့"
[7,] "ကြွက်နားပေါင်းပင် ကြွက်နို့" "ကြွက်မြီးတန်း"
[8,] "ကြွက်နို့ ကြွက်မြီးတန်း" "ကြွက်လျှောက်"
[9,] "ကြွက်မြီးတန်း ကြွက်လျှောက်" "ကြွက်ဝမ်းဖြူ"
[10,] "ကြွက်လျှောက် ကြွက်ဝမ်းဖြူ" "ကြွက်သား"
[11,] "မီ ခံအုတ်" "မီးခိုးကြွက်လျှောက်"
post pattern
[1,] "ကိုယ်ကျိုးနည်း ကိုယ်ကျင့်တရား" "ကြွက်"
[2,] "ကြွက်စုတ် ကြွက်တက်" "ကြွက်"
[3,] "ကြွက်တက် ကြွက်နားပေါင်းပင်" "ကြွက်"
[4,] "ကြွက်နားပေါင်းပင် ကြွက်နို့" "ကြွက်"
[5,] "ကြွက်နို့ ကြွက်မြီးတန်း" "ကြွက်"
[6,] "ကြွက်မြီးတန်း ကြွက်လျှောက်" "ကြွက်"
[7,] "ကြွက်လျှောက် ကြွက်ဝမ်းဖြူ" "ကြွက်"
[8,] "ကြွက်ဝမ်းဖြူ ကြွက်သား" "ကြွက်"
[9,] "ကြွက်သား (ခြေသလုံး-)\nခခယမ်းယမ်း" "ကြွက်"
[10,] "(ခြေသလုံး-)\nခခယမ်းယမ်း ခခွေးအက္ခရာ" "ကြွက်"
[11,] "မီးခိုးတိတ် မီးခတ်ကျောက်" "ကြွက်"
Conclusion
Without a custom software for searching Myanmar text, text search using ready-made software based on the English language would have some inherent limitations. From the result of my exercise, I think, I will have to conclude that the cause of the difficulties I am trying to find out comes from such limitations.
Nevertheless, such ready-made tools are basically usable as-is with our language, I guess. With some ingenuity you may be able to devise some workarounds where a straight approach is not available. For example, if you can’t search for “ကြိမ်” you could search for “ကြ” and pick what you are looking for from the results. Another example is from an old book of 1847 (The Laws of Menoo) available on Archive.org. It contained pages interleaved in Myanmar and English. This book is a searchable PDF, but you could only search in English. Obviously if you could reach a particular English page through text search you get to the Myanmar language page. For example if you are looking for “သင်္ဂဟဝတ္ထု” and could guess that it begins with “Theng” you could search with Acrobat Reader and get 28 hits, out of which 4 would be what you are looking for.