C#,数值计算——数据建模Plog的计算方法与源程序

news2025/1/13 13:55:14

1 文本格式

using System;

namespace Legalsoft.Truffer
{
    public class Plog
    {
        private int ndat { get; set; }
        private double[] dat { get; set; }
        private double[] stau { get; set; }
        private double[] slogtau { get; set; }

        public Plog(double[] data)
        {
            this.dat = data;
            this.ndat = data.Length;
            this.stau = new double[ndat];
            this.slogtau = new double[ndat];
            stau[0] = slogtau[0] = 0.0;
            for (int i = 1; i < ndat; i++)
            {
                stau[i] = dat[i] - dat[0];
                slogtau[i] = slogtau[i - 1] + Math.Log(dat[i] - dat[i - 1]);
            }
        }

        public double get(State s)
        {
            int ilo = 0;
            int ihi = ndat - 1;
            while (ihi - ilo > 1)
            {
                int i = (ihi + ilo) >> 1;
                if (s.tc > dat[i])
                {
                    ilo = i;
                }
                else
                {
                    ihi = i;
                }
            }
            int n1 = ihi;
            int n2 = ndat - 1 - ihi;
            double st1 = stau[ihi];
            double st2 = stau[ndat - 1] - st1;
            double stl1 = slogtau[ihi];
            double stl2 = slogtau[ndat - 1] - stl1;
            double ans = n1 * (s.k1 * Math.Log(s.lam1) - Globals.factln(s.k1 - 1)) + (s.k1 - 1) * stl1 - s.lam1 * st1;
            ans += n2 * (s.k2 * Math.Log(s.lam2) - Globals.factln(s.k2 - 1)) + (s.k2 - 1) * stl2 - s.lam2 * st2;
            return (s.plog = ans);
        }
    }
}
 

2 代码格式

using System;

namespace Legalsoft.Truffer
{
    public class Plog
    {
        private int ndat { get; set; }
        private double[] dat { get; set; }
        private double[] stau { get; set; }
        private double[] slogtau { get; set; }

        public Plog(double[] data)
        {
            this.dat = data;
            this.ndat = data.Length;
            this.stau = new double[ndat];
            this.slogtau = new double[ndat];
            stau[0] = slogtau[0] = 0.0;
            for (int i = 1; i < ndat; i++)
            {
                stau[i] = dat[i] - dat[0];
                slogtau[i] = slogtau[i - 1] + Math.Log(dat[i] - dat[i - 1]);
            }
        }

        public double get(State s)
        {
            int ilo = 0;
            int ihi = ndat - 1;
            while (ihi - ilo > 1)
            {
                int i = (ihi + ilo) >> 1;
                if (s.tc > dat[i])
                {
                    ilo = i;
                }
                else
                {
                    ihi = i;
                }
            }
            int n1 = ihi;
            int n2 = ndat - 1 - ihi;
            double st1 = stau[ihi];
            double st2 = stau[ndat - 1] - st1;
            double stl1 = slogtau[ihi];
            double stl2 = slogtau[ndat - 1] - stl1;
            double ans = n1 * (s.k1 * Math.Log(s.lam1) - Globals.factln(s.k1 - 1)) + (s.k1 - 1) * stl1 - s.lam1 * st1;
            ans += n2 * (s.k2 * Math.Log(s.lam2) - Globals.factln(s.k2 - 1)) + (s.k2 - 1) * stl2 - s.lam2 * st2;
            return (s.plog = ans);
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1092239.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Redis】使用Java客户端操作Redis

目录 引入jedis依赖连接Redis命令get/setexists/delkeysexpire/ttltype 引入jedis依赖 连接Redis 命令 get/set exists/del keys expire/ttl type

简单三步,让你的二维码焕发新生

在当今数字化时代&#xff0c;二维码已经成为了我们日常生活和工作中不可或缺的一部分。然而&#xff0c;你是否厌倦了那些单调、乏味的二维码&#xff1f;是否希望你的二维码能够更加美观、个性化&#xff1f;接下来&#xff0c;就让我们一起走进二维码的美化之旅。 首先&…

8.Covector Transformation Rules

上一节已知&#xff0c;任意的协向量都可以写成对偶基向量的线性组合&#xff0c;以及如何通过计算基向量穿过的协向量线来获得协向量分量&#xff0c;且看到 协向量分量 以 与向量分量 相反的方式进行变换。 现要在数学上确认协向量变换规则是什么。 第一件事&#xff1a;…

学习记忆——数学篇——案例——代数——不等式——一元二次不等式

重点记忆法 归类记忆法 解一元二次不等式的步骤 1.先化成标准型&#xff1a; a x 2 b x c > 0 ( 或 < 0 ) ax^2bxc>0(或<0) ax2bxc>0(或<0)&#xff0c;且a >0&#xff1b; 2.计算对应方程的判别式 △ △ △&#xff1b; 3.求对应方程的根&#xff1b…

Spring-学习

Spring&#xff1a; 图片出处&#xff1a;b站黑马 ssm学习截图 是一个大家族 &#xff0c;是一套完整的开发生态圈。可以利用这个spring全家桶快速构建企业级开发环境。 Spring Freamwork 是其他框架的基础 Springbot 使用了注解开发 SpringCloud 分布式 云服务 Sprin…

ShopXO download 任意文件读取

漏洞描述 ShopXO存在任意文件读取漏洞&#xff0c;攻击者可利用该漏洞获取敏感信息 漏洞复现 访问url&#xff1a; 构造payload 漏洞证明&#xff1a; 文笔生疏&#xff0c;措辞浅薄&#xff0c;望各位大佬不吝赐教&#xff0c;万分感谢。 免责声明&#xff1a;由于传播或…

想要精通算法和SQL的成长之路 - 连续的子数组和

想要精通算法和SQL的成长之路 - 连续的子数组和 前言一. 连续的子数组和1.1 最原始的前缀和1.2 前缀和 哈希表 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 连续的子数组和 原题链接 1.1 最原始的前缀和 如果这道题目&#xff0c;用前缀和来算&#xff0c;我们的思路…

基于Java的点歌管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作…

车载电子电器架构 —— 国产基础软件现在与未来

我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师&#xff1a; 屏蔽力是信息过载时代一个人的特殊竞争力&#xff0c;任何消耗你的人和事&#xff0c;多看一眼都是你的不…

【Vue 2】Props

Prop大小写 Prop的命名规则有camelCase&#xff0c;驼峰命名和kebab-case&#xff0c;短横线分隔。 由于HTML对大小写不敏感&#xff0c;所以浏览器会把大写字母解释为小写字母。 当我们使用camelCase命名prop时&#xff0c;在Dom中的template模板使用该prop就需要换成对应的…

【LeetCode】17. 电话号码的字母组合

1 问题 给定一个仅包含数字 2-9 的字符串&#xff0c;返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下&#xff08;与电话按键相同&#xff09;。注意 1 不对应任何字母。 示例 1&#xff1a; 输入&#xff1a;digits “23” 输出&…

微信小程序入门->小程序简介,小程序商城项目案例,小程序入门案例及目录结构

1.小程序简介 什么是小程序&#xff1f; 1. 2017年度百度百科十大热词之一 2. 微信小程序&#xff08;wei xin xiao cheng xu&#xff09;&#xff0c;简称小程序&#xff0c;英文名Mini Program&#xff0c;是一种不需要下载安装即可使用的应用( 张小龙对其的定义是无需安装&a…

Linux8yum安装mysql5.7版本流程

Linux8yum安装mysql Linux8yum安装报错解决 yum安装流程 首先下载mysql的yum配置 wget http://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm安装mysql源 yum -y install mysql57-community-release-el7-11.noarch.rpm安装mysql yum -y install mysql-s…

Leetcode算法解析——查找总价格为目标值的两个商品

1. 题目链接&#xff1a;LCR 179. 查找总价格为目标值的两个商品 2. 题目描述&#xff1a; 商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况&#xff0c;返回任一结果即可。 示例 1&#xff1a; 输入&#xff1a;price …

分布式链路追踪如何跨线程

背景 我们希望实现全链路信息&#xff0c;但是代码中一般都会异步的线程处理。 解决思路 我们可以对以前的 Runable 和 Callable 进行增强。 可以使用 ali 已经存在的实现方式。 TransmittableThreadLocal (TTL) 解决异步执行时上下文传递的问题 核心的实现思路如下&#…

C++程序加速方法

C程序加速方法 1. 将反复使用的数据存放在全局变量里面2. 使用多线程3. 用a和a&#xff0c;a–,--a4. 减少除法运算5. 尽量减少值传递&#xff0c;多用引用来传递参数。6. 循环引发的讨论1&#xff08;循环内定义&#xff0c;还是循环外定义对象&#xff09;7. 循环引发的讨论2…

Word论文封面下划线怎么都对不齐

我们常常发现&#xff0c;无论是写论文还是平时填写word封面的信息的时候&#xff0c;下划线老是随着字符的多少的边长变短&#xff0c;我们使用空格键也非常不好对齐&#xff0c;这就给我们造成了很大的烦恼&#xff0c;想想自己也是这样&#xff0c;我一旦输入字符&#xff0…

JVM:虚拟机类加载机制

JVM:虚拟机类加载机制 什么是JVM的类加载 众所周知&#xff0c;Java是面向对象编程的一门语言&#xff0c;每一个对象都是一个类的实例。所谓类加载&#xff0c;就是JVM虚拟机把描述类的数据从class文件加载到内存&#xff0c;并对数据进行校验&#xff0c;转换解析和初始化&a…

为什么现在很多企业都在做私域?

不知大家发现没有&#xff0c;最近两年&#xff0c;宣传私域流量的声量好像没那么大了&#xff0c;但是&#xff0c;踏踏实实去做私域流量的企业&#xff0c;却越来越多了&#xff0c;好像大家突然统一了口径&#xff0c;不再只是停留在说&#xff0c;而是开始亲身实践&#xf…

【自然语言处理】— 隐马尔可夫模型详解、例解

【自然语言处理】— 隐马尔可夫模型 【自然语言处理】— 隐马尔可夫模型引例隐马尔可夫模型概念隐马尔可夫模型的关键隐马尔可夫模型的数学表示隐含状态与观测结果状态转移矩阵观测概率矩阵初始状态概率向量 小结 【自然语言处理】— 隐马尔可夫模型 引例 假设有三种不同的骰…