side_of_oriented_sphere_3.h

来自「CGAL is a collaborative effort of severa」· C头文件 代码 · 共 143 行

H
143
字号
// Copyright (c) 2001,2004  Utrecht University (The Netherlands),// ETH Zurich (Switzerland), Freie Universitaet Berlin (Germany),// INRIA Sophia-Antipolis (France), Martin-Luther-University Halle-Wittenberg// (Germany), Max-Planck-Institute Saarbruecken (Germany), RISC Linz (Austria),// and Tel-Aviv University (Israel).  All rights reserved.//// This file is part of CGAL (www.cgal.org); 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; version 2.1 of the License.// See the file LICENSE.LGPL distributed with CGAL.//// Licensees holding a valid commercial license may use this file in// accordance with the commercial license agreement provided with the software.//// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.//// $Source: /CVSROOT/CGAL/Packages/Interval_arithmetic/include/CGAL/Static_filters/Side_of_oriented_sphere_3.h,v $// $Revision: 1.26 $ $Date: 2004/11/18 14:25:53 $// $Name:  $//// Author(s)     : Sylvain Pion#ifndef CGAL_STATIC_FILTERS_SIDE_OF_ORIENTED_SPHERE_3_H#define CGAL_STATIC_FILTERS_SIDE_OF_ORIENTED_SPHERE_3_H#include <CGAL/Profile_counter.h>#include <CGAL/Static_filter_error.h>CGAL_BEGIN_NAMESPACEtemplate < typename K_base >class SF_Side_of_oriented_sphere_3  : public K_base::Side_of_oriented_sphere_3{  typedef typename K_base::Point_3                      Point_3;  typedef typename K_base::Side_of_oriented_sphere_3    Base;public:  Oriented_side  operator()(const Point_3 &p, const Point_3 &q, const Point_3 &r,             const Point_3 &s, const Point_3 &t) const  {      CGAL_PROFILER("In_sphere_3 calls");      double px, py, pz, qx, qy, qz, rx, ry, rz, sx, sy, sz, tx, ty, tz;      if (fit_in_double(p.x(), px) && fit_in_double(p.y(), py) &&          fit_in_double(p.z(), pz) &&          fit_in_double(q.x(), qx) && fit_in_double(q.y(), qy) &&          fit_in_double(q.z(), qz) &&          fit_in_double(r.x(), rx) && fit_in_double(r.y(), ry) &&          fit_in_double(r.z(), rz) &&          fit_in_double(s.x(), sx) && fit_in_double(s.y(), sy) &&          fit_in_double(s.z(), sz) &&          fit_in_double(t.x(), tx) && fit_in_double(t.y(), ty) &&          fit_in_double(t.z(), tz))      {          CGAL_PROFILER("In_sphere_3 semi-static attempts");          double ptx = px - tx;          double pty = py - ty;          double ptz = pz - tz;          double pt2 = CGAL_NTS square(ptx) + CGAL_NTS square(pty)	             + CGAL_NTS square(ptz);          double qtx = qx - tx;          double qty = qy - ty;          double qtz = qz - tz;          double qt2 = CGAL_NTS square(qtx) + CGAL_NTS square(qty)	             + CGAL_NTS square(qtz);          double rtx = rx - tx;          double rty = ry - ty;          double rtz = rz - tz;          double rt2 = CGAL_NTS square(rtx) + CGAL_NTS square(rty)	             + CGAL_NTS square(rtz);          double stx = sx - tx;          double sty = sy - ty;          double stz = sz - tz;          double st2 = CGAL_NTS square(stx) + CGAL_NTS square(sty)	             + CGAL_NTS square(stz);          // Compute the semi-static bound.          double maxx = fabs(ptx);          if (maxx < fabs(qtx)) maxx = fabs(qtx);          if (maxx < fabs(rtx)) maxx = fabs(rtx);          if (maxx < fabs(stx)) maxx = fabs(stx);          double maxy = fabs(pty);          if (maxy < fabs(qty)) maxy = fabs(qty);          if (maxy < fabs(rty)) maxy = fabs(rty);          if (maxy < fabs(sty)) maxy = fabs(sty);          double maxz = fabs(ptz);          if (maxz < fabs(qtz)) maxz = fabs(qtz);          if (maxz < fabs(rtz)) maxz = fabs(rtz);          if (maxz < fabs(stz)) maxz = fabs(stz);	  double maxt = maxx;          if (maxt < maxy) maxt = maxy;          if (maxt < maxz) maxt = maxz;          double eps = 1.246613653102729e-13 * maxx * maxy * maxz                     * (maxt * maxt);          double det = det4x4_by_formula(ptx,pty,ptz,pt2,                                         rtx,rty,rtz,rt2,                                         qtx,qty,qtz,qt2,                                         stx,sty,stz,st2);          // Protect against underflow in the computation of eps.          if (maxx < 1e-59 || maxy < 1e-59 || maxz < 1e-59) {            if (maxx == 0 || maxy == 0 || maxz == 0)              return ON_ORIENTED_BOUNDARY;          }          else {            if (det > eps)  return ON_POSITIVE_SIDE;            if (det < -eps) return ON_NEGATIVE_SIDE;          }          CGAL_PROFILER("In_sphere_3 semi-static failures");      }      return Base::operator()(p, q, r, s, t);  }  // Computes the epsilon for In_sphere_3.  static double compute_epsilon()  {    typedef CGAL::Static_filter_error F;    F t1 = F(1,F::ulp()/2);         // First translation    F sq = t1*t1+t1*t1+t1*t1; // squares    F det = det4x4_by_formula(t1, t1, t1, sq,                              t1, t1, t1, sq,                              t1, t1, t1, sq,                              t1, t1, t1, sq); // Full det    double err = det.error();    std::cerr << "*** epsilon for In_sphere_3 = " << err << std::endl;    return err;  }};CGAL_END_NAMESPACE#endif // CGAL_STATIC_FILTERS_SIDE_OF_ORIENTED_SPHERE_3_H

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?