12 #ifndef FAISS_POLYSEMOUS_TRAINING_INCLUDED 
   13 #define FAISS_POLYSEMOUS_TRAINING_INCLUDED 
   16 #include "ProductQuantizer.h" 
   28     double init_temperature;   
 
   29     double temperature_decay;  
 
   48     virtual double compute_cost (
const int *perm) 
const = 0;
 
   52     virtual double cost_update (
const int *perm, 
int iw, 
int jw) 
const;
 
   60     double dis_weight_factor;
 
   62     static double sqr (
double x) { 
return x * x; }
 
   66     double dis_weight (
double x) 
const;
 
   72     double get_source_dis (
int i, 
int j) 
const;
 
   75     double compute_cost(
const int* perm) 
const override;
 
   79     double cost_update(
const int* perm, 
int iw, 
int jw) 
const override;
 
   83            const double *source_dis_in,
 
   84            const double *target_dis_in,
 
   85            double dis_weight_factor);
 
   87     static void compute_mean_stdev (
const double *tab, 
size_t n2,
 
   88                                     double *mean_out, 
double *stddev_out);
 
   90     void set_affine_target_dis (
const double *source_dis_in);
 
   95 struct RandomGenerator;
 
  113     double optimize (
int *perm);
 
  116     double run_optimization (
int * best_perm);
 
  137     int ntrain_permutation;
 
  138     double dis_weight_factor; 
 
  141     std::string log_pattern;
 
  149                                   size_t n, 
const float *x) 
const;
 
random generator that can be used in multithreaded contexts 
same as _2, but use rank of y+ - rank of y- 
SimulatedAnnealingOptimizer(PermutationObjective *obj, const SimulatedAnnealingParameters &p)
logs values of the cost function 
int n
size of the permutation 
const double * target_dis
wanted distances (size n^2) 
double init_cost
remember intial cost of optimization 
void optimize_ranking(ProductQuantizer &pq, size_t n, const float *x) const 
called by optimize_pq_for_hamming 
optimizes the order of indices in a ProductQuantizer 
std::vector< double > weights
weights for each distance (size n^2) 
parameters used for the simulated annealing method 
abstract class for the loss function 
std::vector< double > source_dis
"real" corrected distances (size n^2) 
void optimize_reproduce_distances(ProductQuantizer &pq) const 
called by optimize_pq_for_hamming 
void optimize_pq_for_hamming(ProductQuantizer &pq, size_t n, const float *x) const 
Simulated annealing optimization algorithm for permutations.