You need the R package tesseract, which is bindings to a powerful optical character recognition (OCR) engine, to do OCR with imagerExtra.
See the installation guide of tesseract if you haven’t installed tesseract.
ocr function of tesseract works best for images with high contrast, little noise, and horizontal text.
ocr function doesn’t show a good performance for degraded images as shown below.
[1] ""
[1] word confidence bbox
<0 rows> (or 0-length row.names)
OCR function and OCR_data function are wrappers for ocr function and ocr_data function of tesseract.
We can see OCR function and OCR_data function failed to recognize the text “Hello”.
We need to clean the image before using OCR function.
hello <- DenoiseDCT(papers, 0.01) %>% ThresholdAdaptive(., 0.1, range = c(0,1))
plot(hello, main = "Hello")
[1] "Hello\n"
word confidence bbox
1 Hello 95.29642 8,9,118,54
We can see the text “Hello” was recognized.
Using tesseract in combination with imagerExtra enables us to extract text from degraded images.