C#,数值计算——泊松偏差(Poisson Deviance,Poissondev)的计算方法与源程序

本文主要是介绍C#,数值计算——泊松偏差(Poisson Deviance,Poissondev)的计算方法与源程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 文本格式

using System;

namespace Legalsoft.Truffer
{
    public class Poissondev : Ran
    {
        private double lambda { get; set; }
        private double sqlam { get; set; }
        private double loglam { get; set; }
        private double lamexp { get; set; }
        private double lambold { get; set; }
        private double[] logfact { get; set; }

        public Poissondev(double llambda, ulong ix) : base(ix)
        {
            this.lambda = llambda;
            this.logfact = new double[1024];
            for (int i = 0; i < 1024; i++)
            {
                logfact[i] = -1.0;
            }
            this.lambold = -1.0;
        }

        public int dev()
        {
            double v2 = 0.0;
            int k;
            if (lambda < 5.0)
            {
                if (lambda != lambold)
                {
                    lamexp = Math.Exp(-lambda);
                }
                k = -1;
                double t = 1.0;
                do
                {
                    ++k;
                    t *= doub();
                } while (t > lamexp);
            }
            else
            {
                if (lambda != lambold)
                {
                    sqlam = Math.Sqrt(lambda);
                    loglam = Math.Log(lambda);
                }
                for (; ; )
                {
                    double u = 0.64 * doub();
                    double v = -0.68 + 1.28 * doub();
                    if (lambda > 13.5)
                    {
                        v2 = Globals.SQR(v);
                        if (v >= 0.0)
                        {
                            if (v2 > 6.5 * u * (0.64 - u) * (u + 0.2))
                            {
                                continue;
                            }
                        }
                        else
                        {
                            if (v2 > 9.6 * u * (0.66 - u) * (u + 0.07))
                            {
                                continue;
                            }
                        }
                    }
                    k = (int)Math.Floor(sqlam * (v / u) + lambda + 0.5);
                    if (k < 0)
                    {
                        continue;
                    }
                    double u2 = Globals.SQR(u);
                    if (lambda > 13.5)
                    {
                        if (v >= 0.0)
                        {
                            if (v2 < 15.2 * u2 * (0.61 - u) * (0.8 - u))
                            {
                                break;
                            }
                        }
                        else
                        {
                            if (v2 < 6.76 * u2 * (0.62 - u) * (1.4 - u))
                            {
                                break;
                            }
                        }
                    }
                    double lfac;
                    if (k < 1024)
                    {
                        if (logfact[k] < 0.0)
                        {
                            logfact[k] = Globals.gammln(k + 1.0);
                        }
                        lfac = logfact[k];
                    }
                    else
                    {
                        lfac = Globals.gammln(k + 1.0);
                    }
                    double p = sqlam * Math.Exp(-lambda + k * loglam - lfac);
                    if (u2 < p)
                    {
                        break;
                    }
                }
            }
            lambold = lambda;
            return k;
        }

        public int dev(double llambda)
        {
            lambda = llambda;
            return dev();
        }
    }
}
 

2 代码格式

using System;namespace Legalsoft.Truffer
{public class Poissondev : Ran{private double lambda { get; set; }private double sqlam { get; set; }private double loglam { get; set; }private double lamexp { get; set; }private double lambold { get; set; }private double[] logfact { get; set; }public Poissondev(double llambda, ulong ix) : base(ix){this.lambda = llambda;this.logfact = new double[1024];for (int i = 0; i < 1024; i++){logfact[i] = -1.0;}this.lambold = -1.0;}public int dev(){double v2 = 0.0;int k;if (lambda < 5.0){if (lambda != lambold){lamexp = Math.Exp(-lambda);}k = -1;double t = 1.0;do{++k;t *= doub();} while (t > lamexp);}else{if (lambda != lambold){sqlam = Math.Sqrt(lambda);loglam = Math.Log(lambda);}for (; ; ){double u = 0.64 * doub();double v = -0.68 + 1.28 * doub();if (lambda > 13.5){v2 = Globals.SQR(v);if (v >= 0.0){if (v2 > 6.5 * u * (0.64 - u) * (u + 0.2)){continue;}}else{if (v2 > 9.6 * u * (0.66 - u) * (u + 0.07)){continue;}}}k = (int)Math.Floor(sqlam * (v / u) + lambda + 0.5);if (k < 0){continue;}double u2 = Globals.SQR(u);if (lambda > 13.5){if (v >= 0.0){if (v2 < 15.2 * u2 * (0.61 - u) * (0.8 - u)){break;}}else{if (v2 < 6.76 * u2 * (0.62 - u) * (1.4 - u)){break;}}}double lfac;if (k < 1024){if (logfact[k] < 0.0){logfact[k] = Globals.gammln(k + 1.0);}lfac = logfact[k];}else{lfac = Globals.gammln(k + 1.0);}double p = sqlam * Math.Exp(-lambda + k * loglam - lfac);if (u2 < p){break;}}}lambold = lambda;return k;}public int dev(double llambda){lambda = llambda;return dev();}}
}

这篇关于C#,数值计算——泊松偏差(Poisson Deviance,Poissondev)的计算方法与源程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/beijinghorn/article/details/133231624
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/235658

相关文章

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR

C#继承之里氏替换原则分析

《C#继承之里氏替换原则分析》:本文主要介绍C#继承之里氏替换原则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#里氏替换原则一.概念二.语法表现三.类型检查与转换总结C#里氏替换原则一.概念里氏替换原则是面向对象设计的基本原则之一:核心思想:所有引py

C#实现访问远程硬盘的图文教程

《C#实现访问远程硬盘的图文教程》在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件,这次我们将给出一个完整的... 目录引言一. 远程硬盘功能展示二. 远程硬盘代码实现1. 底层业务通信实现2. UI 实现三. De

C#通过进程调用外部应用的实现示例

《C#通过进程调用外部应用的实现示例》本文主要介绍了C#通过进程调用外部应用的实现示例,以WINFORM应用程序为例,在C#应用程序中调用PYTHON程序,具有一定的参考价值,感兴趣的可以了解一下... 目录窗口程序类进程信息类 系统设置类 以WINFORM应用程序为例,在C#应用程序中调用python程序

Java计算经纬度距离的示例代码

《Java计算经纬度距离的示例代码》在Java中计算两个经纬度之间的距离,可以使用多种方法(代码示例均返回米为单位),文中整理了常用的5种方法,感兴趣的小伙伴可以了解一下... 目录1. Haversine公式(中等精度,推荐通用场景)2. 球面余弦定理(简单但精度较低)3. Vincenty公式(高精度,

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr

C#特性(Attributes)和反射(Reflection)详解

《C#特性(Attributes)和反射(Reflection)详解》:本文主要介绍C#特性(Attributes)和反射(Reflection),具有很好的参考价值,希望对大家有所帮助,如有错误... 目录特性特性的定义概念目的反射定义概念目的反射的主要功能包括使用反射的基本步骤特性和反射的关系总结特性

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删

通过C#获取Excel单元格的数据类型的方法详解

《通过C#获取Excel单元格的数据类型的方法详解》在处理Excel文件时,了解单元格的数据类型有助于我们正确地解析和处理数据,本文将详细介绍如何使用FreeSpire.XLS来获取Excel单元格的... 目录引言环境配置6种常见数据类型C# 读取单元格数据类型引言在处理 Excel 文件时,了解单元格

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel