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

📄 lexicographic.hpp

📁 CGAL is a collaborative effort of several sites in Europe and Israel. The goal is to make the most i
💻 HPP
字号:
/* Boost interval/compare/lexicographic.hpp template implementation file * * Copyright 2002-2003 Guillaume Melquiond * * Distributed under the Boost Software License, Version 1.0. * (See accompanying file LICENSE_1_0.txt or * copy at http://www.boost.org/LICENSE_1_0.txt) */#ifndef BOOST_NUMERIC_INTERVAL_COMPARE_LEXICOGRAPHIC_HPP#define BOOST_NUMERIC_INTERVAL_COMPARE_LEXICOGRAPHIC_HPP#include <boost/numeric/interval/detail/interval_prototype.hpp>#include <boost/numeric/interval/detail/test_input.hpp>namespace boost {namespace numeric {namespace interval_lib {namespace compare {namespace lexicographic {template<class T, class Policies1, class Policies2> inlinebool operator<(const interval<T, Policies1>& x, const interval<T, Policies2>& y){  if (detail::test_input(x, y)) throw comparison_error();  const T& xl = x.lower();  const T& yl = y.lower();  return xl < yl || (xl == yl && x.upper() < y.upper());}template<class T, class Policies> inlinebool operator<(const interval<T, Policies>& x, const T& y){  if (detail::test_input(x, y)) throw comparison_error();  return x.lower() < y;}template<class T, class Policies1, class Policies2> inlinebool operator<=(const interval<T, Policies1>& x, const interval<T, Policies2>& y){  if (detail::test_input(x, y)) throw comparison_error();  const T& xl = x.lower();  const T& yl = y.lower();  return xl < yl || (xl == yl && x.upper() <= y.upper());}template<class T, class Policies> inlinebool operator<=(const interval<T, Policies>& x, const T& y){  if (detail::test_input(x, y)) throw comparison_error();  const T& xl = x.lower();  return xl < y || (xl == y && x.upper() <= y);}template<class T, class Policies1, class Policies2> inlinebool operator>(const interval<T, Policies1>& x, const interval<T, Policies2>& y){  if (detail::test_input(x, y)) throw comparison_error();  const T& xl = x.lower();  const T& yl = y.lower();  return xl > yl || (xl == yl && x.upper() > y.upper());}template<class T, class Policies> inlinebool operator>(const interval<T, Policies>& x, const T& y){  if (detail::test_input(x, y)) throw comparison_error();  const T& xl = x.lower();  return xl > y || (xl == y && x.upper() > y);}template<class T, class Policies1, class Policies2> inlinebool operator>=(const interval<T, Policies1>& x, const interval<T, Policies2>& y){  if (detail::test_input(x, y)) throw comparison_error();  const T& xl = x.lower();  const T& yl = y.lower();  return xl > yl || (xl == yl && x.upper() >= y.upper());}template<class T, class Policies> inlinebool operator>=(const interval<T, Policies>& x, const T& y){  if (detail::test_input(x, y)) throw comparison_error();  return x.lower() >= y;}template<class T, class Policies1, class Policies2> inlinebool operator==(const interval<T, Policies1>& x, const interval<T, Policies2>& y){  if (detail::test_input(x, y)) throw comparison_error();  return x.lower() == y.lower() && x.upper() == y.upper();}template<class T, class Policies> inlinebool operator==(const interval<T, Policies>& x, const T& y){  if (detail::test_input(x, y)) throw comparison_error();  return x.lower() == y && x.upper() == y;}template<class T, class Policies1, class Policies2> inlinebool operator!=(const interval<T, Policies1>& x, const interval<T, Policies2>& y){  if (detail::test_input(x, y)) throw comparison_error();  return x.lower() != y.lower() || x.upper() != y.upper();}template<class T, class Policies> inlinebool operator!=(const interval<T, Policies>& x, const T& y){  if (detail::test_input(x, y)) throw comparison_error();  return x.lower() != y || x.upper() != y;}} // namespace lexicographic} // namespace compare} // namespace interval_lib} // namespace numeric} // namespace boost#endif // BOOST_NUMERIC_INTERVAL_COMPARE_LEXICOGRAPHIC_HPP

⌨️ 快捷键说明

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