/usr/include/sc/math/isosurf/edge.h is in libsc-dev 2.3.1-16.
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 | //
// edge.h
//
// Copyright (C) 1996 Limit Point Systems, Inc.
//
// Author: Curtis Janssen <cljanss@limitpt.com>
// Maintainer: LPS
//
// This file is part of the SC Toolkit.
//
// The SC Toolkit is free software; you can redistribute it and/or modify
// it under the terms of the GNU Library General Public License as published by
// the Free Software Foundation; either version 2, or (at your option)
// any later version.
//
// The SC Toolkit 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 Library General Public License for more details.
//
// You should have received a copy of the GNU Library General Public License
// along with the SC Toolkit; see the file COPYING.LIB. If not, write to
// the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
//
// The U.S. Government is granted a limited license as per AL 91-7.
//
#ifndef _math_isosurf_edge_h
#define _math_isosurf_edge_h
#ifdef __GNUC__
#pragma interface
#endif
#include <set>
#include <math/isosurf/vertex.h>
namespace sc {
class Edge: public RefCount {
private:
int _order;
Ref<Vertex> *_vertices; // nvertices = _order + 1
public:
Edge(const Ref<Vertex> &p1,
const Ref<Vertex> &p2)
{
_order = 1;
_vertices = new Ref<Vertex>[2];
_vertices[0]=p1; _vertices[1]=p2;
}
Edge(const Ref<Vertex> &p1,
const Ref<Vertex> &p2,
const Ref<Vertex> &p3);
Edge(const Ref<Vertex> &p1,
const Ref<Vertex> &p2,
const Ref<Vertex> &p3,
const Ref<Vertex> &p4);
~Edge();
int order() const { return _order; }
double straight_length();
// return the endpoints
Ref<Vertex> vertex(int i) const
{
return i?_vertices[_order]:_vertices[0];
}
// returns endpoints or interior vertex 0 <= i <= order
Ref<Vertex> interior_vertex(int i) const
{
return _vertices[i];
}
// add the endpoints to the set
void add_vertices(std::set<Ref<Vertex> >&);
void set_order(int order, const Ref<Volume>&vol,double isovalue);
// find the position of a point on the edge
int interpolate(double location, SCVector3&point, SCVector3&norm);
// find the true position of a point using the isosurface
int interpolate(double location, SCVector3&point, SCVector3&norm,
const Ref<Volume> &vol, double isovalue);
};
}
#endif
// Local Variables:
// mode: c++
// c-file-style: "CLJ"
// End:
|