2007-07-18 09:11:18 +08:00
|
|
|
#!/bin/bash
|
|
|
|
# File: counttestset.sh
|
|
|
|
# Description: Script to count the errors on a single UNLV set.
|
|
|
|
# Author: Ray Smith
|
|
|
|
# Created: Wed Jun 13 11:58:01 PDT 2007
|
|
|
|
#
|
|
|
|
# (C) Copyright 2007, Google Inc.
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
2018-06-09 20:47:09 +08:00
|
|
|
if [ $# -ne 2 ]
|
2007-07-18 09:11:18 +08:00
|
|
|
then
|
2018-06-09 20:47:09 +08:00
|
|
|
echo "Usage:$0 pagesfile langcode"
|
2007-07-18 09:11:18 +08:00
|
|
|
exit 1
|
|
|
|
fi
|
2018-06-06 20:20:14 +08:00
|
|
|
if [ ! -d src/api ]
|
2007-07-18 09:11:18 +08:00
|
|
|
then
|
|
|
|
echo "Run $0 from the tesseract-ocr root directory!"
|
|
|
|
exit 1
|
|
|
|
fi
|
2018-06-06 20:20:14 +08:00
|
|
|
|
2007-07-18 09:11:18 +08:00
|
|
|
pages=$1
|
2018-06-09 20:47:09 +08:00
|
|
|
langcode=$2
|
2007-07-18 09:11:18 +08:00
|
|
|
|
|
|
|
imdir=${pages%/pages}
|
|
|
|
setname=${imdir##*/}
|
2018-06-06 20:20:14 +08:00
|
|
|
resdir=unlvtests/results/$setname
|
|
|
|
mkdir -p unlvtests/reports
|
2007-07-18 09:11:18 +08:00
|
|
|
echo "Counting on set $setname in directory $imdir to $resdir"
|
|
|
|
accfiles=""
|
|
|
|
wafiles=""
|
|
|
|
while read page dir
|
|
|
|
do
|
|
|
|
if [ "$dir" ]
|
|
|
|
then
|
|
|
|
srcdir="$imdir/$dir"
|
|
|
|
else
|
|
|
|
srcdir="$imdir"
|
|
|
|
fi
|
2018-06-08 22:28:50 +08:00
|
|
|
#echo "$srcdir/$page.tif"
|
2018-06-10 10:49:50 +08:00
|
|
|
# Convert groundtruth and recognized text to UTF-8 to correctly treat accented letters.
|
2018-06-09 20:47:09 +08:00
|
|
|
iconv -f ISO8859-1 -t UTF-8 "$srcdir/$page.txt" >"$srcdir/$page.text"
|
2018-06-10 10:49:50 +08:00
|
|
|
iconv -f ISO8859-1 -t UTF-8 "$resdir/$page.unlv" >"$resdir/$page.text"
|
|
|
|
# Count character errors.
|
2018-06-09 20:47:09 +08:00
|
|
|
ocrevalutf8 accuracy "$srcdir/$page.text" "$resdir/$page.text" > "$resdir/$page.acc"
|
2018-06-08 22:28:50 +08:00
|
|
|
accfiles="$accfiles $resdir/$page.acc"
|
2007-07-18 09:11:18 +08:00
|
|
|
# Count word errors.
|
2018-06-09 20:47:09 +08:00
|
|
|
#langcode should be either eng or spa
|
|
|
|
if [ "$langcode" = "eng" ]
|
|
|
|
then
|
|
|
|
ocrevalutf8 wordacc "$srcdir/$page.text" "$resdir/$page.text" > "$resdir/$page.wa"
|
|
|
|
else
|
2018-06-09 22:47:51 +08:00
|
|
|
cp ~/ISRI-OCRtk/stopwords/spa.stopwords.txt "$resdir/spa.stopwords"
|
2018-06-09 20:47:09 +08:00
|
|
|
ocrevalutf8 wordacc -S"$resdir/spa.stopwords" "$srcdir/$page.text" "$resdir/$page.text" > "$resdir/$page.wa"
|
|
|
|
fi
|
2007-07-18 09:11:18 +08:00
|
|
|
wafiles="$wafiles $resdir/$page.wa"
|
2017-04-08 16:18:01 +08:00
|
|
|
done <"$pages"
|
2018-06-06 20:20:14 +08:00
|
|
|
|
2018-06-08 22:28:50 +08:00
|
|
|
accsum $accfiles >"unlvtests/results/$setname.characc"
|
|
|
|
wordaccsum $wafiles >"unlvtests/results/$setname.wordacc"
|
2018-06-09 20:47:09 +08:00
|
|
|
|