ocrd-galley/Dockerfile

91 lines
3 KiB
Text
Raw Normal View History

2019-10-16 12:50:31 +02:00
#FROM nvidia/cuda:10.0-cudnn7-runtime-ubuntu18.04
2019-06-24 16:36:19 +02:00
FROM ubuntu:18.04
ENV LC_ALL=C.UTF-8 LANG=C.UTF-8
ENV LEPTONICA_VERSION 1.78.0
ENV TESSERACT_VERSION 4.1.0
ENV TESSDATA_BEST_VERSION 4.0.0
ENV TESSDATA_PREFIX /usr/local/share/tessdata
2019-08-21 11:54:01 +02:00
2019-09-23 15:02:59 +02:00
2019-06-24 16:36:19 +02:00
RUN apt-get update && \
apt-get install -y \
2019-09-23 15:02:59 +02:00
curl xz-utils \
python3-pip \
2019-06-24 16:36:19 +02:00
git \
2019-09-23 15:02:59 +02:00
# For leptonica/tesseract:
2019-10-21 17:04:06 +02:00
cmake libgif-dev libjpeg-dev libpng-dev libtiff-dev zlib1g-dev libpango1.0-dev \
2019-09-23 15:02:59 +02:00
# For clstm on Ubuntu 19.04:
swig libeigen3-dev libpng-dev libprotobuf-dev \
# For cv2:
libsm6 libxrender1 \
2019-10-21 17:04:06 +02:00
# For ocrd_olena:
wget graphviz imagemagick libmagick++-dev libgraphicsmagick++1-dev libboost-dev \
2019-09-23 15:02:59 +02:00
# XML utils
2019-06-24 16:36:19 +02:00
libxml2-utils \
xmlstarlet \
&& \
apt-get clean
2019-09-23 15:02:59 +02:00
# Build Leptonica and Tesseract.
# XXX Use a multi stage build for this.
RUN curl -sSL -O https://github.com/DanBloomberg/leptonica/releases/download/$LEPTONICA_VERSION/leptonica-$LEPTONICA_VERSION.tar.gz && \
tar xvzf leptonica-$LEPTONICA_VERSION.tar.gz && \
cd leptonica-$LEPTONICA_VERSION && \
mkdir build && cd build && cmake .. && make install && ldconfig && \
cd ../.. && rm -rf leptonica-$LEPTONICA_VERSION leptonica-$LEPTONICA_VERSION.tar.gz
RUN curl -sSL -O https://github.com/tesseract-ocr/tesseract/archive/$TESSERACT_VERSION.tar.gz && \
tar xvzf $TESSERACT_VERSION.tar.gz && \
cd tesseract-$TESSERACT_VERSION && \
mkdir build && cd build && cmake .. && make install && ldconfig && \
cd ../.. && rm -rf tesseract-$TESSERACT_VERSION $TESSERACT_VERSION.tar.gz
RUN curl -sSL -O https://github.com/tesseract-ocr/tessdata_best/archive/$TESSDATA_BEST_VERSION.tar.gz && \
tar xvzf $TESSDATA_BEST_VERSION.tar.gz && \
mv tessdata_best-$TESSDATA_BEST_VERSION $TESSDATA_PREFIX && \
rm -rf $TESSDATA_BEST_VERSION.tar.gz
2019-10-21 17:04:06 +02:00
# Build ocrd_olena
RUN pip3 install --no-cache-dir --upgrade pip && \
curl -sSL -o ocrd_olena.tar.gz https://github.com/OCR-D/ocrd_olena/archive/fde4436.tar.gz && \
2019-10-21 17:04:06 +02:00
mkdir ocrd_olena && \
tar xvz -C ocrd_olena --strip-components=1 -f ocrd_olena.tar.gz && \
cd ocrd_olena && \
make install PREFIX=/usr/local && \
cd .. && rm -rf ocrd_olena ocrd_olena.tar.gz
# Copy OCR models
2019-10-07 12:36:40 +02:00
RUN mkdir -p /var/lib/calamari-models
COPY data/calamari-models/GT4HistOCR /var/lib/calamari-models/GT4HistOCR
2019-10-07 12:36:40 +02:00
RUN mkdir -p $TESSDATA_PREFIX
COPY data/tesseract-models/GT4HistOCR/GT4HistOCR_2000000.traineddata $TESSDATA_PREFIX
2019-09-23 15:02:59 +02:00
RUN tesseract --list-langs
2019-09-23 15:02:59 +02:00
# Copy over sbb_textline_detector
COPY vendor vendor
COPY data/textline_detection /var/lib/textline_detection
2019-06-24 16:36:19 +02:00
COPY requirements.txt /tmp
RUN pip3 install --no-cache-dir --upgrade pip && \
pip3 install --no-cache-dir -r /tmp/requirements.txt && \
pip3 check
2019-06-24 16:36:19 +02:00
COPY my_ocrd_workflow /usr/bin
COPY xsd/* /usr/share/xml/
2019-06-24 16:36:19 +02:00
2019-11-19 14:35:23 +01:00
2020-02-04 16:51:38 +01:00
# XXX Work around concurrency problems(?)
RUN sed -i 's#num_cores *= *cpu_count()#num_cores = 1#' /usr/local/lib/python3.6/dist-packages/qurator/sbb_textline_detector/main.py
2019-11-19 14:35:23 +01:00
2019-06-24 16:36:19 +02:00
WORKDIR /data
CMD ["/usr/bin/my_ocrd_workflow"]