This file is indexed.

/usr/include/libwildmagic/Wm5Fluid2Db.h is in libwildmagic-dev 5.13-1.

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
// Geometric Tools, LLC
// Copyright (c) 1998-2014
// Distributed under the Boost Software License, Version 1.0.
// http://www.boost.org/LICENSE_1_0.txt
// http://www.geometrictools.com/License/Boost/LICENSE_1_0.txt
//
// File Version: 5.0.1 (2010/10/01)

#ifndef WM5FLUID2DB_H
#define WM5FLUID2DB_H

#include "Wm5PhysicsLIB.h"
#include "Wm5Vector2.h"

// This class is an implementation based on the ideas in "Real-Time Fluid
// Dynamics for Games", by Jos Stam (GDC 2003 Proceedings), but the code
// is faster in that it processes the source, diffusion, and advection
// terms all at the same time.  The only Gauss-Seidel iteration is in the
// Poisson solver.

namespace Wm5
{

template <typename Real>
class WM5_PHYSICS_ITEM Fluid2Db
{
public:
    // Construction and destruction.
    Fluid2Db (Real x0, Real y0, Real x1, Real y1, Real dt, Real denViscosity,
        Real velViscosity, int imax, int jmax, int numGaussSeidelIterations,
        bool densityDirichlet);

    virtual ~Fluid2Db ();

    // Member access.
    inline Real GetX0 () const;
    inline Real GetY0 () const;
    inline Real GetX1 () const;
    inline Real GetY1 () const;
    inline Real GetDt () const;
    inline Real GetDx () const;
    inline Real GetDy () const;
    inline Real GetTime () const;
    inline int GetIMax () const;
    inline int GetJMax () const;
    inline const Real* GetX () const;
    inline const Real* GetY () const;
    inline Real** GetDensity () const;
    inline Vector2<Real>** GetVelocity () const;

    // Derived classes must provide initialization at time 0.
    virtual Real InitialDensity (Real x, Real y,
        int i, int j) = 0;

    virtual Vector2<Real> InitialVelocity (Real x, Real y,
        int i, int j) = 0;

    // Derived classes must provide source terms.  The density has a
    // source-sink function.  The velocity has a force (impulse) function.
    virtual Real SourceDensity (Real t, Real x, Real y,
        int i, int j) = 0;

    virtual Vector2<Real> SourceVelocity (Real t, Real x, Real y,
        int i, int j) = 0;

    void Initialize ();
    void DoSimulationStep ();

protected:
    // Update the boundary values after the interior values have been
    // assigned.
    void DirichletBoundaryZero (Real** data);
    void NeumannBoundaryZero (Real** data);
    void UpdateDensityBoundary ();
    void UpdateVelocityBoundary ();

    // Swap the buffer pointers.
    void SwapDensityBuffers ();
    void SwapVelocityBuffers ();

    // Constructor inputs.
    Real mX0, mY0, mX1, mY1;
    Real mDt;
    Real mDenViscosity, mVelViscosity;
    int mIMax, mJMax;
    int mNumGaussSeidelIterations;
    bool mDensityDirichlet;

    // Derived quantities;
    int mIMaxM1, mJMaxM1, mIMaxP1, mJMaxP1, mKMaxP1, mNumPixels;
    Real mDx, mDy;
    Real mDxDx, mDyDy;
    Real mHalfDivDx, mHalfDivDy;
    Real mDtDivDx, mDtDivDy, mDtDivDxDx, mDtDivDyDy;
    Real mEpsilon0, mEpsilonX, mEpsilonY;
    Real mDenLambdaX, mDenLambdaY;
    Real mVelLambdaX, mVelLambdaY;
    Real mDenGamma0, mDenGammaX, mDenGammaY;
    Real mVelGamma0, mVelGammaX, mVelGammaY;

    // Current simulation time.
    Real mTime;

    // Lattice cell centers.
    Real* mX;
    Real* mY;

    // State arrays.
    Real** mDensity0;
    Real** mDensity1;
    Vector2<Real>** mVelocity0;
    Vector2<Real>** mVelocity1;
    Real** mDivergence;
    Real** mPoisson;
};

#include "Wm5Fluid2Db.inl"

}

#endif