Classes | Typedefs | Functions
aib.h File Reference

AIB (Agglomerative Information Bottleneck (AIB)) More...

#include "generic.h"
#include "mathop.h"
Include dependency graph for aib.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

struct  _VlAIB

Typedefs

typedef struct _VlAIB VlAIB

Functions

VL_INLINE int vl_aib_get_verbosity (VlAIB const *self)
 Get the verbosity.
VL_INLINE void vl_aib_set_verbosity (VlAIB *self, int verbosity)
 Set the verbosity.
Create and destroy
VL_EXPORT VlAIBvl_aib_new (double *Pcx, vl_uint nvalues, vl_uint nlabels)
 Allocates and initializes the internal data structure.
VL_EXPORT void vl_aib_delete (VlAIB *aib)
 Deletes AIB data structure.
Process data
VL_EXPORT void vl_aib_process (VlAIB *aib)
 Runs AIB on Pcx.
Retrieve results
VL_INLINE vl_uintvl_aib_get_parents (VlAIB const *aib)
 Get resulting list of parents.
VL_INLINE double * vl_aib_get_costs (VlAIB const *aib)
 Get a list of merge costs.

Detailed Description

AIB (Agglomerative Information Bottleneck (AIB))

Author:
Brian Fulkerson
Andrea Vedaldi

Definition in file aib.h.


Typedef Documentation

typedef struct _VlAIB VlAIB

------------------------------------------------------------------


Function Documentation

VL_EXPORT void vl_aib_delete ( VlAIB aib)

Deletes AIB data structure.

------------------------------------------------------------------

Parameters:
aibdata structure to delete.

Definition at line 534 of file vl/aib.c.

VL_INLINE double * vl_aib_get_costs ( VlAIB const *  aib)

Get a list of merge costs.

------------------------------------------------------------------

Parameters:
aibAIB filter.
Returns:
An array of costs

Definition at line 107 of file aib.h.

VL_INLINE vl_uint * vl_aib_get_parents ( VlAIB const *  aib)

Get resulting list of parents.

------------------------------------------------------------------

Parameters:
aibAIB filter.
Returns:
An array of parents

Definition at line 96 of file aib.h.

VL_INLINE int vl_aib_get_verbosity ( VlAIB const *  self)

Get the verbosity.

Parameters:
selfAIB object.
Returns:
the verbosity level.

Definition at line 128 of file aib.h.

VL_EXPORT VlAIB* vl_aib_new ( double *  Pcx,
vl_uint  nvalues,
vl_uint  nlabels 
)

Allocates and initializes the internal data structure.

------------------------------------------------------------------

Parameters:
PcxA pointer to a 2D array of probabilities
nvaluesThe number of rows in the array
nlabelsThe number of columns in the array

Creates a new VlAIB struct containing pointers to all the data that will be used during the AIB process.

Allocates memory for the following:

  • Px (nvalues*sizeof(double))
  • Pc (nlabels*sizeof(double))
  • nodelist (nvalues*sizeof(vl_uint))
  • which (nvalues*sizeof(vl_uint))
  • beta (nvalues*sizeof(double))
  • bidx (nvalues*sizeof(vl_uint))
  • parents ((2*nvalues-1)*sizeof(vl_uint))
  • costs (nvalues*sizeof(double))

Since it simply copies to pointer to Pcx, the total additional memory requirement is:

(3*nvalues+nlabels)*sizeof(double) + 4*nvalues*sizeof(vl_uint)

Returns:
An allocated and initialized VlAIB pointer

Definition at line 489 of file vl/aib.c.

VL_EXPORT void vl_aib_process ( VlAIB aib)

Runs AIB on Pcx.

------------------------------------------------------------------

Parameters:
aibAIB object to process

The function runs Agglomerative Information Bottleneck (AIB) on the joint probability table aib->Pcx which has labels along the columns and feature values along the rows. AIB iteratively merges the two values of the feature x that causes the smallest decrease in mutual information between the random variables x and c.

Merge operations are arranged in a binary tree. The nodes of the tree correspond to the original feature values and any other value obtained as a result of a merge operation. The nodes are indexed in breadth-first order, starting from the leaves. The first index is zero. In this way, the leaves correspond directly to the original feature values. In total there are 2*nvalues-1 nodes.

The results may be accessed through vl_aib_get_parents which returns an array with one element per tree node. Each element is the index the parent node. The root parent is equal to zero. The array has 2*nvalues-1 elements.

Feature values with null probability are ignored by the algorithm and their nodes have parents indexing a non-existent tree node (a value bigger than 2*nvalues-1).

Then the function will also compute the information level after each merge. vl_get_costs will return a vector with the information level after each merge. cost has nvalues entries: The first is the value of the cost functional before any merge, and the others are the cost after the nvalues-1 merges.

Definition at line 588 of file vl/aib.c.

VL_INLINE void vl_aib_set_verbosity ( VlAIB self,
int  verbosity 
)

Set the verbosity.

Parameters:
selfAIB object.
verbositya non-negative integer.

Definition at line 118 of file aib.h.



libvlfeat
Author(s): Andrea Vedaldi
autogenerated on Thu Jun 6 2019 20:25:51