Source code for bob.bio.vein.preprocessor.preprocessor

#!/usr/bin/env python
# vim: set fileencoding=utf-8 :
import h5py

from bob.bio.base.preprocessor import Preprocessor as BasePreprocessor


class Preprocessor(BasePreprocessor):
    """
    Extracts the mask and pre-processes fingervein images.

    In this implementation, the finger image is (in this order):

      #. The image is pre-cropped to remove obvious non-finger image parts
      #. The mask is extrapolated from the image using one of our
         :py:class:`Masker`'s concrete implementations
      #. The image is normalized with one of our :py:class:`Normalizer`'s
      #. The image is filtered with one of our :py:class:`Filter`'s


    Parameters:

      crop (:py:class:`Cropper`): An object that will perform pre-cropping on
        the input image before a mask can be estimated. It removes parts of the
        image which are surely not part of the finger region you'll want to
        consider for the next steps.

      mask (:py:class:`Masker`): An object representing a Masker instance which
        will extrapolate the mask from the input image.

      normalize (:py:class:`Normalizer`): An object representing a Normalizer
        instance which will normalize the input image and its mask returning a
        new image mask pair.

      filter (:py:class:`Filter`): An object representing a Filter instance will
        will filter the input image and return a new filtered image. The filter
        instance also receives the extrapolated mask so it can, if desired, only
        apply the filtering operation where the mask has a value of ``True``

    """

    def __init__(self, crop, mask, normalize, filter, **kwargs):

        BasePreprocessor.__init__(
            self,
            crop=crop,
            mask=mask,
            normalize=normalize,
            filter=filter,
            **kwargs
        )

        self.crop = crop
        self.mask = mask
        self.normalize = normalize
        self.filter = filter

    def __call__(self, data, annotations=None):
        """Reads the input image or (image, mask) and prepares for fex.

        Parameters:

          data (numpy.ndarray): An 2D numpy array containing a gray-scaled image
            with dtype ``uint8``. The image maybe annotated with an RoI.


        Returns:

          numpy.ndarray: The image, preprocessed and normalized

          numpy.ndarray: A mask, of the same size of the image, indicating where
          the valid data for the object is.

        """

        data = self.crop(data)
        mask = self.mask(data)
        data, mask = self.normalize(data, mask)
        data = self.filter(data, mask)
        return data, mask

[docs] def write_data(self, data, filename): """Overrides the default method implementation to handle our tuple""" with h5py.File(filename, "w") as f: f["image"] = data[0] f["mask"] = data[1]
[docs] def read_data(self, filename): """Overrides the default method implementation to handle our tuple""" with h5py.File(filename, "r") as f: return f["image"][()], f["mask"][()]