You can use the multimedia analytics framework in a Big Data environment to perform facial recognition in videos and images.
The multimedia analytics feature of Oracle Big Data Spatial and Graph provides a framework for processing video and image data in Apache Hadoop. The framework enables distributed processing of video and image data. Features of the framework include:
APIs to process and analyze video and image data in Apache Hadoop
APIs to process and analyze video and image data in batch using MapReduce (input data can be in HDFS, Oracle NoSQL Database, or Apache HBase)
APIs to process and analyze streaming video in real-time using Apache Spark
Scalable, high speed processing, leveraging the parallelism of Apache Hadoop
Built-in face recognition using OpenCV
Ability to install and implement custom video/image processing (for example, license plate recognition) to use the framework to run in Apache Hadoop
The video analysis framework is installed on Oracle Big Data Appliance if Oracle Spatial and Graph is licensed, and you can install it on other Hadoop clusters.
The multimedia analytics framework processes video and image data stored in HDFS using MapReduce.
Face recognition using OpenCV is integrated with the framework and available with the product. Third party processing code can also be integrated into the framework for a variety of use cases, such as face recognition, license plate recognition, and object recognition.
Video and image data processing involves the following
Input data comes from HDFS, Oracle NoSQL Database, or Apache HBase.
Video input data can be stored in HDFS, or decoded frames can be stored in Oracle NoSQL Database or Apache HBase.
Image input data can be stored in HDFS, Oracle NoSQL Database, or Apache HBase.
The data is split into a set of images or video frames.
The Images or video frames are processed on each node, using OpenCV or third party code.
The output of processing is stored in HDFS or Apache HBase.
Streaming video from RTSP and HTTP servers can be processed in real time using Apache Spark. Streaming video can also be read from HDFS.
Face detection and face recognition using OpenCV is integrated with the framework and available with the product. Third party processing code can be integrated into the framework for a variety of use cases, such as face recognition, license plate recognition, and object recognition.
Streaming video is processed by a Apache Spark. A Spark job processes each frame and outputs the result into HDFS, or to specialized output locations using custom implementations to write output. Sample implementations of custom writers to write to the local file system and send data to a demo image player are available with the product.
Streaming video processing involves the following
Input data comes from RTSP or HTTP streaming servers or from HDFS. The framework can also read video streaming into HDFS.
Streaming video is decoded into frames.
Video frames are processed by Apache Spark.
Results of the processing can be written to HDFS or to specialized locations, such as an image player using custom plugins. Sample plugins are available for:
Writing JSON, CSV, and/or image data to the local file system
Sending the image data to an image player, enabling the results to be viewed in real time. (A demo image player is included with the product.)
The multimedia analytics feature comes with built-in face recognition. Face recognition uses OpenCV libraries, which are available with the product.
This topic describes using this face recognition functionality with MapReduce to process video and images stored in HDFS. Face recognition has two steps:
“Training” a model with face images. This step can be run in any Hadoop client or node.
Recognizing faces from input video or images using the training model. This step is a MapReduce job that runs in a Hadoop cluster.
The training process creates a model stored in a file. This file is used as input for face recognition from videos or images.
Topics:
Training is done using the Java program OrdFaceTrainer, which is part of ordhadoop_multimedia_analytics.jar. Inputs to this program are a set of images and a label mapping file that maps images to labels. The output is a training model that is written to a file. (You must not edit this file.)
To train the multimedia analytics feature to detect (recognize) faces, follow these steps.
Create a parent directory and subdirectories to store images that are to be recognized.
Each subdirectory should contain one or more images of one person. A person can have images in multiple subdirectories, but a subdirectory can have images of only one person. For example, assume that a parent directory named images exists where one subdirectory (d1) contains images of a person named Andrew, and two subdirectories (d2 and d3) contain images of a person named Betty (such as pictures taken at two different times in two different locations). In this example, the directories and their contents might be as follows:
images/1 contains five images of Andrew.
images/2 contains two images of Betty.
images/3 contains four images of Betty.
Create a mapping file that maps image subdirectories to labels.
A “label” is a numeric ID value to be associated with a person who has images for recognition. For example, Andrew might be assigned the label value 100, and Betty might be assigned the label value 101. Each record (line) in the mapping file must have the following structure:
<subdirectory>,<label-id>,<label-text>
For example:
1,100,Andrew 2,101,Betty 3,101,Betty
Set the required configuration properties:
oracle.ord.hadoop.ordfacemodel oracle.ord.hadoop.ordfacereader oracle.ord.hadoop.ordsimplefacereader.dirmap oracle.ord.hadoop.ordsimplefacereader.imagedir
For information about the available properties, see Configuration Properties for Multimedia Analytics.
Set the CLASSPATH. Include the following in the Java CLASSPATH definition. Replace each asterisk (*) with the actual version number.
$MMA_HOME/lib/ordhadoop-multimedia-analytics.jar $MMA_HOME/opencv_3.0.0/opencv-300.jar $HADOOP_HOME/hadoop-common-*.jar $HADOOP_HOME/hadoop-auth-*.jar $HADOOP_HOME/commons-lang*.jar $HADOOP_HOME/commons-logging-*.jar $HADOOP_HOME/commons-configuration-*.jar $HADOOP_HOME/commons-collections-*.jar $HADOOP_HOME/guava-*.jar $HADOOP_HOME/slf4j-api-*.jar $HADOOP_HOME/slf4j-log4j12-*.jar $HADOOP_HOME/log4j-*.jar $HADOOP_HOME/commons-cli-*.jar $HADOOP_HOME/protobuf-java-*.jar $HADOOP_HOME/avro-*.jar $HADOOP_HOME/hadoop-hdfs-*.jar $HADOOP_HOME/hadoop-mapreduce-client-core-*.jar
Create the training model. Enter a command in the following general form:
java -classpath <…> oracle.ord.hadoop.recognizer.OrdFaceTrainer <training_config_file.xml>
Note:
$MMA_HOME/example has a set of sample files. It includes scripts for setting the Java CLASSPATH. You can edit the example as needed to create a training model.Images used to create the training model should contain only the face, with as little extra detail around the face as possible. The following are some examples, showing four images of the same man’s face with different facial expressions.

The selection of images for training is important for accurate matching. The following guidelines apply:
The set of images should contain faces with all possible positions and facial movements, for example, closed eyes, smiles, and so on.
The images should have the same size.
The images should have good resolution and good pixel quality.
Try to avoid including images that are very similar.
If it is necessary to recognize a person with several backgrounds and light conditions, include images with these backgrounds.
The number of images to include depends on the variety of movements and backgrounds expected in the input data.
An example to process images in a set of images and create good training images is available in: $MMA_HOME/example/facetrain/runFaceTrainUIExample.sh
To detect (recognize) faces in videos, you have the following options for video processing software to transcode video data:
Use OrdOpenCVFaceRecognizerMulti as the frame processor, along with any of the frontal face cascade classifiers available with OpenCV.
Haarcascade_frontalface_alt2.xml is a good place to start. You can experiment with the different cascade classifiers to identify a good fit for your requirements.
Use third-party face recognition software.
To perform recognition, follow these steps:
Copy the video files (containing video in which you want to recognize faces) to HDFS.
Copy these required files to a shared location accessible by all nodes in the cluster:
Generated training model
Mapping file that maps image subdirectories to labels
Cascade classifier XML file
Create the configuration file.
Required configuration parameters:
oracle.ord.hadoop.inputtype: Type if input data (video or image).
oracle.ord.hadoop.outputtypes: Format of generated results (JSON/text/Image).
oracle.ord.hadoop.ordframegrabber: Get a video frame from the video data. You can use the Java classes available with the product or you can provide an implementation for the abstraction.
OrdJCodecFrameGrabber is available with the product. This class can be used without any additional steps. See www.jcodec.org for more details on JCodec.
OrdFFMPEGFrameGrabber is available with the product. This class requires installation of FFMPEG libraries. See www.ffmpeg.org for more details
oracle.ord.hadoop.ordframeprocessor: Processor to use on the video frame to recognize faces. You can use the Java classes available with the product or you can provide an implementation for the abstraction.
oracle.ord.hadoop.recognizer.classifier: Cascade classifier XML file.
oracle.ord.hadoop.recognizer.labelnamefile: Mapping file that maps image subdirectories to labels.
Optional configuration parameters:
oracle.ord.hadoop.frameinterval: Time interval (number of seconds) between frames that are processed. Default: 1.
oracle.ord.hadoop.numofsplits: Number of splits of the video file on the Hadoop cluster, with one split analyzed on each node of the Hadoop cluster. Default: 1.
oracle.ord.hadoop.recognizer.cascadeclassifier.scalefactor: Scale factor to be used for matching images used in training with faces identified in video frames or images. Default: 1.1 (no scaling)
oracle.ord.hadoop.recognizer.cascadeclassifier.minneighbor: Determines size of the sliding window to detect face in video frame or image. Default: 1.
oracle.ord.hadoop.recognizer.cascadeclassifier.flags: Determines type of face detection.
oracle.ord.hadoop.recognizer.cascadeclassifier.minsize: Smallest bounding box used to detect a face.
oracle.ord.hadoop.recognizer.cascadeclassifier.maxsize: Largest bounding box used to detect a face.
oracle.ord.hadoop.recognizer.cascadeclassifier.maxconfidence: Maximum allowable distance between the detected face and a face in the model.
oracle.ord.hadoop.ordframeprocessor.k2: Key class for the implemented class for OrdFrameProcessor.
oracle.ord.hadoop.ordframeprocessor.v2: Value class for the implemented class for OrdFrameProcessor.
Set the HADOOP_CLASSPATH.
Ensure that HADOOP_CLASSPATH includes the files listed in Training to Detect Faces
Run the Hadoop job to recognize faces. Enter a command in the following format:
$ hadoop jar $MMA_HOME/lib/orhadoop-multimedia-analytics.jar -conf <conf file> <hdfs_input_directory_containing_video_data> <hdfs_output_directory_to_write_results>
The accuracy of detecting faces depends on a variety of factors, including lighting, brightness, orientation of the face, distance of the face from the camera, and clarity of the video or image. You should experiment with the configuration properties to determine the best set of values for your use case. Note that it is always possible to have false positives (identifing objects that are not faces as faces) and false recognitions (wrongly labeling a face).
Note:
$MMA_HOME/example has a set of sample files. It includes scripts for setting the Java CLASSPATH. You can edit as needed to submit a job to detect faces.To detect faces in images, copy the images to HDFS. Specify the following property:
<property> <name>oracle.ord.hadoop.inputtype</name> <value>image</value> </property>
Oracle NoSQL Database providesperformance improvements when working with small objects such as images. Images can be stored in Oracle NoSQL Database and accessed by the multimedia analytics framework. If input data is video, then the video must be decoded into frames and the frames stored in Oracle NoSQL Database. HDFS or HBase can be used to store the output of multimedia processing.
The following properties are required when the input is in Oracle NoSQL Database:
oracle.ord.hadoop.datasource – Storage option for input data. Specify kvstore if input data is in Oracle NoSQL Database. Default is HDFS.
oracle.ord.kvstore.input.name – Name of NoSQL Database storage.
oracle.ord.kvstore.input.table – Name of the NoSQL Database table.
oracle.ord.kvstore.input.hosts – Hostname and port.
oracle.ord.kvstore.input.primarykey – Primary key for accessing records in a table.
oracle.ord.hadoop.datasink – Storage option for the output of multimedia analysis. Default is HDFS. Specify HBase to use an HBase table to store the output.
The Oracle NoSQL Database documentation is available at: https://docs.oracle.com/cd/NOSQL/html/index.html
Apache provides performance improvements when working with small objects such as images. Images can be stored in an HBase table and accessed by the multimedia analytics framework. If input data is video, then the video must be decoded into frames and the frames stored in an HBase table.
The following properties are used when the input or output is an HBase table:
oracle.ord.hadoop.datasource – Storage option for input data. Specify HBase if input data is in an HBase table. Default is HDFS.
oracle.ord.hbase.input.table – Name of the HBase table containing the input data.
oracle.ord.hbase.input.columnfamily – Name of the HBase column family containing the input data.
oracle.ord.hbase.input.column – Name of the HBase column containing the input data.
oracle.ord.hadoop.datasink – Storage option for the output of multimedia analysis. Specify HBase to use an HBase table to store the output. Default is HDFS.
oracle.ord.hbase.output.columnfamily – Name of the HBase column family in the output HBase table.
Several examples and training materials are provided to help you get started detecting faces.
$MMA_HOME contains these directories:
video/ (contains a sample video file in mp4 and avi formats) facetrain/ analytics/
facetrain/ contains an example for training, facetrain/config/ contains the sample configuration files, and facetrain/faces/ contains images to create the training model and the mapping file that maps labels to images.
runFaceTrainExample.sh is a bash example script to run the training step.
You can create the training model as follows:
$ ./runFaceTrainExample.sh
The training model will be written to ordfacemodel_bigdata.dat.
For detecting faces in videos, analytics/ contains an example for running a Hadoop job to detect faces in the input video file. This directory contains conf/ with configuration files for the example.
You can run the job as follows (includes copying the video file to HDFS directory vinput)
$ ./runFaceDetectionExample.sh
The output of the job will be in the HDFS directory voutput.
For recognizing faces in videos, analytics/ contains an example for running a Hadoop job to recognize faces in the input video file. This directory contains conf/ with configuration files for the example. You can run the job as follows (includes copying the video file to the HDFS directory vinput):
$ ./runFaceRecognizerExample.sh
After the face recognition job, you can display the output images:
$ ./runPlayImagesExample.sh
The multimedia analytics framework uses the standard methods for specifying configuration properties in the hadooop command. You can use the –conf option to identify configuration files, and the -D option to specify individual properties.
This topic presents reference information about the configuration properties, grouped into the following subtopics:
This category of multimedia analytics framework configuration properties applies to the processing of stored videos and images.
These property names all start with oracle.ord. They can be grouped into two subcategories:
Generic Framework Properties
Face Recognition Properties (contain the string recognizer)
Within each subcategory, the available configuration properties are listed in alphabetical order. For each property the property name is listed, then information about the property.
Generic Framework Properties
String. Storage option for the output of multimedia analysis: HBase to use an HBase table to store the output; otherwise, HDFS. Default value: HDFS. Example:
<property> <name>oracle.ord.hadoop.datasink</name> <value>hbase</value> </property>
String. Storage option for input data: HBase if the input data is in an HBase database; kvstore if the input data is in an Oracle NoSQL Database; otherwise, HDFS. Default value: HDFS: Example:
<property> <name>oracle.ord.hadoop.datasource</name> <value>hbase</value> </property>
String.Timestamp interval (in seconds) to extract frames for processing. Allowable values: positive integers and floating point numbers. Default value: 1. Example:
<property> <name>oracle.ord.hadoop.frameinterval</name> <value>1</value> </property>
Sring. The InputFormat class name in the framework, which represents the input file type in the framework. Default value: oracle.ord.hadoop.OrdVideoInputFormat. Example:
<property> <name>oracle.ord.hadoop.inputformat</name> <value>oracle.ord.hadoop.OrdVideoInputFormat</value> </property>
String. Type of input data: video or image. Example:
<property> <name>oracle.ord.hadoop.inputtype</name> <value>video</value> </property>
Positive integer. Number of the splits of the video files on the Hadoop cluster, with one split able to be analyzed in each node of the Hadoop cluster. Recommended value: the number of nodes/processors in the cluster. Default value: 1. Example:
<property> <name>oracle.ord.hadoop.numofsplits</name> <value>1</value> </property>
String. Name of the file that stores the model created by the training. Example:
<property> <name> oracle.ord.hadoop.ordfacemodel </name> <value>ordfacemodel_bigdata.dat</value> </property>
String. Name of the Java class that reads images used for training the face recognition model. Example:
<property> <name> oracle.ord.hadoop.ordfacereader </name> <value> oracle.ord.hadoop.OrdSimpleFaceReader </value> </property>
String. File containing additional configuration properties for the specific application. Example:
<property> <name> oracle.ord.hadoop.ordfacereaderconfig </name> <value>config/ordsimplefacereader_bigdata.xml</value> </property>
String. Name of the Java class that decodes a video file. This is the implemented class for OrdFrameGrabber, and it is used by the mapper to decode the video file. Available installed implementations with the product: oracle.ord.hadoop.OrdJCodecFrameGrabber (the default) and oracle.ord.hadoop.OrdFFMPEGFrameGrabber (when FFMPEG is installed by the user). You can add custom implementations. Example:
<property>
    <name>oracle.ord.hadoop.ordframegrabber</name>
    <value>oracle.ord.hadoop.OrdJCodecFrameGrabber</value>
</property>
String. Name of the implemented Java class of interface OrdFrameProcessor, which is used by the mapper to process the frame and recognize the object of interest. Default value: oracle.ord.hadoop.mapreduce.OrdOpenCVFaceRecognizerMulti. Example:
<property> <name>oracle.ord.hadoop.ordframeprocessor </name> <value>oracle.ord.hadoop.mapreduce.OrdOpenCVFaceRecognizerMulti</value> </property>
String. Java class name, output key class of the implemented class of interface OrdFrameProcessor. Default value: org.apache.hadoop.io.Text. Example:
<property> <name>oracle.ord.hadoop.ordframeprocessor.k2</name> <value>org.apache.hadoop.io.Text</value> </property>
String. Java class name, output value class of the implemented class of interface OrdFrameProcessor . Default value: oracle.ord.hadoop.mapreduce.OrdImageWritable. Example:
<property> <name>oracle.ord.hadoop.ordframeprocessor.v2 </name> <value>oracle.ord.hadoop.mapreduce.OrdImageWritable</value> </property>
String. Only only relevant for custom (user-specified) plug-ins: name of the implemented Java class of interface OrdOutputProcessor that processes the key-value pair from the map output in the reduce phase. Example:
<property> <name>oracle.ord.hadoop.ordframeprocessor</name> <value>mypackage.MyOutputProcessorClass</value> </property>
String. Mapping file that maps face labels to directory names and face images. Example:
<property> <name> oracle.ord.hadoop.ordsimplefacereader.dirmap </name> <value>faces/bigdata/dirmap.txt</value> </property>
String. File system directory containing faces used to create a model. This is typically in a local file system. Example:
<property> <name> oracle.ord.hadoop.ordsimplefacereader.imagedir </name> <value>faces/bigdata</value> </property>
String. Name of the OutputFormat class, which represents the output file type in the framework. Default value: org.apache.hadoop.mapreduce.lib.output.TextOutputFormat. Example:
<property> <name>oracle.ord.hadoop.outputformat</name> <value> org.apache.hadoop.mapreduce.lib.output.TextOutputFormat; </value> </property>
String. Format of output that contains face labels of identified faces with the time stamp, location, and confidence of the match: must be json, image, or text. Example:
<property> <name>oracle.ord.hadoop.outputtype</name> <value>json</value> </property>
String. File containing additional configuration properties for the specific job. Example:
<property> <name>oracle.ord.hadoop.parameterfile </name> <value>oracle_multimedia_face_recognition.xml</value> </property>
String. Use this property to select the type of object detection. Must be CASCADE_DO_CANNY_PRUNING, CASCADE_SCALE_IMAGE, CASCADE_FIND_BIGGEST_OBJECT (look only for the largest face), or CASCADE_DO_ROUGH_SEARCH. . Default: CASCADE_SCALE_IMAGE | CASCADE_DO_ROUGH_SEARCH. Example:
<property> <name> oracle.ord.hadoop.recognizer.cascadeclassifier.flags</name> <value>CASCADE_SCALE_IMAGE</value> </property>
Floating point value. Specifies how large the distance (difference) between a face in the model and a face in the input data can be. Larger valuse will give more matches but might be less accurate (more false positives). Smaller values will give fewer matches, but be more accurate. Example:
<property> <name> oracle.ord.hadoop.recognizer.cascadeclassifier.maxconfidence</name> <value>200.0</value> </property
String. Name of the HBase column containing the input data. Example:
<property> <name>oracle.ord.hbase.input.column</name> <value>binary_data</value> </property>
String. Name of the HBase column family containing the input data. Example:
<property> <name>oracle.ord.hbase.input.columnfamily</name> <value>image_data</value> </property>
String. Name of the HBase table containing the input data. Example:
<property> <name>oracle.ord.hbase.input.table</name> <value>images</value> </property>
String. Name of the HBase column family in the output HBase table. Example:
<property> <name>oracle.ord.hbase.output.columnfamily</name> <value>face_data</value> </property>
String. Name of the HBase table for output data. Example:
<property> <name>oracle.ord.hbase.output.table</name> <value>results</value> </property>
String. Defines the consistency constraints during read. Read operations can be serviced at a Master or Replica node. The default value of ABSOLUTE ensures the read operation is serviced at the Master node. Example:
<property>
    <name>oracle.ord.kvstore.get.consistency</name>
    <value>absolute</value>
</property>
Number. Upper bound on the time interval for retrieving a chunk of the large object or its associated metadata. A best effort is made not to exceed the specified limit. If zero, the KVStoreConfig.getLOBTimeout(java.util.concurrent.TimeUnit) value is used. Default value is 5. Example:
<property>
    <name>oracle.ord.kvstore.get.timeout</name>
    <value>5</value>
</property>
String. Unit of the timeout parameter, can be NULL only if timeout is zero. Default value is seconds. Example:
<property>
    <name>oracle.ord.kvstore.get.timeunit</name>
    <value>seconds</value>
</property>
String. Host and port of an active node in Oracle NoSQL Database store. Example:
<property>
    <name>oracle.ord.kvstore.input.hosts</name>
    <value>localhost:5000</value>
</property>
Oracle NoSQL Database uses these to construct the keys used to load and retrieve large objects (LOBs). Default value for oracle.ord.kvstore.input.lob.prefix is lobprefix. Default value for oracle.ord.kvstore.input.lob.suffix is lobsuffix.lob. Example:
<property>
    <name>oracle.ord.kvstore.lob.prefix</name>
    <value>lobprefix</value>
</property>
<property>
    <name>oracle.ord.kvstore.lob.suffix</name>
    <value>lobsuffix.lob</value>
</property>
String. Name of Oracle NoSQL Database store. The name provided here must be identical to the name used when the store was installed. Example:
<property>
    <name>oracle.ord.kvstore.input.name</name>
    <value>kvstore</value>
</property>
String. Primary key of the Oracle NoSQL Database table. Example:
<property>
    <name>oracle.ord.kvstore.input.primarykey</name>
    <value>filename</value>
</property>
String. Name of the Oracle NoSQL Database table containing the input data. Example:
<property>
    <name>oracle.ord.kvstore.input.table</name>
    <value>images</value>
</property>
Face Recognition Properties (contain the string recognizer)
String. Use this property to select the type of object detection. Must be CASCADE_DO_CANNY_PRUNING, CASCADE_SCALE_IMAGE, CASCADE_FIND_BIGGEST_OBJECT (look only for the largest face), or CASCADE_DO_ROUGH_SEARCH. . Default: CASCADE_SCALE_IMAGE | CASCADE_DO_ROUGH_SEARCH. Example:
<property> <name> oracle.ord.hadoop.recognizer.cascadeclassifier.flags</name> <value>CASCADE_SCALE_IMAGE</value> </property>
Floating point value. Specifies how large the distance (difference) between a face in the model and a face in the input data can be. Larger valuse will give more matches but might be less accurate (more false positives). Smaller values will give fewer matches, but be more accurate. Example:
<property> <name> oracle.ord.hadoop.recognizer.cascadeclassifier.maxconfidence</name> <value>200.0</value> </property
String, specifically a pair of values. Specifies the maximum size of the bounding box for the object detected. If the object is close by, the bounding box is larger; if the object is far away, like faces on a beach, the bounding box is smaller. Objects with a larger bounding box than the maximum size are ignored. Example:
<property> <name> oracle.ord.hadoop.recognizer.cascadeclassifier.maxsize</name> <value>(500,500)</value> </property>
Integer. Determines the size of the sliding window used to detect the object in the input data. Higher values will detect fewer objects but with higher quality. Default value: 1. Example:
<property> <name> oracle.ord.hadoop.recognizer.cascadeclassifier.minneighbor</name> <value>1</value> </property>
String, specifically a pair of values. Specifies the minimum size of the bounding box for the object detected. If the object is close by, the bounding box is larger; if the object is far away, like faces on a beach, the bounding box is smaller. Objects with a smaller bounding box than the minimum size are ignored. Example:
<property> <name> oracle.ord.hadoop.recognizer.cascadeclassifier.minsize</name> <value>(100,100)</value> </property>
Floating pointnumber. Scale factor to be used with the mapping file that maps face labels to directory names and face images. A value of 1.1 means to perform no scaling before comparing faces in the run-time input with images stored in subdirectories during the training process. Example:
<property> <name> oracle.ord.hadoop.recognizer.cascadeclassifier.scalefactor</name> <value>1.1</value> </property>
String. XML file containing classifiers for face. The feature can be used with any of the frontal face pre-trained classifiers available with OpenCV. Example:
<property> <name> oracle.ord.hadoop.recognizer.classifier</name> <value>haarcascade_frontalface_alt2.xml</value> </property>
String. Mapping file that maps face labels to directory names and face images. Example:
<property> <name> oracle.ord.hadoop.recognizer.labelnamefiler</name> <value>haarcascade_frontalface_alt2.xml</value> </property>
String. File containing the model generated in the training step. The file must be in a shared location, accessible by all cluster nodes. Example:
<property> <name> oracle.ord.hadoop.recognizer.modelfile</name> <value>myface_model.dat</value> </property>
This category of multimedia analytics framework configuration properties applies to the processing of streaming video.
These property names all start with spark.oracle.ord. They can be grouped into two subcategories:
Generic Framework Properties
Face Recognition and Face Detection Properties (contain the string recognizer)
Within each subcategory, the available configuration properties are listed in alphabetical order. For each property the property name is listed, then information about the property.
Generic Framework Properties
String. Frame rate when the sample image player displays the results as frames containing the results of the processing. The player will show a new frame each n seconds. Default is 1.
Example:
spark.oracle.ord.demo.imageplayer.framerate=1
String. Local file system directory that receives the CSV output of video frame processing. Example:
spark.oracle.ord.demo.localfswriter.outputcsvpath=/home/oracle/example/spark/facerecognizer/output/csv
String. Local file system directory that receives the image output of video frame processing. Example:
spark.oracle.ord.demo.localfswriter.outputimagepath=/home/oracle/example/spark/facerecognizer/output/image
String. Local file system directory that receives the JSON output of video frame processing. Example:
spark.oracle.ord.demo.localfswriter.outputjsonpath=/home/oracle/example/spark/facerecognizer/output/json
String. HDFS directory that receives video frames from the Spark streaming adapter. Example:
spark.oracle.ord.inputdirectory=spark_input
String. Local file system directory that receives the image output of video frame processing. Example:
spark.oracle.ord.demo.localfswriter.outputimagepath=/home/oracle/example/spark/facerecognizer/output/image
String. Local file system directory that receives the JSON output of video frame processing. Example:
spark.oracle.ord.demo.localfswriter.outputjsonpath=/home/oracle/example/spark/facerecognizer/output/json
String. Processor to use to process the video frame. You can use the Java classes available with the product for face detection and recognition, or you can provide an implementation for the abstraction. Examples:
spark.oracle.ord.ordsparkframeprocessor=oracle.ord.spark.demo.OrdSparkFaceDetector detects that there is a face in a video frame.
spark. oracle.ord.ordsparkframeprocessor=oracle.ord.spark.demo.OrdSparkFaceRecognizer recognizes the face using the training model.
OrdSparkFaceDetector and OrdSparkFaceRecognizer are available with the product as sample implementations for use with spark.oracle.ord.ordsparkframeprocessor.
String. Name of the class that implements an image player that plays the video frames. Example:
spark.oracle.ord.ordsparkresultwriter=oracle.ord.spark.demo.OrdSparkImagePlayer
String. HDFS directory that receives the output of video frame processing. Example:
spark.oracle.ord.outputdirectory=spark_output
String. Format of generated results (JSON/text/image). Example:
spark.oracle.ord.outputtypes=JSON
Number. The time interval that determines the set of frames processed as a batch. The unit is milliseconds. Default is 5. Example:
spark.oracle.ord.streamingduration=5
String. Output of the Spark job process. By default the output is written to HDFS, but custom writers can be implemented. The product includes a custom writer for writing to the local file system and an image player. Example:
spark.oracle.ord.streamsink=HDFS
Input data for the Spark job. This can be HTTP or RTSP streaming servers, or HDFS. Default is HDFS. Example:
spark.oracle.ord.streamsource=HDFS
Face Recognition and Face Detection Properties (contain the string recognizer)
String. XML file containing classifiers for face. The feature can be used with any of the frontal face pre-trained classifiers available with OpenCV. Example:
spark.oracle.ord.recognizer.classifier=haarcascade_frontalface_alt2_opencv3.0.xml
String. Use this property to select the type of object detection. Must be CASCADE_DO_CANNY_PRUNING, CASCADE_SCALE_IMAGE, CASCADE_FIND_BIGGEST_OBJECT (look only for the largest face), or CASCADE_DO_ROUGH_SEARCH. Default: CASCADE_SCALE_IMAGE | CASCADE_DO_ROUGH_SEARCH. Example:
spark.oracle.ord.recognizer.flags=CASCADE_SCALE_IMAGE|CASCADE_DO_ROUGH_SEARCH
Number. The number of grid cells on the X axis used in each frame to extract histograms. A typical value is 8. The greater the value, higher will be the dimensionality of the resulting feature vector. Example:
spark.oracle.ord.recognizer.gridx=8
Number. The number of grid cells on the Y axis used in each frame to extract histograms. A typical value is 8 .Example:
spark.oracle.ord.recognizer.gridy=8
String. Mapping file that maps face labels to directory names and face images. Example:
spark.oracle.ord.recognizer.labelfilepath=faces/bigdata/dirmap.txt
String. Specifies the maximum size of the bounding box (in number of pixels on the X and Y axis) for the object detected.. If the object is nearby, the bounding box is larger; if the object is far away, such as faces on a beach, the bounding box is smaller. Objects with a larger bounding box than the maximum size are ignored. Example:
spark.oracle.ord.recognizer.maxsize=500
Integer. Available options are 1, 2, or 3. 1 will recognize more faces, but might also recognize objects that are not faces. 3 is the most accurate, but might miss some faces. . Example:
spark.oracle.ord.recognizer.minneighbors=1
String. Specifies the minimum size of the bounding box (in number of pixels on the X and Y axis) for the object detected. If the object is nearby, the bounding box is larger; if the object is far away, such as faces on a beach, the bounding box is smaller. Objects with a smaller bounding box than the minimum size are ignored. Example:
spark.oracle.ord.recognizer.minsize=100
Number. Number of sample points to build a circular local binary pattern. Example:
spark.oracle.ord.recognizer.neighbors=8
Floating point number. Specifies how quickly the algorithm should increase the scale as it makes multiple passes over an image. Setting this higher makes the detector run faster (since it results in fewer passes), but a very high value might miss information as it jumps to a new scale. The default is 1.1, which means the scale increases by 10% in each pass. This parameter can have value 1.1, 1.2, 1.3, or 1.4. Example:
spark.oracle.ord.recognizer.scalefactor=1.1
Number. The value that determines whether a face is matched or not. If the output value when comparing a face with a face in the video is higher than this value, the face is considered not a match. Otherwise it is considered a match.. Default is 130. Example:
spark.oracle.ord.recognizer.threshold=130
String. Name of the file that stores the model created by the training. Example:
spark.oracle.ord.recognizer.trainingmodelpath=ordfacemodel_bigdata.data
This category of multimedia analytics framework configuration properties applies to the training of images for face recognition.
These properties contain the string face, and they are listed in alphabetical order. For each property the property name is listed, then information about the property.
String. Name of the file that stores the model created by the training. Example:
<property> <name> oracle.ord.hadoop.ordfacemodel </name> <value>ordfacemodel_bigdata.dat</value> </property>
String. Name of the Java class that reads images used for training the face recognition model. Example:
<property> <name> oracle.ord.hadoop.ordfacereader </name> <value> oracle.ord.hadoop.OrdSimpleFaceReader </value> </property>
String. File containing additional configuration properties for the specific application. Example:
<property> <name> oracle.ord.hadoop.ordfacereaderconfig </name> <value>config/ordsimplefacereader_bigdata.xml</value> </property>
String. Mapping file that maps face labels to directory names and face images. Example:
<property> <name> oracle.ord.hadoop.ordsimplefacereader.dirmap </name> <value>faces/bigdata/dirmap.txt</value> </property>
String. File system directory containing faces used to create a model. This is typically in a local file system. Example:
<property> <name> oracle.ord.hadoop.ordsimplefacereader.imagedir </name> <value>faces/bigdata</value> </property>
You can implement and install custom modules for multimedia decoding and processing.
You can use a custom video decoder in the framework by implementing the abstract class oracle.ord.hadoop.decoder.OrdFrameGrabber. See the Javadoc for additional details. The product includes two implementations of the video decoder that extend OrdFrameGrabber for JCodec and FFMPEG (requires a separate installation of FFMPEG).
You can use custom multimedia analysis in the framework by implementing two abstract classes.
oracle.ord.hadoop.mapreduce.OrdFrameProcessor<K1,V1,K2,V2>. The extended class of OrdFrameProcessor is used in the map phase of the MapReduce job that processes the video frames or images. (K1, V1) is the input key-value pair types and (K2, V2) is the output key-value pair type. See the Javadoc for additional details. The product includes an implementation using OpenCV.
oracle.ord.hadoop.mapreduce.OrdOutputProcessor<K1,V1,K2,V2>. The extended class of OrdFrameProcessor is used in the reducer phase of the MapReduce job that processes the video frames or images. (K1, V1) is the input key-value pair types and (K2, V2) is the output key-value pair type. See the Javadoc for additional details. Most implementations do not require implementing this class.
An example of framework configuration parameters is available in $MMA_HOME/example/analytics/conf/oracle_multimedia_analysis_framework.xml.
If the output is displayed as images, oracle.ord.hadoop.OrdPlayImages can be used to display all the images in the output HDFS directory. This will display the image frames marked with labels for identified faces. For example:
$ java oracle.ord.hadoop.demo.OrdPlayImages –hadoop_conf_dir $HADOOP_CONF_DIR –image_file_dir voutput