attributes.sh 4.49 KB
#!/bin/bash

BASE="Open+PP5Register+Rename(PP5_Landmark0_Right_Eye,Affine_0)+Rename(PP5_Landmark1_Left_Eye,Affine_1)+Affine(192,240,.345,.475)+Cvt(Gray)+Stasm(false,true,[(66.24,114),(125.76,114)])"
SUBSPACE="Blur(1.1)+Gamma(0.2)+DoG(1,2)+ContrastEq(0.1,10)+LBP(1,2)+RectRegions(8,8,4,4)+Hist(59)+Cat+PCA(0.95)"

NOSE="RectFromStasmNoseWithBridge+ROI+Resize(36,24)+$SUBSPACE"
MOUTH="RectFromStasmMouth+ROI+Resize(24,36)+$SUBSPACE"
EYES="RectFromStasmEyes+ROI+Resize(24,36)+$SUBSPACE"
HAIR="RectFromStasmHair+ROI+Resize(24,36)+$SUBSPACE"
BROW="RectFromStasmBrow+ROI+Resize(24,36)+$SUBSPACE"
JAW="RectFromStasmJaw+ROI+Resize(36,36)+$SUBSPACE"
FACE="Crop(24,30,144,190)+Resize(36,36)+$SUBSPACE"

ATTDIR=Attributes
mkdir -p $ATTDIR

# Provide a sensible default value for DATA if undefined
DATA=${DATA:-~/data/CUHK-VHDC}

if [ ! -f $ATTDIR/all.model ]; then
  br -crossValidate 2 -algorithm "CrossValidate($BASE+ \
  ($BROW+ \
    TurkClassifier(unibrow,[unibrow],3)/ \
    TurkClassifier(eyebroworientation,[eyebrowsdown,eyebrowsuptodown],3)/ \
    TurkClassifier(thickeyebrows,[thickeyebrows,lighteyebrows],3))/ \
  ($MOUTH+ \
    TurkClassifier(smiling,[smiling],3)/ \
    TurkClassifier(mouthasymmetry,[asymmetrical],3))/ \
  ($EYES+ \
    TurkClassifier(eyecolor,[darkeyes,lighteyes],3)/ \
    TurkClassifier(baggyeyes,[baggy],3)/ \
    TurkClassifier(almondeyes,[almond],3)/ \
    TurkClassifier(buriedeyes,[buriedeyes],3)/ \
    TurkClassifier(sleepyeyes,[sleepy],3)/ \
    TurkClassifier(lineeyes,[line],3)/ \
    TurkClassifier(roundeyes,[round],3)/ \
    TurkClassifier(smalleyes,[smalleyes],3)/ \
    TurkClassifier(glasses,[glasses],3)/ \
    TurkClassifier(eyelashvisibility,[feweyelashes],3))/ \
  ($FACE+ \
    TurkClassifier(gender,[male],3)/ \
    TurkClassifier(cheekdensity,[puffy,in,normal],3)/ \
    TurkClassifier(facemarks,[scars,moles,normal],3)/ \
    TurkClassifier(facelength,[long],3)/ \
    TurkClassifier(nosetomouthdist,[long,small],3))/ \
  ($HAIR+ \
    TurkClassifier(foreheadwrinkles,[wrinkled],3)/ \
    TurkClassifier(haircolor,[darkhair,lighthair,greyhair],3)/ \
    TurkClassifier(hairstyle,[curlyhair],3))/ \
  ($NOSE+ \
    TurkClassifier(noseorientation,[upnose,downnose],3)/ \
    TurkClassifier(nosewidth,[small,thick],3)/ \
    TurkClassifier(nosesize,[smallnose,bignose],3))/ \
  ($JAW+ \
    TurkClassifier(chinsize,[shortchin,longchin],3)) \
  ): \
CrossValidate+Fuse([ \
Turk(unibrow,[unibrow],3), \
Turk(eyebroworientation,[eyebrowsdown,eyebrowsuptodown],3), \
Turk(thickeyebrows,[thickeyebrows,lighteyebrows],3), \
Turk(smiling,[smiling],3), \
Turk(mouthasymmetry,[asymmetrical],3), \
Turk(eyecolor,[darkeyes,lighteyes],3), \
Turk(baggyeyes,[baggy],3), \
Turk(almondeyes,[almond],3), \
Turk(buriedeyes,[buriedeyes],3), \
Turk(sleepyeyes,[sleepy],3), \
Turk(lineeyes,[line],3), \
Turk(roundeyes,[round],3), \
Turk(smalleyes,[smalleyes],3), \
Turk(glasses,[glasses],3), \
Turk(cheekdensity,[puffy,in,normal],3), \
Turk(facemarks,[scars,moles,normal],3), \
Turk(facelength,[long],3), \
Turk(nosetomouthdist,[long,small],3), \
Turk(foreheadwrinkles,[wrinkled],3), \
Turk(haircolor,[darkhair,lighthair,greyhair],3), \
Turk(hairstyle,[curlyhair],3), \
Turk(noseorientation,[upnose,downnose],3), \
Turk(nosewidth,[small,thick],3), \
Turk(nosesize,[smallnose,bignose],3), \
Turk(chinsize,[shortchin,longchin],3)],indices=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,16,17,18,19,20,21,22,23,24,25,26])" \
-path $DATA/CUFSF/target/ -train results1194v2.turk $ATTDIR/all.model
fi

br -crossValidate 2 -path $DATA/CUFSF/target/ -algorithm $ATTDIR/all.model -compare results1194v2.turk results1194v2.turk $ATTDIR/all.mtx

br -crossValidate 2 -setHeader $ATTDIR/all.mtx $DATA/CUFSF/target.xml $DATA/CUFSF/query.xml
br -crossValidate 2 -convert Output $ATTDIR/all.mtx $ATTDIR/all.rank
br -crossValidate 2 -convert Output $ATTDIR/all.mtx $ATTDIR/all_CUFSF%1.eval

# Not trained on: earpitch, earsize, neck thickness
# Not used for comparison: gender, eyelashvisbility

#br -crossValidate 2 -path $DATA/CUFSF/target/ -algorithm models/attributes -enroll results30v2.turk gallery/results30v2.gal

#for attribute in male puffy in scars moles long long small darkeyes lighteyes upnose downnose darkhair lighthair thickeyebrows lighteyebrows upnose downnose small thick smallnose bignose asymmetrical eyebrowsdown eyebrowsuptodown shortchin longchin baggy almond buriedeyes sleepy line round smalleyes smiling feweyelashes wrinkled curlyhair unibrow; do

#echo $attribute
#br -evalRegression gallery/results30v2.gal gallery/results30v2.gal $attribute predicted_$attribute

#done