证据权模型(C#版)
证据权法是通过计算和利用各种不同证据的权重(表示相对重要性)并将多种证据结合起来,预测某个时间是否会发生的一种方法
证据权法以概率论中的贝叶斯定理为基础。设D表示要一个随机事件。用P(D)表示这一事件概率,即D发生的概率。假设P(D)事先知道,即它是先验概率。则D不发生的概率为:

定义:
称为事件D的几率(Odd Ratio),也称优势率,它能更好的表示事件D发生的可能性大小。
用集合 
表示与D有关的n个证据,并设Xj都是逻辑变量。用D|X表示"单元中存在X的情况下D发生"这一事件。用P(D|X)表示概率,也称为后验概率(后验概率是获得有关信息后对先验概率修正后的概率)。由贝叶斯定理:

可以得出优势率:

假设n个条件相互条件独立,并在两边同时去对数:

令:


于是:

事件D|X的几率为

于是后验概率为:

其中wi称为证据X的证据权,反应Xi的存在对D的重要性:

其中,各条件概率的计算:

定义:

为X的对比系数,可以用来综合评价各证据的重要性
在数据较少的情况下,采用C来选择证据,回增大结果的不确定性,定义

其中:
为第i个证据后验概率的正负方差:

- /// <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
- }
证据权模型(C#版)的更多相关文章
- Reactor模型-单线程版
Reactor模型是典型的事件驱动模型.在网络编程中,所谓的事件当然就是read.write.bind.connect.close等这些动作了.Reactor模型的实现有很多种,下面介绍最基本的三种: ...
- 网络IO模型-异步选择模型(Delphi版)
其实关于这个模型,网络上也有一个案例说明 老陈使用了微软公司的新式信箱.这种信箱非常先进,一旦信箱里有新的信件,盖茨就会给老陈打电话:喂,大爷,你有新的信件了!从此,老陈再也不必频繁上下楼检查信箱了, ...
- Linux提权(2)-高级版
当你在攻击受害者的电脑时即使你拥有了一个shell,依然可能会有一些拒绝执行指令的限制.为了获得目标主机的完整控制权限,你需要在未授权的地方绕过权限控制.这些权限可以删除文件,浏览私人信息,或者安装并 ...
- Linux提权(1)-基础版~
利用Linux内核漏洞提权 VulnOS version 2是VulHub上的一个Linux提权练习,当打开虚拟机后,可以看到 获取到低权限SHELL后我们通常做下面几件事 1.检测操作系统的发行版本 ...
- IO模型-java版
描述IO,我们需要从两个层面: 编程语言 实现原理 底层基础 从编程语言层面 BIO | NIO | AIO 以Java的角度,理解,linux c里也有AIO的概念(库),本文只从Java角度入手. ...
- java 高性能Server —— Reactor模型单线程版
NIO模型 NIO模型示例如下: Acceptor注册Selector,监听accept事件 当客户端连接后,触发accept事件 服务器构建对应的Channel,并在其上注册Selector,监听读 ...
- NLP学习(2)----文本分类模型
实战:https://github.com/jiangxinyang227/NLP-Project 一.简介: 1.传统的文本分类方法:[人工特征工程+浅层分类模型] (1)文本预处理: ①(中文) ...
- 模型(Model)– ASP.NET MVC 4 系列
为 MVC Music Store 建模 在 Models 目录中为专辑.艺术家.流派建模: public class Album { public virtual int ...
- 《ASP.NET MVC 5 高级编程(第5版)》
第1章.入门 本章主要内容: ASP.NET MVC 5概述 其应用程序的创建方法 其应用程序的及结构 概述:将MVC设计模式应用于ASP.NET框架 ASP.NET 1.0支持两层抽象: Syste ...
随机推荐
- orcale复制表结构及其数据
http://hi.baidu.com/tag/Oracle/feeds http://hi.baidu.com/gqftuisidibabiq/item/14d306cc87cbdf45bcef69 ...
- Building Modern Web Apps-构建现代的 Web 应用程序
Building Modern Web Apps-构建现代的 Web 应用程序 视频长度:1 小时左右 视频作者:Scott Hunter 和 Scott Hanselman 视频背景:Visual ...
- Android项目---webView
之前用webView的时候,只知道它可以加载出html页面,竟然不知道,它也可以与js进行交互. WebView是一个网络视图,能加载显示网页,可以将它看作一个浏览器.它使用WebKit渲染引擎加载显 ...
- Ibatis.Net执行Sql超时commandTimeout的一个坑
项目中使用了Ibatis.Net,数据库是Mysql,在做一个批量Update的操作时,需要执行40几秒,在执行到30秒的时候,会抛出异常:Timeout expired , The timeout ...
- w5cValidator【AngularJS】 2.0 版本发布
w5cValidator 插件基于angular原有的表单验证,在原有的基础上扩展了一些错误提示的功能,让大家不用在每个表单上写一些提示信息的模板,专心的去实现业务逻辑. 代码地址:https://g ...
- ASP.NET MVC5 视图预编译
ASP.NET MVC5 视图预编译 ASP.NET MVC5 视图预编译 关于Razor视图及引擎原理,就不多说了. 这里通俗或者不恰当地说,cshtml视图文件是先编译成dll文件,再通过视图 ...
- iOS基础 - 数据存取
一.iOS应用数据存储的常用方式 XML属性列表(plist)归档 Preference(偏好设置) NSKeyedArchiver归档 SQLite3 Core Data 二.应用沙盒 每个iOS应 ...
- ASP.NET MVC 使用MSBuild生成的几个注意事项
做新项目,当时参考NopCommerce的结构,后台Nop.Admin是一个独立的Area Web Site,但部署的时候发现,使用一键发布,Admin Area会丢失. 研究了下NopCommerc ...
- GNU Make 学习系列一:怎样写一个简单的Makefile
编程通常遵循一个相当简单的程序:编辑源文件,编译源代码成可执行的格式,调试结果.尽管将源代码翻译成可执行程序是常规的过程,如果做的不正确,程序员可能会浪费大量的时间去追踪问题.大多数的开发者都经历过这 ...
- Asp.Net MVC 3
Asp.Net MVC 3 wcf基础教程之 契约(合同)Contract 摘要: 在前几篇博客中我有说到服务的寄宿,就是服务要运行起来必须采取的几种方式,相当于我们可以照葫芦画瓜的效果运行一个w ...