-
-
Notifications
You must be signed in to change notification settings - Fork 7.3k
/
Copy pathaddition_rule.cpp
42 lines (36 loc) · 1.14 KB
/
addition_rule.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/**
* @file
* @brief Addition rule of probabilities
*/
#include <iostream>
/**
* calculates the probability of the independent events A or B for independent
* events
* \parama [in] A probability of event A
* \parama [in] B probability of event B
* \returns probability of A and B
*/
double addition_rule_independent(double A, double B) {
return (A + B) - (A * B);
}
/** Calculates the probability of the events A or B for dependent events
* note that if value of B_given_A is unknown, use chainrule to find it
* \parama [in] A probability of event A
* \parama [in] B probability of event B
* \parama [in] B_given_A probability of event B condition A
* \returns probability of A and B
*/
double addition_rule_dependent(double A, double B, double B_given_A) {
return (A + B) - (A * B_given_A);
}
/** Main function */
int main() {
double A = 0.5;
double B = 0.25;
double B_given_A = 0.05;
std::cout << "independent P(A or B) = " << addition_rule_independent(A, B)
<< std::endl;
std::cout << "dependent P(A or B) = "
<< addition_rule_dependent(A, B, B_given_A) << std::endl;
return 0;
}