This file is indexed.

/usr/include/irstlm/ngramcache.h is in libirstlm-dev 6.00.05-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
// $Id: ngramcache.h 3679 2010-10-13 09:10:01Z bertoldi $

/******************************************************************************
IrstLM: IRST Language Model Toolkit
Copyright (C) 2006 Marcello Federico, ITC-irst Trento, Italy

This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301 USA

******************************************************************************/

#ifndef MF_NGRAMCACHE_H
#define MF_NGRAMCACHE_H

#include "mempool.h"
#include "htable.h"
#include "util.h"

#define NGRAMCACHE_t ngramcache

#define NGRAMCACHE_LOAD_FACTOR  0.5

typedef struct PROB_AND_STATE_ENTRY {
  double logpr;   //!< probability value of an ngram
  ngram_state_t ngramstate;  //!< index of the largest n-gram contained in the LM table.
  char* state;  //!< the largest suffix of an n-gram contained in the LM table.
  unsigned int statesize; //!< LM statesize of an ngram
  double bow;     //!< backoff weight
  int bol;        //!< backoff level
  bool extendible;  //!< flag for extendibility of the ngram
  double lastbow;        //!< bow weight of the deepest found ngram
//  PROB_AND_STATE_ENTRY(double lp=0.0, char* st=NULL, unsigned int stsz=0, double bw=0.0, int bl=0, bool ex=false): logpr(lp), state(st), statesize(stsz), bow(bw), bol(bl), extendible(ex) {}; //initializer
  PROB_AND_STATE_ENTRY(double lp=0.0, ngram_state_t ngramst=0, char* st=NULL, unsigned int stsz=0, double bw=0.0, int bl=0, bool ex=false, double lstbw=0): logpr(lp), ngramstate(ngramst), state(st), statesize(stsz), bow(bw), bol(bl), extendible(ex), lastbow(lstbw) {}; //initializer
} prob_and_state_t;

void print(prob_and_state_t* pst,  std::ostream& out=std::cout);

class ngramcache
{
private:

  static const bool debug=true;

  htable<int*>* ht;
  mempool *mp;
  int maxn;
  int ngsize;
  int infosize;
  int accesses;
  int hits;
  int entries;
  float load_factor; //!< ngramcache loading factor
  void print(const int*);

public:
  ngramcache(int n,int size,int maxentries,float lf=NGRAMCACHE_LOAD_FACTOR);
  ~ngramcache();

  inline int cursize() const {
    return entries;
  }
  inline int maxsize() const {
    return maxn;
  }
  void reset(int n=0);
  char* get(const int* ngp,char*& info);
  char* get(const int* ngp,double& info);
  char* get(const int* ngp,prob_and_state_t& info);
  int add(const int* ngp,const char*& info);
  int add(const int* ngp,const double& info);
  int add(const int* ngp,const prob_and_state_t& info);
  inline int isfull() const {
    return (entries >= maxn);
  }
  void stat() const;
  inline void used() const {
    stat();
  };

  inline float set_load_factor(float value) {
    return load_factor=value;
  }
};

#endif