MapFunction.cpp
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018 #include "MapFunction.h"
00019 #include "MathConstant.h"
00020
00021 #include <math.h>
00022
00023 double DistanceToRecombination(double distance)
00024 {
00025 return (1.0 - exp(-2.0 * distance)) * 0.5;
00026 }
00027
00028 double RecombinationToDistance(double recombination)
00029 {
00030 return (log(max(1.0 - 2 * recombination, 1e-7)) * -0.5);
00031 }
00032
00033 double KosambiDistanceToRecombination(double distance)
00034 {
00035 double e_to_4x = exp(4.0 * distance);
00036
00037 return (0.5 *(e_to_4x - 1.0) / (e_to_4x + 1.0));
00038 }
00039
00040 double RecombinationToKosambiDistance(double theta)
00041 {
00042 return 0.25 * log((1.0 + 2*theta) / max(1.0 - 2.0*theta, 1e-7));
00043 }