This file is indexed.

/usr/include/ssm/ss_csia.h is in libssm-dev 1.1-0ubuntu1.

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
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
// $Id: ss_csia.h,v 1.2 2004/04/28 14:11:21 keb Exp $
/*
     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
*/
// =================================================================
//
//    27.04.04   <--  Date of Last Modification.
//                   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
// -----------------------------------------------------------------
//
//  **** Module  :  ss_csia       <interface>
//       ~~~~~~~~~
//  **** Classes :  CSSGraphMatch ( matching SS graphs )
//       ~~~~~~~~~
//
//  E. Krissinel 2001-2004
//
//  When used, please cite:
//
//   Krissinel, E. and Henrick, K. (2004)
//   Common subgraph isomorphism detection by backtracking search.
//   Software - Practice and Experience, 34, 591-607.
//
// =================================================================
//

#ifndef  __SS_CSIA__
#define  __SS_CSIA__


#ifndef  __SS_Graph__
#include "ss_graph.h"
#endif


//  =========================  CSSMatch  ===========================

DefineClass(CSSMatch)

class CSSMatch : public CStream  {

  friend class CSSGraphMatch;

  public :

    CSSMatch ();
    CSSMatch ( RPCStream Object );
    CSSMatch ( ivector FV1, ivector FV2, int nv, int n, int m );
    ~CSSMatch();

    void SetMatch ( ivector FV1, ivector FV2,
                    int nv, int n, int m );   // FV1[], FV2[] are copied

    void    Swap();

    Boolean isMatch ( ivector FV1, ivector FV2, int nv );

    int  isSubMatch ( ivector FV1, ivector FV2, int nv );
    // return 0 <=> no submatch relations
    //        1 <=> "this" is submatch of (FV1,FV2)
    //       -1 <=> (FV1,FV2) is submatch of "this"

    void GetMatch ( ivector  & FV1,  // do not allocate or
                    ivector  & FV2,  // dispose FV1 and FV2 in
                    int      & nv ); // application!

    void GetMatch ( ivector  & FV1, // do not allocate or
                    ivector  & FV2, // dispose FV1 and FV2 in
                    int      & nv,  // application!
                    realtype & p1,
                    realtype & p2 );

    void read  ( RCFile f );
    void write ( RCFile f );

  protected :
    int     mlength,n1,n2;
    ivector F1,F2;

    void InitSSMatch();

  private :
    int nAlloc;

};

DefineStreamFunctions(CSSMatch)



//  =========================  CSSGraphMatch  ===========================

#define SSMF_UniqueMatch       0x00000001
#define SSMF_BestMatch         0x00000002
#define SSMF_WrongConnectOnly  0x00000004


DefineClass(CSSGraphMatch)

class CSSGraphMatch : public CStream  {

  public :

    CSSGraphMatch ();
    CSSGraphMatch ( RPCStream Object );
    ~CSSGraphMatch();

    void  SetUniqueMatch ( Boolean unique_match );
    void  SetBestMatch   ( Boolean best_match   );
    void  SetMatchBufferLength ( int matchBufLen );
    void  SetFlags       ( word Flags );
    void  RemoveFlags    ( word Flags );

    void  MatchGraphs    ( PCSSGraph Gh1, PCSSGraph Gh2, int minMatch );

    PCSSGraph  GetGraph1 ();
    PCSSGraph  GetGraph2 ();
    void  GetMatches     ( PPCSSMatch & SSMatch, int & nOfMatches );
    int   GetMaxRecursionLevel() { return maxRecursionLevel; }

    int   CheckConnectivity ( int matchNo );

    void  read  ( RCFile f );
    void  write ( RCFile f );


  protected :

    PCSSGraph   G1,G2;
    PPCSSVertex V1;
    PPCSSVertex V2;
    PPCSSEdge   E1;
    PPCSSEdge   E2;
    imatrix     c1,c2;
    Boolean     swap;
    word        flags;
    int         n,m;

    imatrix3    P;
    imatrix     iF1;
    ivector     F1,F2,ix;

    int         nMatches,maxNofMatches;
    PPCSSMatch  Match;
    Boolean     UniqueMatch,BestMatch,wasFullMatch,Stop;
    int         maxMatch,maxCollectedMatch,maxRecursionLevel;

    void  InitSSGraphMatch ();
    void  FreeMemory       ();
    void  FreeRecHeap      ();
    void  GetMemory        ();
    void  GetRecHeap       ();
    int   Initialize       ();
    void  DoMatch          ( int minMatch );
    void  MatchSingleVertex();
    void  Backtrack        ( int i );
    void  Backtrack1       ( int i, int k0 );
    void  CollectMatch     ( int nm );

  private :
    int nAlloc,mAlloc,nMAlloc;

};

DefineStreamFunctions(CSSGraphMatch)


#endif