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)的计算方法与源程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/235658

相关文章

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

C#实现文件读写到SQLite数据库

《C#实现文件读写到SQLite数据库》这篇文章主要为大家详细介绍了使用C#将文件读写到SQLite数据库的几种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录1. 使用 BLOB 存储文件2. 存储文件路径3. 分块存储文件《文件读写到SQLite数据库China编程的方法》博客中,介绍了文

使用C#如何创建人名或其他物体随机分组

《使用C#如何创建人名或其他物体随机分组》文章描述了一个随机分配人员到多个团队的代码示例,包括将人员列表随机化并根据组数分配到不同组,最后按组号排序显示结果... 目录C#创建人名或其他物体随机分组此示例使用以下代码将人员分配到组代码首先将lstPeople ListBox总结C#创建人名或其他物体随机分组

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

C#中字符串分割的多种方式

《C#中字符串分割的多种方式》在C#编程语言中,字符串处理是日常开发中不可或缺的一部分,字符串分割是处理文本数据时常用的操作,它允许我们将一个长字符串分解成多个子字符串,本文给大家介绍了C#中字符串分... 目录1. 使用 string.Split2. 使用正则表达式 (Regex.Split)3. 使用

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

C# Task Cancellation使用总结

《C#TaskCancellation使用总结》本文主要介绍了在使用CancellationTokenSource取消任务时的行为,以及如何使用Task的ContinueWith方法来处理任务的延... 目录C# Task Cancellation总结1、调用cancellationTokenSource.

C# dynamic类型使用详解

《C#dynamic类型使用详解》C#中的dynamic类型允许在运行时确定对象的类型和成员,跳过编译时类型检查,适用于处理未知类型的对象或与动态语言互操作,dynamic支持动态成员解析、添加和删... 目录简介dynamic 的定义dynamic 的使用动态类型赋值访问成员动态方法调用dynamic 的

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa

通过C#和RTSPClient实现简易音视频解码功能

《通过C#和RTSPClient实现简易音视频解码功能》在多媒体应用中,实时传输协议(RTSP)用于流媒体服务,特别是音视频监控系统,通过C#和RTSPClient库,可以轻松实现简易的音视... 目录前言正文关键特性解决方案实现步骤示例代码总结最后前言在多媒体应用中,实时传输协议(RTSP)用于流媒体服