MySQL 9.6.0
Source Code Documentation
base_volume.h
Go to the documentation of this file.
1// Copyright (c) 2025, Oracle and/or its affiliates.
2//
3// This program is free software; you can redistribute it and/or modify
4// it under the terms of the GNU General Public License, version 2.0,
5// as published by the Free Software Foundation.
6//
7// This program is designed to work with certain software (including
8// but not limited to OpenSSL) that is licensed under separate terms,
9// as designated in a particular file or component or in included license
10// documentation. The authors of MySQL hereby grant you an additional
11// permission to link the program and your derivative works with the
12// separately licensed software that they have either included with
13// the program or referenced in the documentation.
14//
15// This program is distributed in the hope that it will be useful,
16// but WITHOUT ANY WARRANTY; without even the implied warranty of
17// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18// GNU General Public License, version 2.0, for more details.
19//
20// You should have received a copy of the GNU General Public License
21// along with this program; if not, write to the Free Software
22// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
23
24#ifndef MYSQL_SETS_BASE_VOLUME_H
25#define MYSQL_SETS_BASE_VOLUME_H
26
27/// @file
28/// Experimental API header
29
31
32/// @addtogroup GroupLibsMysqlSets
33/// @{
34
35namespace mysql::sets {
36
37/// Return the volume of the first set minus the volume of the second set.
38///
39/// This is the default implementation. The result is accurate for set types
40/// whose volumes can be represented without loss of precision in the return
41/// type from `volume`, i.e., typically set types whose volume does not exceed
42/// std::numeric_limits<uint64_t>::max(). Other set types should override this
43/// function to avoid precision loss for large sets of almost the same size.
44///
45/// @tparam Result_t Type of return value. Default is double. The result will be
46/// exact if it is at most `mysql::math::max_exact_int<double>`.
47///
48/// @tparam Set1_t Type of first set.
49///
50/// @tparam Set2_t Type of second set.
51///
52/// @param set1 First set.
53///
54/// @param set2 Second set.
55template <class Result_t = double, Is_set Set1_t, Is_set Set2_t>
56 requires Is_compatible_set<Set1_t, Set2_t>
57[[nodiscard]] Result_t volume_difference(const Set1_t &set1,
58 const Set2_t &set2) {
59 auto c1 = volume(set1);
60 auto c2 = volume(set2);
61 if (c1 < c2) return -Result_t(c2 - c1);
62 return Result_t(c1 - c2);
63}
64
65} // namespace mysql::sets
66
67// addtogroup GroupLibsMysqlSets
68/// @}
69
70#endif // ifndef MYSQL_SETS_BASE_VOLUME_H
Definition: gtid_set.h:183
constexpr auto volume(const Boundary_set_t &set)
Return the sum of the lengths of all intervals in the given Boundary set.
Definition: boundary_set_volume.h:43
Result_t volume_difference(const Set1_t &set1, const Set2_t &set2)
Return the volume of the first set minus the volume of the second set.
Definition: base_volume.h:57
Experimental API header.