This algorithm is a legacy one. The API has changed since its implementation. New versions and forks will need to be updated.
This algorithm is splittable

Algorithms have at least one input and one output. All algorithm endpoints are organized in groups. Groups are used by the platform to indicate which inputs and outputs are synchronized together. The first group is automatically synchronized with the channel defined by the block in which the algorithm is deployed.

Group: main

Endpoint Name Data Format Nature
image system/array_2d_uint8/1 Input
features system/array_2d_floats/1 Output

Parameters allow users to change the configuration of an algorithm when scheduling an experiment

Name Description Type Default Range/Choices
regions_cols Number of regions in column uint8 8 [1, 100]
lbp_maxradius Maxmum radius of milti LBP uint8 1 [1, 10]
regions_rows Number of regions in row uint8 8 [1, 100]
lbp_minradius Minimum radius of milti LBP uint8 1 [1, 10]
lbp_circular LBP Circular bool True
lbp_uniform LBP Uniform bool True
lbp_neighbor_count LBP Neighbour count uint8 8 [8, 32]
xxxxxxxxxx
70
 
1
import bob
2
import numpy as np
3
4
5
class Algorithm:
6
7
    def __init__(self):
8
        self.lbp_minradius = 1
9
        self.lbp_maxradius = 10
10
        self.lbp_neighbor_count = 8
11
        self.lbp_uniform = True
12
        self.lbp_circular = True
13
        self.regions_cols = 8
14
        self.regions_rows = 8
15
16
17
18
    def setup(self, parameters):
19
        self.lbp_minradius = parameters.get('lbp_minradius', self.lbp_minradius)
20
        self.lbp_maxradius  = parameters.get('lbp_maxradius',  self.lbp_maxradius)
21
        self.lbp_neighbor_count = parameters.get('lbp_neighbor_count', self.lbp_neighbor_count)
22
        self.lbp_uniform = parameters.get('lbp_uniform', self.lbp_uniform)
23
        self.lbp_circular  = parameters.get('lbp_circular',  self.lbp_circular)
24
        self.regions_cols = parameters.get('regions_cols', self.regions_cols)
25
        self.regions_rows = parameters.get('regions_rows', self.regions_rows)
26
        self.lbp_rotation_invariant  = False
27
        self.lbp_compare_to_average = False
28
        self.lbp_add_average = False
29
        self.lbp_extractors = [bob.ip.LBP(np.int(self.lbp_neighbor_count), np.float(r), 
30
                                          self.lbp_circular, False, False, 
31
                                          self.lbp_uniform, False) for r in xrange(self.lbp_minradius, self.lbp_maxradius+1)]    
32
        return True
33
34
35
    def process(self, inputs, outputs):
36
        cropped_image = inputs["image"].data.value
37
        regions_width = (cropped_image.shape[1]-2*self.lbp_maxradius)/self.regions_cols
38
        regions_height = (cropped_image.shape[0]-2*self.lbp_maxradius)/self.regions_rows
39
        features = np.empty([self.regions_cols*self.regions_rows,0])
40
        assert(features.shape[0]!=self.regions_cols*self.regions_rows,'features.shape[0]!=self.regions_cols*self.regions_rows')
41
        std_lbp_output_image = np.ndarray(self.lbp_extractors[self.lbp_maxradius-1].get_lbp_shape(cropped_image), dtype = np.uint16 )
42
        for i in xrange(len(self.lbp_extractors)):
43
            lbp_output_image = np.ndarray(self.lbp_extractors[i].get_lbp_shape(cropped_image), dtype = np.uint16 )
44
            self.lbp_extractors[i](cropped_image,lbp_output_image)
45
            lbp_output_image = bob.ip.crop(lbp_output_image,
46
                                           int(self.lbp_maxradius-self.lbp_extractors[i].radius),
47
                                           int(self.lbp_maxradius-self.lbp_extractors[i].radius),
48
                                           std_lbp_output_image.shape[0],std_lbp_output_image.shape[1])
49
            lbp_img_blks = bob.ip.block(lbp_output_image,regions_height,regions_width,0,0)
50
            lbp_img_blks = lbp_img_blks.reshape(lbp_img_blks.shape[0]*lbp_img_blks.shape[1],lbp_img_blks.shape[2],lbp_img_blks.shape[3])
51
            lbp_shists = np.empty([self.regions_cols*self.regions_rows,self.lbp_extractors[i].max_label])
52
            for j in xrange(lbp_img_blks.shape[0]):
53
                lbp_hist = np.float32(bob.ip.histogram(lbp_img_blks[j],self.lbp_extractors[i].max_label-1))
54
                lbp_hist /= lbp_hist.sum()
55
                lbp_shists[j] = lbp_hist
56
            features = np.hstack((features,lbp_shists))
57
58
#        if features.shape[1]==118:
59
#            print a
60
#       if features.shape[0]==64:
61
#           print b
62
        assert(features.shape[1]!=59,'features.shape[1]!=59')
63
        assert(features.shape[1]!=self.lbp_extractors[i].max_label*len(self.lbp_extractors),'number of radii not match')
64
#        assert(features.shape[0]!=64,'features.shape[0]!=64')
65
#        assert(features.shape[1]!=59,'features.shape[1]!=59')
66
67
        outputs["features"].write({
68
                "value" : features
69
            })
70
        return True

The code for this algorithm in Python
The ruler at 80 columns indicate suggested POSIX line breaks (for readability).
The editor will automatically enlarge to accomodate the entirety of your input
Use keyboard shortcuts for search/replace and faster editing. For example, use Ctrl-F (PC) or Cmd-F (Mac) to search through this box

Refer to: Chi-Ho Chan, Josef Kittler, Kieron Messer: Multi-scale Local Binary Pattern Histograms for Face Recognition. 809-818

Experiments

Updated Name Databases/Protocols Analyzers
smarcel/chichan/full_pre_mlbphs_projection/2/mobio-f_TT_MLBPH_PCA98_LDA300_postperf-iso mobio/2@female tutorial/eerhter_postperf_iso/1
smarcel/chichan/full_pre_mlbphs_projection/2/mobio-m_TT_MLBPH_PCA98_LDA300_postperf-iso mobio/2@male tutorial/eerhter_postperf_iso/1
smarcel/chichan/full_pre_mlbphs_projection/2/mobio-m_TT_MLBPH_PCA98_postperf-iso mobio/2@male tutorial/eerhter_postperf_iso/1
smarcel/chichan/full_pre_mlbphs_projection/2/mobio-f_TT_MLBPH_PCA98_postperf-iso mobio/2@female tutorial/eerhter_postperf_iso/1
chichan/chichan/full_pre_mlbphs_projection/2/Prep_MLBPH_XM2VTS_nouniform_PCA xm2vts/1@darkened-lp1,xm2vts/1@lp1 tutorial/eerhter_postperf/1
chichan/chichan/full_pre_mlbphs_projection/2/Prep_MLBPH_XM2VTS_LDA xm2vts/1@darkened-lp1,xm2vts/1@lp1 tutorial/eerhter_postperf/1
chichan/chichan/full_pre_mlbphs_projection/2/Prep_MLBPH_XM2VTS_no_uniform_p98LDA xm2vts/1@darkened-lp1,xm2vts/1@lp1 tutorial/eerhter_postperf/1
chichan/chichan/full_pre_mlbphs_projection/2/Prep_MLBPH_XM2VTS_PCA xm2vts/1@darkened-lp1,xm2vts/1@lp1 tutorial/eerhter_postperf/1
Created with Raphaël 2.1.2[compare]chichan/mlbphs_comp_features/322015Oct2

This table shows the number of times this algorithm has been successfully run using the given environment. Note this does not provide sufficient information to evaluate if the algorithm will run when submitted to different conditions.

Terms of Service | Contact Information | BEAT platform version 2.2.1b0 | © Idiap Research Institute - 2013-2025