/usr/include/libwildmagic/Wm5MassSpringSurface.h is in libwildmagic-dev 5.13-1ubuntu3.
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 | // 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 WM5MASSSPRINGSURFACE_H
#define WM5MASSSPRINGSURFACE_H
#include "Wm5PhysicsLIB.h"
#include "Wm5ParticleSystem.h"
namespace Wm5
{
template <typename Real, typename TVector>
class WM5_PHYSICS_ITEM MassSpringSurface : public ParticleSystem<Real,TVector>
{
public:
// Construction and destruction. This class represents an RxC array of
// masses lying on a surface and connected by an array of springs. The
// masses are indexed by mass[r][c] for 0 <= r < R and 0 <= c < C. The
// mass at interior position X[r][c] is connected by springs to the
// masses at positions X[r-1][c], X[r+1][c], X[r][c-1], and X[r][c+1].
// Boundary masses have springs connecting them to the obvious neighbors
// ("edge" mass has 3 neighbors, "corner" mass has 2 neighbors). The
// masses are arranged in row-major order: position[c+C*r] = X[r][c]
// for 0 <= r < R and 0 <= c < C. The other arrays are stored similarly.
MassSpringSurface (int numRows, int numCols, Real step);
virtual ~MassSpringSurface ();
int GetNumRows () const;
int GetNumCols () const;
void SetMass (int row, int col, Real mass);
Real GetMass (int row, int col) const;
TVector** Positions2D () const;
TVector& Position (int row, int col);
TVector** Velocities2D () const;
TVector& Velocity (int row, int col);
// The interior mass at (r,c) has springs to the left, right, bottom, and
// top. Edge masses have only three neighbors and corner masses have only
// two neighbors. The mass at (r,c) provides access to the springs
// connecting to locations (r,c+1) and (r+1,c). Edge and corner masses
// provide access to only a subset of these. The caller is responsible
// for ensuring the validity of the (r,c) inputs.
Real& ConstantR (int row, int col); // spring to (r+1,c)
Real& LengthR (int row, int col); // spring to (r+1,c)
Real& ConstantC (int row, int col); // spring to (r,c+1)
Real& LengthC (int row, int col); // spring to (r,c+1)
// Callback for acceleration (ODE solver uses x" = F/m) applied to
// particle i. The positions and velocities are not necessarily
// mPositions and mVelocities since the ODE solver evaluates the
// impulse function at intermediate positions.
virtual TVector Acceleration (int i, Real time,
const TVector* positions, const TVector* velocities);
// The default external force is zero. Derive a class from this one to
// provide nonzero external forces such as gravity, wind, friction,
// and so on. This function is called by Acceleration(...) to append the
// acceleration F/m generated by the external force F.
virtual TVector ExternalAcceleration (int i, Real time,
const TVector* positions, const TVector* velocities);
protected:
using ParticleSystem<Real,TVector>::mInvMasses;
using ParticleSystem<Real,TVector>::mPositions;
using ParticleSystem<Real,TVector>::mVelocities;
int GetIndex (int row, int col) const;
void GetCoordinates (int i, int& row, int& col) const;
int mNumRows; // R
int mNumCols; // C
TVector** mPositionGrid; // R-by-C
TVector** mVelocityGrid; // R-by-C
int mNumRowsM1; // R-1
int mNumColsM1; // C-1
Real** mConstantsR; // (R-1)-by-C
Real** mLengthsR; // (R-1)-by-C
Real** mConstantsC; // R-by-(C-1)
Real** mLengthsC; // R-by-(C-1)
};
typedef MassSpringSurface<float,Vector2f> MassSpringSurface2f;
typedef MassSpringSurface<double,Vector2d> MassSpringSurface2d;
typedef MassSpringSurface<float,Vector3f> MassSpringSurface3f;
typedef MassSpringSurface<double,Vector3d> MassSpringSurface3d;
}
#endif
|