⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 conflict_2.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// Copyright (c) 2006 INRIA Sophia-Antipolis (France).// All rights reserved.//// This file is part of CGAL (www.cgal.org); you may redistribute it under// the terms of the Q Public License version 1.0.// See the file LICENSE.QPL 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.//// $URL: svn+ssh://scm.gforge.inria.fr/svn/cgal/branches/CGAL-3.3-branch/Apollonius_graph_2/include/CGAL/Apollonius_graph_2/new_traits/Conflict_2.h $// $Id: Conflict_2.h 33210 2006-08-10 09:03:31Z mkaravel $// //// Author(s)     : Menelaos Karavelas <mkaravel@tem.uoc.gr>//                 Christophe Delage <Christophe.Delage@sophia.inria.fr>//                 David Millman <dlm336@cs.nyu.edu>#ifndef CGAL_APOLLONIUS_GRAPH_2_CONFLICT_2_H#define CGAL_APOLLONIUS_GRAPH_2_CONFLICT_2_H 1#include <CGAL/Apollonius_graph_2/basic.h>#include <CGAL/Apollonius_graph_2/Predicate_constructions_C2.h>CGAL_BEGIN_NAMESPACECGAL_APOLLONIUS_GRAPH_2_BEGIN_NAMESPACE//-----------------------------------------------------------------------//                        Conflict Base//-----------------------------------------------------------------------template < class K, class Method_tag >class Conflict_2{public:  typedef Inverted_weighted_point_2<K>  Inverted_weighted_point;  typedef typename K::RT                RT;	  typedef typename K::Sign              Sign;  typedef Sign                          result_type;  struct Arity {};protected:    Sign orientation(const Inverted_weighted_point &p1,                      const Inverted_weighted_point &p2,                     const Inverted_weighted_point &p3) const    {        return sign_of_determinant3x3( p1.p(), p2.p(), p3.p(),				       p1.x(), p2.x(), p3.x(),				       p1.y(), p2.y(), p3.y() );    }    Sign radical_intersection(const Inverted_weighted_point &p1,                              const Inverted_weighted_point &p2,                              const Inverted_weighted_point &p3, int i) const    {        Sign s =  CGAL::sign(		CGAL::square(det3x3_by_formula<RT>(                        p1.p(), p1.weight(), p1.y(),                        p2.p(), p2.weight(), p2.y(),                        p3.p(), p3.weight(), p3.y()))                + CGAL::square(det3x3_by_formula<RT>(                        p1.p(), p1.x(), p1.weight(),                        p2.p(), p2.x(), p2.weight(),                        p3.p(), p3.x(), p3.weight()))                - CGAL::square(det3x3_by_formula<RT>(                        p1.p(), p1.x(), p1.y(),                        p2.p(), p2.x(), p2.y(),                        p3.p(), p3.x(), p3.y())));        if (s != ZERO || i < 0) { return s; }        // perturbation        switch (i) {            case (1) : return radical_side(p3, p2, p1, 3);            case (2) : return radical_side(p1, p3, p2, 3);            case (3) : return radical_side(p1, p2, p3, 3);            default :                CGAL_assertion_msg(false, "Case should not hapen");                return ZERO;        }    }	    Sign radical_side(const Inverted_weighted_point &p1,                      const Inverted_weighted_point &p2,                      const Inverted_weighted_point &p3, int i) const    {        CGAL_assertion(i == -1 || i == 1 || i == 2 || i == 3);        Sign s =  -CGAL::sign(                  det2x2_by_formula<RT>(                      p1.p(), p1.x(),                       p2.p(), p2.x())                   * det3x3_by_formula<RT>(                      p1.p(), p1.weight(), p1.x(),                      p2.p(), p2.weight(), p2.x(),                      p3.p(), p3.weight(), p3.x())                  + det2x2_by_formula<RT>(                      p1.p(), p1.y(),                      p2.p(), p2.y())                  * det3x3_by_formula<RT>(                      p1.p(), p1.weight(), p1.y(),                      p2.p(), p2.weight(), p2.y(),                      p3.p(), p3.weight(), p3.y()));        if (s != ZERO || i < 1) { return s; }        // perturbation        return POSITIVE;    }    Sign power_test(const Inverted_weighted_point &p1,		    const Inverted_weighted_point &p2,		    const Inverted_weighted_point &p3, int i) const    {        CGAL_assertion(i == -1 || i == 1 || i == 2 || i == 3);        Sign s;	Sign s_xTest = sign_of_determinant2x2(p2.p(), p2.x(), p1.p(), p1.x());	if ( s_xTest != ZERO ) {	  s = s_xTest *	    sign_of_determinant3x3( p1.p(), p1.x(), p1.weight(),				    p2.p(), p2.x(), p2.weight(),				    p3.p(), p3.x(), p3.weight() );	} else {            s = sign_determinant2x2( p2.p(), p2.y(), p1.p(), p1.y() ) *	      sign_of_determinant3x3( p1.p(), p1.y(), p1.weight(),				      p2.p(), p2.y(), p2.weight(),				      p3.p(), p3.y(), p3.weight() );	}        if (s != ZERO || i < 1) { return s; }        switch (i) {	case 1:	  return ordered_on_line (p1, p2, p3) ? NEGATIVE : POSITIVE;	case 2:	  return ordered_on_line (p2, p1, p3) ? NEGATIVE : POSITIVE;	case 3:	  return NEGATIVE;	default:	  CGAL_assertion_msg (false, "this should not happen.");        }        // perturbation        bool ool;        if (i == 1) {            ool = ordered_on_line(p2, p1, p3);        } else if (i == 2) {            ool = ordered_on_line(p1, p2, p3);        } else if (i == 3) {            ool = ordered_on_line(p1, p3, p2);         } else 	{		            CGAL_assertion_msg(false, "this does not happen.");            ool = false;        }        if (ool) { return NEGATIVE; }                    return POSITIVE;    }    Sign ordered_on_line_test(const Inverted_weighted_point &p1,                              const Inverted_weighted_point &p2) const    {      Sign s_det = sign_of_determinant2x2( p1.p(), p1.x(), p2.p(), p2.x() );      if ( s_det != ZERO ) { return s_det; }      return sign_of_determinant2x2( p1.p(), p1.y(), p2.p(), p2.y() );    }    bool ordered_on_line(const Inverted_weighted_point &p1,                         const Inverted_weighted_point &p2,                         const Inverted_weighted_point &p3) const    {      if (ordered_on_line_test(p1, p2) == POSITIVE) {	return ordered_on_line_test(p2, p3) == POSITIVE;      }      return ordered_on_line_test(p3, p2) == POSITIVE;    }};CGAL_APOLLONIUS_GRAPH_2_END_NAMESPACECGAL_END_NAMESPACE#endif // CGAL_APOLLONIUS_GRAPH_2_CONFLICT_2_H

⌨️ 快捷键说明

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