C#,数值计算——KMeans分类的计算方法与源程序

news2025/1/13 17:25:43

1 文本格式

using System;

namespace Legalsoft.Truffer
{
    /// <summary>
    /// K-Means classification
    /// </summary>
    public class Kmeans
    {
        private int nn { get; set; }
        private int mm { get; set; }
        private int kk { get; set; }
        private int nchg { get; set; }
        private double[,] data { get; set; }
        private double[,] means { get; set; }
        private int[] assign { get; set; }
        private int[] count { get; set; }

        public Kmeans(double[,] ddata, double[,] mmeans)
        {
            this.nn = ddata.GetLength(0);
            this.mm = ddata.GetLength(1);
            this.kk = mmeans.GetLength(0);
            this.data = Globals.CopyFrom(ddata);
            this.means = Globals.CopyFrom(mmeans);
            this.assign = new int[nn];
            this.count = new int[kk];

            estep();
            mstep();
        }

        public int estep()
        {
            int kmin = 0;
            nchg = 0;
            for (int k = 0; k < kk; k++)
            {
                count[k] = 0;
            }
            for (int n = 0; n < nn; n++)
            {
                double dmin = 9.99e99;
                for (int k = 0; k < kk; k++)
                {
                    double d = 0.0;
                    for (int m = 0; m < mm; m++)
                    {
                        d += Globals.SQR(data[n, m] - means[k, m]);
                    }
                    if (d < dmin)
                    {
                        dmin = d;
                        kmin = k;
                    }
                }
                if (kmin != assign[n])
                {
                    nchg++;
                }
                assign[n] = kmin;
                count[kmin]++;
            }
            return nchg;
        }

        public void mstep()
        {
            for (int k = 0; k < kk; k++)
            {
                for (int m = 0; m < mm; m++)
                {
                    means[k, m] = 0.0;
                }
            }
            for (int n = 0; n < nn; n++)
            {
                for (int m = 0; m < mm; m++)
                {
                    means[assign[n], m] += data[n, m];
                }
            }
            for (int k = 0; k < kk; k++)
            {
                if (count[k] > 0)
                {
                    for (int m = 0; m < mm; m++)
                    {
                        means[k, m] /= count[k];
                    }
                }
            }
        }
    }
}
 

2 代码格式

using System;

namespace Legalsoft.Truffer
{
    /// <summary>
    /// K-Means classification
    /// </summary>
    public class Kmeans
    {
        private int nn { get; set; }
        private int mm { get; set; }
        private int kk { get; set; }
        private int nchg { get; set; }
        private double[,] data { get; set; }
        private double[,] means { get; set; }
        private int[] assign { get; set; }
        private int[] count { get; set; }

        public Kmeans(double[,] ddata, double[,] mmeans)
        {
            this.nn = ddata.GetLength(0);
            this.mm = ddata.GetLength(1);
            this.kk = mmeans.GetLength(0);
            this.data = Globals.CopyFrom(ddata);
            this.means = Globals.CopyFrom(mmeans);
            this.assign = new int[nn];
            this.count = new int[kk];

            estep();
            mstep();
        }

        public int estep()
        {
            int kmin = 0;
            nchg = 0;
            for (int k = 0; k < kk; k++)
            {
                count[k] = 0;
            }
            for (int n = 0; n < nn; n++)
            {
                double dmin = 9.99e99;
                for (int k = 0; k < kk; k++)
                {
                    double d = 0.0;
                    for (int m = 0; m < mm; m++)
                    {
                        d += Globals.SQR(data[n, m] - means[k, m]);
                    }
                    if (d < dmin)
                    {
                        dmin = d;
                        kmin = k;
                    }
                }
                if (kmin != assign[n])
                {
                    nchg++;
                }
                assign[n] = kmin;
                count[kmin]++;
            }
            return nchg;
        }

        public void mstep()
        {
            for (int k = 0; k < kk; k++)
            {
                for (int m = 0; m < mm; m++)
                {
                    means[k, m] = 0.0;
                }
            }
            for (int n = 0; n < nn; n++)
            {
                for (int m = 0; m < mm; m++)
                {
                    means[assign[n], m] += data[n, m];
                }
            }
            for (int k = 0; k < kk; k++)
            {
                if (count[k] > 0)
                {
                    for (int m = 0; m < mm; m++)
                    {
                        means[k, m] /= count[k];
                    }
                }
            }
        }
    }
}

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

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

相关文章

ACL配置

目录 1.使用基本ACL配置交换telnet访问的权限 2.使用高级ACL配置流分类实现限制互访某一台服务器 3.使用二层ACL配置流分类拒绝指定报文通过 4.通过流策略实现策略路由(重定向到不同的下一跳) 5.通过流策略实现不同网段间限制互访 6.通过流策略实现限速功能 7.通过流策略…

C# CodeFormer Colorization 人脸着色

效果 项目 代码 using Microsoft.ML.OnnxRuntime; using Microsoft.ML.OnnxRuntime.Tensors; using OpenCvSharp; using System; using System.Collections.Generic; using System.Drawing; using System.Drawing.Imaging; using System.Windows.Forms;namespace CodeFormer_D…

联合体(共用体)

1. 联合类型的定义 联合也是一种特殊的自定义类型。 这种类型定义的变量也包含一系列的成员&#xff0c;特征是这些成员公用同一块空间。 2.联合大小的计算 联合的大小 至少是最大成员的大小 。 当最大成员大小不是最大对齐数的整数倍的时候&#xff0c;就要对 齐到最大对齐数…

反射、代理模式、注解

目录 一.Java反射 1.1反射的第一步&#xff1a;获取Class类的对象 1.2使用反射获取构造器对象并使用 1.3使用反射获取成员变量对象并使用 1.4使用反射获取成员方法对象并使用 二.代理模式 2.1概述 2.2代理模式在Java中的应用 2.3静态代理 2.4动态代理 2.4.1JDK动态代…

第60节——使用redux-toolkit实战一个商品列表的增删查改

一、样例 二、需求 调用goods.js这个单例完成对goods数据的增删查改 class Goods {constructor() {const data localStorage.getItem("qf-goods-data");this.goods data ? JSON.parse(data) : [];}time 500;/*** 获取商品* returns*/getGoods() {return new Pr…

序列化和反序列化指令在PLC通信上的应用

在了解本篇博客之前,大家可以熟悉下序列化指令的相关介绍,详细内容如下: 博途PLC 1200/1500 PLC 序列化和反序列化指令编程应用_博图序列化和反序列化-CSDN博客序列化最重要的作用:在传递和保存对象时.保证对象的完整性和可传递性。对象转换为有序字节流,以便在网络上传输…

Apache Doris (四十四): Doris数据更新与删除 - Delete 数据删除

🏡 个人主页:IT贫道_大数据OLAP体系技术栈,Apache Doris,Clickhouse 技术-CSDN博客 🚩 私聊博主:加入大数据技术讨论群聊,获取更多大数据资料。 🔔 博主个人B栈地址:豹哥教你大数据的个人空间-豹哥教你大数据个人主页-哔哩哔哩视频 目录

在 Python 脚本中设置环境变量

环境变量是与系统进程交互的一种深入方式&#xff1b; 它允许用户获得有关系统属性、路径和已经存在的变量的更详细信息。 我们如何使用环境变量 如上所述&#xff0c;环境变量促使我们与系统进程进行交互。 我们可以使用环境变量来访问系统中的所有变量和键。 为此&#xff…

Spring中构造注入详解

目录 一、构造注入是什么 二、构造注入重载 一、构造注入是什么 书接上回&#xff0c;我们已经知道了setter注入是什么了&#xff0c;这里的构造注入也就很好理解了。构造注入也就是Spring通过调用类对象中的构造方法来进行注入。接下来利用代码演示构造注入 1&#xff09;先…

Elasticsearch系列组件:Beats高效的日志收集和传输解决方案

Elasticsearch 是一个开源的、基于 Lucene 的分布式搜索和分析引擎&#xff0c;设计用于云计算环境中&#xff0c;能够实现实时的、可扩展的搜索、分析和探索全文和结构化数据。它具有高度的可扩展性&#xff0c;可以在短时间内搜索和分析大量数据。 Elasticsearch 不仅仅是一个…

上海亚商投顾:沪指震荡调整 转基因概念股逆势大涨

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 沪指昨日低开低走&#xff0c;深成指、创业板指均跌超1%&#xff0c;双双创出年内新低。转基因概念股逆势大涨…

C语言初学者工具选择:vscode + MSYS2 + cmake 搭建 C环境

文章目录 前言1. MSYS2 安装1. 下载安装包2. 安装3. pacman 换清华大学源4. 安装 mingw-w64 toolchain 和 cmake ninja5. 将 toolchain 加入系统环境变量 2. 设置 vscode1. 必要的插件2. 一个简单的 vscode cmake 项目 最后C数据结构与算法CMake 前言 网上关于使用 vscode 配…

Leetcode刷题详解——无重复字符的最长子串

1. 题目链接&#xff1a;3. 无重复字符的最长子串 2. 题目描述&#xff1a; 给定一个字符串 s &#xff0c;请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 输入: s "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc"&#xff0c;所…

C++11(包装器)

目录 一、function包装器 1、概念 2、function的引入 3、function 1、对函数指针包装 2、对函数对象进行包装 3、对lambda表达式进行包装 4、对类的成员函数进行包装 二、bind包装器 1、概念 2、bind 1、绑定全局函数 2、绑定成员函数 3、参数调换顺序 一、functi…

pinia下载使用时报错如何解决?

报错 可能是因为pnpm下载的时候版本出现了问题 更新pnpm的版本 一、windowr打开终端 输入pnpm -v检查是否是最新版本 如果是8.6.2的话 就更新 更新步骤如下&#xff1a; 二&#xff1a;打开pnpm下载的网盘位置 我的是在c盘 找到里面的用户文件夹 点击选择dell里面的App data文…

C语言 内存

内存分配 内存分配的类型 C/C中内存分为5个区&#xff0c;分别为栈区、堆区、全局/静态存储区、常量存储区、代码区 静态内存分配&#xff1a;编译时分配&#xff0c;包括全局、静态全局、静态局部三种变量。 动态内存分配&#xff1a;运行时分配&#xff0c;包括栈&#x…

21天学会C++:Day15----STL简介

CSDN的uu们&#xff0c;大家好。这里是C入门的第十五讲。 座右铭&#xff1a;前路坎坷&#xff0c;披荆斩棘&#xff0c;扶摇直上。 博客主页&#xff1a; 姬如祎 收录专栏&#xff1a;C专题 目录 1. 什么是STL 2. STL的版本 3.STL的六大组件 4. STL的重要性 5. 如何学…

二叉树实现表达式求值(C++)

用二叉树来表示表达式&#xff0c;树的每一个节点包括一个运算符和运算数。代数表达式中只包含&#xff0c;-&#xff0c;*&#xff0c;/&#xff0c;&#xff08;&#xff0c;&#xff09;和一位整数且没有错误。按照先括号&#xff0c;再乘除&#xff0c;后加减的规则构造二叉…

【算法设计zxd】第6章 回溯法

目录 6.1 回溯法的设计技术 &#xff1a; 四皇后问题 回溯法&#xff1a; 算法框架&#xff1a; 思考题&#xff1a; 回溯算法的适用条件 【例6-1】求满足下列不等式的所有整数解&#xff1a; 6.2回溯算法的经典例题 【例6-2】装载问题  问题分析 计算模型  算法设计与描…

selenium多窗口、多iframe切换、alert、3种等待

1、多标签/多窗口之间的切换 场景&#xff1a; 在页面操作过程中有时候点击某个链接会弹出新的窗口&#xff0c;这时就需要切换到新打开的窗口上进行操作。这种情况下&#xff0c;需要识别多标签或窗口的情况。 操作方法&#xff1a; switch_to.window()方法&#xff1a;切换…