mirror of
https://hub.njuu.cf/TheAlgorithms/C-Plus-Plus.git
synced 2023-10-11 13:05:55 +08:00
46 lines
1.1 KiB
C++
46 lines
1.1 KiB
C++
/**
|
|
* @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;
|
|
}
|