-
/// <summary>
-
/// 计算先验似然概率
-
/// </summary>
-
private void GetMinePriorLikelihoodProb()
-
{
-
mineral_PriorProbability = sum_EvidenceCount[0] / (double)gridNumber;
-
minreal_PriorLiklihoodProbablity = mineral_PriorProbability / (1 - mineral_PriorProbability);
-
}
-
/// <summary>
-
/// 计算证据权参数
-
/// </summary>
-
private void GetEvidenceStatistc()
-
{
-
for (int i = 0; i < mineral_EvidenceCount - 1; i++)
-
{
-
//证据权正定义
-
/* Count(BjD)/Count(D)
-
* ln----------------------
-
* Count(Bj~D)/Count(~D)
-
*/
-
evidence_PosWeight[i] = Math.Log((sumEvidence_MineralOccur[i] / sum_EvidenceCount[0]) /
-
((sum_EvidenceCount[i + 1] - sumEvidence_MineralOccur[i]) / (gridNumber - sum_EvidenceCount[0])));
-
-
//证据权负定义
-
/* Count(~BjD)/Count(D)
-
* ln-------------------------
-
* Count(~Bj~D)/Count(~D)
-
*/
-
evidence_NegWeight[i] = Math.Log(((sum_EvidenceCount[0] - sumEvidence_MineralOccur[i]) / (sum_EvidenceCount[0]))
-
/ ((gridNumber - sum_EvidenceCount[0] - sum_EvidenceCount[i + 1] + sumEvidence_MineralOccur[i]) / (gridNumber - sum_EvidenceCount[0])));
-
-
//证据权正方差
-
/* 1 1
-
* -----------+--------------
-
* Count(BjD) Count(Bj~D)
-
*/
-
evidence_PosVariance[i] = (1 / sumEvidence_MineralOccur[i]) +
-
(1 / (sum_EvidenceCount[i + 1] - sumEvidence_MineralOccur[i]));
-
-
//证据权负方差
-
/* 1 1
-
* -----------+--------------
-
* Count(~BjD) Count(~Bj~D)
-
*/
-
evidence_NegVariance[i] = (1 / (sum_EvidenceCount[0] - sumEvidence_MineralOccur[i])) +
-
(1 / (gridNumber - sum_EvidenceCount[0] - sum_EvidenceCount[i + 1] + sumEvidence_MineralOccur[i]));
-
-
//对比度
-
//Cj=weightj+ - Weightj-
-
evidence_ContrastRatio[i] = evidence_PosWeight[i] - evidence_NegWeight[i];
-
-
//显著性统计量
-
//Stud(C)=Cj/s(c)
-
//s(c)=1/Sqrt(s2(weight+)+s2(weight-))
-
evidence_StatisticalSignficance[i] = evidence_ContrastRatio[i] /
-
(Math.Sqrt(evidence_PosVariance[i] + evidence_NegVariance[i]));
-
}
-
}
-
/// <summary>
-
/// 证据权合成
-
/// </summary>
-
private void SynthesisEvidence()
-
{
-
double[] evidence_PostProbLog = new double[gridNumber];
-
-
double[,] evidence_Data = (double[,])mineralAndEvidence.Clone();
-
for (int i = 1; i < mineral_EvidenceCount; i++)
-
{
-
for (int j = 0; j < mineralAndEvidence.GetLength(1); j++)
-
{
-
//将复制证据图层中与对调
-
if (evidence_Data[i, j] == 0)
-
{
-
evidence_Data[i, j] = 1;
-
}
-
else
-
{
-
evidence_Data[i, j] = 0;
-
}
-
evidence_PostProbLog[j] += evidence_Data[i, j] * evidence_NegWeight[i - 1] +
-
mineralAndEvidence[i, j] * evidence_PosWeight[i - 1];
-
}//for
-
}//for
-
GetPostProb(evidence_PostProbLog);
-
}//Method End
-
/// <summary>
-
/// 计算后验概率
-
/// </summary>
-
/// <param name="postProbLog"></param>
-
private void GetPostProb(double[] postProbLog)
-
{
-
evidence_PostProb = new double[gridNumber];
-
for (int i = 0; i < postProbLog.Length; i++)
-
{
-
evidence_PostProb[i] = (Math.Exp(postProbLog[i] + Math.Log(minreal_PriorLiklihoodProbablity)))
-
/ (1 + Math.Exp(postProbLog[i] + Math.Log(minreal_PriorLiklihoodProbablity)));
-
}//for
-
}