13#ifndef LLVM_SUPPORT_BRANCHPROBABILITY_H
14#define LLVM_SUPPORT_BRANCHPROBABILITY_H
32class BranchProbability {
37 static constexpr uint32_t D = 1u << 31;
38 static constexpr uint32_t UnknownN = UINT32_MAX;
48 bool isZero()
const {
return N == 0; }
49 bool isOne()
const {
return N == D; }
66 template <
class ProbabilityIter>
70 template <
class ProbabilityContainer>
77 double toDouble()
const {
return static_cast<double>(N) / D; }
84#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
108 assert(N != UnknownN &&
RHS.N != UnknownN &&
109 "Unknown probability cannot participate in arithmetics.");
116 assert(N != UnknownN &&
RHS.N != UnknownN &&
117 "Unknown probability cannot participate in arithmetics.");
119 N = N <
RHS.N ? 0 : N -
RHS.N;
124 assert(N != UnknownN &&
RHS.N != UnknownN &&
125 "Unknown probability cannot participate in arithmetics.");
126 N = (
static_cast<uint64_t>(N) *
RHS.N + D / 2) / D;
132 "Unknown probability cannot participate in arithmetics.");
138 assert(N != UnknownN &&
RHS.N != UnknownN &&
139 "Unknown probability cannot participate in arithmetics.");
146 "Unknown probability cannot participate in arithmetics.");
147 assert(
RHS > 0 &&
"The divider cannot be zero.");
153 BranchProbability Prob(*
this);
159 BranchProbability Prob(*
this);
165 BranchProbability Prob(*
this);
171 BranchProbability Prob(*
this);
177 BranchProbability Prob(*
this);
183 BranchProbability Prob(*
this);
192 assert(N != UnknownN &&
RHS.N != UnknownN &&
193 "Unknown probability cannot participate in comparisons.");
198 assert(N != UnknownN &&
RHS.N != UnknownN &&
199 "Unknown probability cannot participate in comparisons.");
204 assert(N != UnknownN &&
RHS.N != UnknownN &&
205 "Unknown probability cannot participate in comparisons.");
206 return !(
RHS < *
this);
210 assert(N != UnknownN &&
RHS.N != UnknownN &&
211 "Unknown probability cannot participate in comparisons.");
212 return !(*
this <
RHS);
217 return Prob.
print(OS);
220template <
class ProbabilityIter>
222 ProbabilityIter End) {
226 unsigned UnknownProbCount = 0;
228 [&](
uint64_t S,
const BranchProbability &BP) {
235 if (UnknownProbCount > 0) {
244 std::replace_if(Begin, End,
245 [](
const BranchProbability &BP) {
return BP.
isUnknown(); },
253 BranchProbability BP(1, std::distance(Begin, End));
254 std::fill(Begin, End, BP);
258 for (
auto I = Begin;
I != End; ++
I)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
LLVM_DUMP_METHOD void dump() const
static LLVM_ABI BranchProbability getBranchProbability(uint64_t Numerator, uint64_t Denominator)
BranchProbability operator-(BranchProbability RHS) const
BranchProbability & operator-=(BranchProbability RHS)
static uint32_t getDenominator()
bool operator<(BranchProbability RHS) const
bool operator!=(BranchProbability RHS) const
static BranchProbability getRaw(uint32_t N)
bool operator==(BranchProbability RHS) const
BranchProbability operator/(uint32_t RHS) const
BranchProbability & operator/=(BranchProbability RHS)
LLVM_ABI BranchProbability pow(unsigned N) const
Compute pow(Probability, N).
bool operator<=(BranchProbability RHS) const
static BranchProbability getOne()
LLVM_ABI raw_ostream & print(raw_ostream &OS) const
BranchProbability & operator*=(BranchProbability RHS)
LLVM_ABI uint64_t scaleByInverse(uint64_t Num) const
Scale a large integer by the inverse.
BranchProbability operator*(BranchProbability RHS) const
static BranchProbability getUnknown()
BranchProbability operator/(BranchProbability RHS) const
uint32_t getNumerator() const
LLVM_ABI uint64_t scale(uint64_t Num) const
Scale a large integer.
static void normalizeProbabilities(ProbabilityContainer &&R)
BranchProbability operator+(BranchProbability RHS) const
bool operator>=(BranchProbability RHS) const
BranchProbability operator*(uint32_t RHS) const
BranchProbability & operator*=(uint32_t RHS)
BranchProbability getCompl() const
BranchProbability & operator+=(BranchProbability RHS)
BranchProbability & operator/=(uint32_t RHS)
static BranchProbability getZero()
bool operator>(BranchProbability RHS) const
static void normalizeProbabilities(ProbabilityIter Begin, ProbabilityIter End)
This class implements an extremely fast bulk output stream that can only output to a stream.
This is an optimization pass for GlobalISel generic memory operations.
constexpr auto adl_begin(RangeT &&range) -> decltype(adl_detail::begin_impl(std::forward< RangeT >(range)))
Returns the begin iterator to range using std::begin and function found through Argument-Dependent Lo...
constexpr auto adl_end(RangeT &&range) -> decltype(adl_detail::end_impl(std::forward< RangeT >(range)))
Returns the end iterator to range using std::end and functions found through Argument-Dependent Looku...
raw_ostream & operator<<(raw_ostream &OS, const APFixedPoint &FX)