C#,数值计算——函数计算,Eulsum的计算方法与源程序

1 文本格式
using System;
namespace Legalsoft.Truffer
{
public class Eulsum
{
private double[] wksp { get; set; }
private int n { get; set; }
private int ncv { get; set; }
public bool cnvgd { get; set; }
private double sum { get; set; }
private double eps { get; set; }
private double lastval { get; set; }
private double lasteps { get; set; }
public Eulsum(int nmax, double epss)
{
this.wksp = new double[nmax];
this.n = 0;
this.ncv = 0;
this.cnvgd = false;
this.sum = 0.0;
this.eps = epss;
this.lastval = 0.0;
}
public double next(double term)
{
if (n + 1 > wksp.Length)
{
throw new Exception("wksp too small in eulsum");
}
if (n == 0)
{
sum = 0.5 * (wksp[n++] = term);
}
else
{
double tmp = wksp[0];
wksp[0] = term;
for (int j = 1; j < n; j++)
{
double dum = wksp[j];
wksp[j] = 0.5 * (wksp[j - 1] + tmp);
tmp = dum;
}
wksp[n] = 0.5 * (wksp[n - 1] + tmp);
if (Math.Abs(wksp[n]) <= Math.Abs(wksp[n - 1]))
{
sum += (0.5 * wksp[n++]);
}
else
{
sum += wksp[n];
}
}
lasteps = Math.Abs(sum - lastval);
if (lasteps <= eps)
{
ncv++;
}
if (ncv >= 2)
{
cnvgd = true;
}
return (lastval = sum);
}
}
}
2 代码格式
using System;namespace Legalsoft.Truffer
{public class Eulsum{private double[] wksp { get; set; }private int n { get; set; }private int ncv { get; set; }public bool cnvgd { get; set; }private double sum { get; set; }private double eps { get; set; }private double lastval { get; set; }private double lasteps { get; set; }public Eulsum(int nmax, double epss){this.wksp = new double[nmax];this.n = 0;this.ncv = 0;this.cnvgd = false;this.sum = 0.0;this.eps = epss;this.lastval = 0.0;}public double next(double term){if (n + 1 > wksp.Length){throw new Exception("wksp too small in eulsum");}if (n == 0){sum = 0.5 * (wksp[n++] = term);}else{double tmp = wksp[0];wksp[0] = term;for (int j = 1; j < n; j++){double dum = wksp[j];wksp[j] = 0.5 * (wksp[j - 1] + tmp);tmp = dum;}wksp[n] = 0.5 * (wksp[n - 1] + tmp);if (Math.Abs(wksp[n]) <= Math.Abs(wksp[n - 1])){sum += (0.5 * wksp[n++]);}else{sum += wksp[n];}}lasteps = Math.Abs(sum - lastval);if (lasteps <= eps){ncv++;}if (ncv >= 2){cnvgd = true;}return (lastval = sum);}}
}
相关文章:
C#,数值计算——函数计算,Eulsum的计算方法与源程序
1 文本格式 using System; namespace Legalsoft.Truffer { public class Eulsum { private double[] wksp { get; set; } private int n { get; set; } private int ncv { get; set; } public bool cnvgd { get; set; } pri…...
ChatGLM3 langchain_demo 代码解析
ChatGLM3 langchain_demo 代码解析 0. 背景1. 项目代码结构2. 代码解析2-1. utils.py2-2. ChatGLM3.py2-3. Tool/Calculator.py2-4. Tool/Weather.py2-5. main.py 0. 背景 学习 ChatGLM3 的项目内容,过程中使用 AI 代码工具,对代码进行解释,…...
asp.net学院网上报销系统VS开发sqlserver数据库web结构c#编程Microsoft Visual Studio
一、源码特点 asp.net学院网上报销系统是一套完善的web设计管理系统,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为vs2010,数据库为sqlserver2008,使用c#语言 开发 asp.net学院网上报销系统 应用技术…...
ElasticSearch知识点
什么是ElasticSearch ElasticSearch: 智能搜索,分布式的搜索引擎,是ELK的一个非常完善的产品,ELK代表的是: E就是ElasticSearch,L就是Logstach,K就是kibana Elasticsearch是一个建立在全文搜索引擎 Apache Lucene基础…...
STM32 GPIO
STM32 GPIO GPIO简介 GPIO(General Purpose Input Output)通用输入输出口,也就是我们俗称的IO口 根据使用场景,可配置为8种输入输出模式 引脚电平:0V~3.3V,部分引脚可容忍5V 数据0就是低电平,…...
Electron 开发页面应用
简介 Electron集成了包括chromium(理解为具备chrom浏览器的工具),nodejs,native apis chromium:支持最新特性的浏览器。 nodejs:js运行时,可实现文件读写等。 native apis :提供…...
CSDN写博文的128天
起因 为什么要写博文? 写博文是因为当我还是编程小白时,我那会啥也不懂,不懂函数调用,不懂指针,更不懂结构体,别更说Linux,平时不会也没有可以问的人,也幸好有CSDN,遇到…...
Linux学习教程(第二章 Linux系统安装)1
第二章 Linux系统安装 学习 Linux,首先要学会搭建 Linux 系统环境,也就是学会在你的电脑上安装 Linux 系统。 很多初学者对 Linux 望而生畏,多数是因为对 Linux 系统安装的恐惧,害怕破坏电脑本身的系统,害怕硬盘数据…...
vue2手机项目如何使用蓝牙功能
要在Vue2手机项目中使用蓝牙功能,你需要先了解基本的蓝牙知识和API。以下是一些基本的步骤: 确认你的手机设备支持蓝牙功能。在Vue2项目中安装蓝牙插件或库,例如vue-bluetooth或vue-bluetooth-manager。你可以通过npm安装它们。在Vue2项目中…...
魔兽服务器学习-笔记1
文章目录 一、环境准备1)依赖安装2)源码下载和编译 二、生成数据信息1)地图数据信息(客户端信息)2)数据库信息 三、启动服务器四、日志模块五、数据库模块六、场景模块1)地图管理2)A…...
代码随想录day60|84.柱状图中最大的矩形
84.柱状图中最大的矩形(找到右边第一个更小的元素) 1、对于每一个柱子:找到左边第一个比他矮的,再找到右边第一个比他矮的。 2、首尾加0: 为什么要在末尾加0:否则如果原数组就是单调递增的话,就…...
常见面试题-分布式锁
Redisson 分布式锁?在项目中哪里使用?多久会进行释放?如何加强一个分布式锁? 答: 什么时候需要使用分布式锁呢? 在分布式的场景下,使用 Java 的单机锁并不可以保证多个应用的同时操作共享资源…...
vue开发 安装一些工具
下载 node.js环境 nodeJs 官网 命令行输入 node -v 和 npm -v 出现版本号 代表nodejs 安装成功选择安装pnpm npm install -g pnpmpnpm -v 出现版本号即成功安装安装 scss vue3 组件库 Element Plus Element 官网 安装 pnpm install Element-Plus --save第一次使用开发v…...
Vue.js 组件 - 自定义事件
Vue.js 组件 - 自定义事件 父组件是使用 props 传递数据给子组件,但如果子组件要把数据传递回去,就需要使用自定义事件! 我们可以使用 v-on 绑定自定义事件, 每个 Vue 实例都实现了事件接口(Events interface),即: …...
深度学习 python opencv 火焰检测识别 计算机竞赛
文章目录 0 前言1 基于YOLO的火焰检测与识别2 课题背景3 卷积神经网络3.1 卷积层3.2 池化层3.3 激活函数:3.4 全连接层3.5 使用tensorflow中keras模块实现卷积神经网络 4 YOLOV54.1 网络架构图4.2 输入端4.3 基准网络4.4 Neck网络4.5 Head输出层 5 数据集准备5.1 数…...
PHP中传值与引用的区别
在PHP中,变量的传递方式主要分为传值和传引用两种。这两种方式在操作中有一些重要的区别,影响着变量在函数调用或赋值操作中的表现。下面详细解释一下这两种传递方式的区别。 传值(By Value) 传值是指将变量的值复制一份传递给函…...
Go常见数据结构的实现原理——map
(一)基础操作 版本:Go SDK 1.20.6 1、初始化 map分别支持字面量初始化和内置函数make()初始化。 字面量初始化: m : map[string] int {"apple": 2,"banana": 3,}使用内置函数make()初始化: m …...
第二十五节——Vuex--历史遗留
文档地址 Vuex 是什么? | Vuex version V4.x 一、概念 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。一个状态自管理应用包含以下几个部…...
大数据Doris(二十一):数据导入演示
文章目录 数据导入演示 一、启动zookeeper集群(三台节点都启动) 二、启动hdfs集群...
[100天算法】-面试题 04.01.节点间通路(day 72)
题目描述 节点间通路。给定有向图,设计一个算法,找出两个节点之间是否存在一条路径。示例1:输入:n 3, graph [[0, 1], [0, 2], [1, 2], [1, 2]], start 0, target 2 输出:true 示例2:输入:n 5, graph [[0, 1], …...
建立班级相册?超简单,保姆级教你在PPT里建立班级“小红书”,3步打造有温度的班级小世界!
边听边看收获更多! 班级相册超简单,保姆级教你在PPT里建立班级“小红书”社区!你有搞班级相册吗? 是不是早已 “名存实亡”? 每次班级活动拍了几十张照片,最后都散落在微信群、QQ 群的聊天记录里 —— 想找…...
7个实用技巧!Vue组件测试指南:基于TypeScript-Vue-Starter的Jest单元测试实战
7个实用技巧!Vue组件测试指南:基于TypeScript-Vue-Starter的Jest单元测试实战 【免费下载链接】TypeScript-Vue-Starter A starter template for TypeScript and Vue with a detailed README describing how to use the two together. 项目地址: https…...
写算法咖啡拉花模板,一键成型,输出:咖啡师/家用都可用。
利用激光切割的高精度,制作出不锈钢或食品级亚克力的镂空模板(Stencil),让即便是新手,也能一键复刻大师级的拿铁艺术。以下是完整的项目交付文档:项目名称:LatteArt-Stencil-Gen (咖啡拉花模板生…...
StructBERT轻量级模型部署教程:7860端口WebUI与8080 API服务配置
StructBERT轻量级模型部署教程:7860端口WebUI与8080 API服务配置 1. 项目概述 今天给大家分享一个实用工具——StructBERT中文情感分析服务的部署教程。这个基于阿里云开源模型的服务,能够快速识别中文文本的情感倾向,无论是个人项目还是企…...
YOLOE开放检测实战案例:YOLOE-v8l-seg在文化遗产数字化保护中的应用
YOLOE开放检测实战案例:YOLOE-v8l-seg在文化遗产数字化保护中的应用 1. 引言:当古老文物遇见现代AI 想象一下,你是一位文化遗产保护工作者,面对一座布满精美壁画和复杂雕刻的古建筑。你的任务是快速、准确地记录下每一处细节——…...
使用Typora与OFA-Image-Caption打造智能Markdown笔记系统
使用Typora与OFA-Image-Caption打造智能Markdown笔记系统 不知道你有没有这样的经历:在Typora里写技术笔记,插入一张截图或者流程图,当时觉得一目了然。可过了一两个月再回头看,对着那张图愣了半天,死活想不起来当时为…...
技术管理中的目标设定与绩效评估
技术管理中的目标设定与绩效评估:驱动团队高效创新的核心 在快速发展的技术领域,目标设定与绩效评估是管理团队、推动创新的关键工具。明确的目标能够为技术团队提供方向,而科学的绩效评估则能确保资源高效利用,激发成员潜力。无…...
Qwen2-VL-2B-Instruct跨平台调用方案:从移动端App到桌面应用的集成实践
Qwen2-VL-2B-Instruct跨平台调用方案:从移动端App到桌面应用的集成实践 1. 引言:当AI能力需要无处不在 最近在做一个项目,需要把视觉语言模型的能力塞进各种客户端里——手机App、桌面软件都得用上。一开始觉得挺简单,不就是调个…...
PhotoshopCClinux部署实战:企业环境批量安装的10个最佳实践技巧
PhotoshopCClinux部署实战:企业环境批量安装的10个最佳实践技巧 【免费下载链接】photoshopCClinux Photoshop CC v19 installer for Gnu/Linux 项目地址: https://gitcode.com/gh_mirrors/ph/photoshopCClinux 在企业环境中高效部署Photoshop CC v19到多台L…...
市场管理化技术市场细分与目标客户选择
市场管理化技术市场细分与目标客户选择 在竞争激烈的商业环境中,企业如何精准定位客户群体并高效满足其需求,成为决定成败的关键。市场管理化技术通过科学的市场细分与目标客户选择,帮助企业挖掘潜在机会,优化资源配置࿰…...
