Skip to content
Snippets Groups Projects
Select Git revision
  • c98dee92a4d7a9297506c068d155d9ff02e17575
  • master default protected
  • gh-pages
  • v4.0.3
  • v4.0.2
  • v4.0.1
  • v4.0.0
  • v3.3.7+1
  • v3.3.7
  • v1.0.8
  • v1.0.7
  • v1.0.6
  • v1.0.5
  • v1.0.4
  • v1.0.3
  • v1.0.2
  • v1.0.1
  • v1.0.0
18 results

morris.html

Blame
  • emd.h 1.52 KiB
    #ifdef __cplusplus
    extern "C" {
    #endif // DEBUG
    
    #ifndef _EMD_H
    #define _EMD_H
    /*
        emd.h
    
        Last update: 3/24/98
    
        An implementation of the Earth Movers Distance.
        Based of the solution for the Transportation problem as described in
        "Introduction to Mathematical Programming" by F. S. Hillier and 
        G. J. Lieberman, McGraw-Hill, 1990.
    
        Copyright (C) 1998 Yossi Rubner
        Computer Science Department, Stanford University
        E-Mail: rubner@cs.stanford.edu   URL: http://vision.stanford.edu/~rubner
    */
    
    
    /* DEFINITIONS */
    #define MAX_SIG_SIZE   100
    #define MAX_ITERATIONS 500
    #define INFINITY       1e20
    #define EPSILON        1e-6
    
    /*****************************************************************************/
    /* feature_t SHOULD BE MODIFIED BY THE USER TO REFLECT THE FEATURE TYPE      */
    typedef float feature_t;
    /*****************************************************************************/
    
    
    typedef struct
    {
      int n;                /* Number of features in the signature */
      feature_t *Features;  /* Pointer to the features vector */
      float *Weights;       /* Pointer to the weights of the features */
    } signature_t;
    
    
    typedef struct
    {
      int from;             /* Feature number in signature 1 */
      int to;               /* Feature number in signature 2 */
      float amount;         /* Amount of flow from "from" to "to" */
    } flow_t;
    
    
    
    float emd(signature_t *Signature1, signature_t *Signature2,
    	  float (*func)(feature_t *, feature_t *),
    	  flow_t *Flow, int *FlowSize);
    
    #endif
    
    #ifdef __cplusplus
    }
    #endif // __cplusplus