当前位置: 首页 > article >正文

使用FCM进行编码解码Python实现代码

文章目录代码整体结构第 1 部分生成二维合成数据固定随机种子means中心位置covs形状sizes点数生成数据裁剪到[0,1]第 2 部分初始化隶属度矩阵为什么要按列归一化?这一步的意义第 3 部分更新聚类中心第 4 部分计算距离每个样本到每个中心的距离为什么要防止除零第 5 部分更新隶属度矩阵为什么先算距离关键部分怎么理解ratio总结第 6 部分FCM 主循环初始化开始迭代为什么看U - U_old第 7 部分解码 / 重构最终结果为什么这就是解码第 8 部分重构误差第 9 部分画图1 原始数据2 重构数据3 聚类中心第 10 部分主程序生成数据设置参数运行FCM重构算误差输出结果画图10 总结代码1 导包2 生成二维合成数据3 初始化隶属度矩阵4 更新聚类中心5 计算距离6 更新隶属度矩阵7 FCM主函数8 解码解粒化9 重构误差10 完整代码代码整体结构1. generate_data() # 生成二维合成数据 2. initialize_membership() # 初始化隶属度矩阵 3. update_centers() # 更新聚类中心 4. compute_distances() # 计算样本到中心的距离 5. update_membership() # 更新隶属度矩阵 6. fcm() # FCM主循环 7. reconstruct_data() # 解码/重构 8. reconstruction_error() # 计算重构误差 9. plot_result() # 画图 10. main # 主程序入口第 1 部分生成二维合成数据固定随机种子means中心位置covs形状sizes点数生成数据裁剪到[0,1]第 2 部分初始化隶属度矩阵为什么要按列归一化?这一步的意义给每个样本随机分配一个“模糊归属”第 3 部分更新聚类中心哪个点对某个簇的隶属度大它对这个簇中心的贡献就更大。所以聚类中心不是简单平均而是加权平均。第 4 部分计算距离每个样本到每个中心的距离为什么要防止除零第 5 部分更新隶属度矩阵为什么先算距离因为 FCM 的思想就是离哪个中心近就更属于哪个中心。所以要先知道每个点离各中心有多远。关键部分怎么理解ratio总结隶属度是根据相对距离算出来的。越近 → 隶属度越大 越远 → 隶属度越小第 6 部分FCM 主循环初始化开始迭代为什么看U - U_old因为 FCM 最终要收敛到一个稳定状态。如果两次隶属度矩阵几乎没变化说明中心也基本稳定了 隶属度也基本稳定了 可以停止迭代第 7 部分解码 / 重构最终结果为什么这就是解码因为编码时一个点被表示成它对各中心的隶属度向量现在解码时又根据隶属度、中心位置把它还原成二维点第 8 部分重构误差第 9 部分画图1 原始数据plt.scatter(X[:,0],X[:,1],markerx,s12,alpha0.45,labelOriginal data)2 重构数据plt.scatter(X_hat[:,0],X_hat[:,1],marker,s18,alpha0.95,labelReconstruction data)3 聚类中心plt.scatter(centers[:,0],centers[:,1],markero,s80,alpha0.9,labelCenters)第 10 部分主程序生成数据Xgenerate_data(seed42)设置参数c8m2.0运行FCMcenters,Ufcm(X,cc,mm,max_iter200,tol1e-5,seed42)重构X_hatreconstruct_data(centers,U,m)算误差Vreconstruction_error(X,X_hat)输出结果print(聚类中心 centers )print(centers)print(\n隶属度矩阵 U 的形状 ,U.shape)print(重构误差 V ,V)画图plot_result(X,X_hat,centers)10 总结这段代码首先构造了一个二维合成数据集然后使用 FCM 算法对数据进行模糊聚类得到聚类中心和隶属度矩阵。这里的隶属度矩阵就是数据的编码结果因为它表示每个样本对各个原型的模糊归属。接着利用聚类中心和隶属度矩阵通过加权平均公式对每个样本进行解码重构得到 reconstruction data最后通过均方误差评价原始数据与重构数据之间的差异并可视化展示结果。代码1 导包importnumpyasnpimportmatplotlib.pyplotasplt2 生成二维合成数据1000 个点 6 组高斯分布 做过归一化defgenerate_data(seed42):np.random.seed(seed)meansnp.array([[0.18,0.82],[0.20,0.55],[0.30,0.62],[0.42,0.40],[0.68,0.34],[0.82,0.18]])covs[[[0.002,-0.001],[-0.001,0.006]],[[0.003,0.000],[0.000,0.005]],[[0.004,-0.002],[-0.002,0.006]],[[0.004,0.000],[0.000,0.003]],[[0.008,-0.004],[-0.004,0.003]],[[0.002,-0.001],[-0.001,0.002]]]sizes[170,170,160,170,180,150]# 总共1000点X_list[]formean,cov,sizeinzip(means,covs,sizes):ptsnp.random.multivariate_normal(mean,cov,size)X_list.append(pts)Xnp.vstack(X_list)Xnp.clip(X,0,1)# 限制在 [0,1]returnX3 初始化隶属度矩阵definitialize_membership(n_samples,c):Unp.random.rand(c,n_samples)UU/np.sum(U,axis0,keepdimsTrue)returnU4 更新聚类中心defupdate_centers(X,U,m):UmU**m centers(Um X)/np.sum(Um,axis1,keepdimsTrue)returncenters5 计算距离defcompute_distances(X,centers):# 返回 shape (c, N)diffX[None,:,:]-centers[:,None,:]distnp.linalg.norm(diff,axis2)distnp.fmax(dist,1e-10)# 防止除零returndist6 更新隶属度矩阵defupdate_membership(X,centers,m):distcompute_distances(X,centers)# (c, N)ccenters.shape[0]nX.shape[0]U_newnp.zeros((c,n))exponent2.0/(m-1.0)foriinrange(c):ratio(dist[i:i1,:]/dist)**exponent U_new[i,:]1.0/np.sum(ratio,axis0)returnU_new7 FCM主函数deffcm(X,c8,m2.0,max_iter200,tol1e-5,seed42):np.random.seed(seed)n_samplesX.shape[0]Uinitialize_membership(n_samples,c)foriterationinrange(max_iter):U_oldU.copy()centersupdate_centers(X,U,m)Uupdate_membership(X,centers,m)diffnp.linalg.norm(U-U_old)print(f第{iteration1}次迭代, 隶属度变化量 {diff:.8f})ifdifftol:print(FCM 收敛)breakcentersupdate_centers(X,U,m)returncenters,U8 解码解粒化defreconstruct_data(centers,U,m):UmU**m numeratorUm.T centers# (N, d)denominatornp.sum(Um,axis0,keepdimsTrue).T# (N, 1)X_hatnumerator/denominatorreturnX_hat9 重构误差defreconstruction_error(X,X_hat):returnnp.mean(np.sum((X-X_hat)**2,axis1))10 完整代码importnumpyasnpimportmatplotlib.pyplotasplt# 1. 生成二维合成数据 defgenerate_data(seed42):np.random.seed(seed)meansnp.array([[0.18,0.82],[0.20,0.55],[0.30,0.62],[0.42,0.40],[0.68,0.34],[0.82,0.18]])covs[[[0.002,-0.001],[-0.001,0.006]],[[0.003,0.000],[0.000,0.005]],[[0.004,-0.002],[-0.002,0.006]],[[0.004,0.000],[0.000,0.003]],[[0.008,-0.004],[-0.004,0.003]],[[0.002,-0.001],[-0.001,0.002]]]sizes[170,170,160,170,180,150]# 总共1000点X_list[]formean,cov,sizeinzip(means,covs,sizes):ptsnp.random.multivariate_normal(mean,cov,size)X_list.append(pts)Xnp.vstack(X_list)Xnp.clip(X,0,1)# 限制在 [0,1]returnX# 2. 初始化隶属度矩阵 definitialize_membership(n_samples,c):Unp.random.rand(c,n_samples)UU/np.sum(U,axis0,keepdimsTrue)returnU# 3. 更新聚类中心 defupdate_centers(X,U,m):UmU**m centers(Um X)/np.sum(Um,axis1,keepdimsTrue)returncenters# 4. 计算距离 defcompute_distances(X,centers):# 返回 shape (c, N)diffX[None,:,:]-centers[:,None,:]distnp.linalg.norm(diff,axis2)distnp.fmax(dist,1e-10)# 防止除零returndist# 5. 更新隶属度矩阵 defupdate_membership(X,centers,m):distcompute_distances(X,centers)# (c, N)ccenters.shape[0]nX.shape[0]U_newnp.zeros((c,n))exponent2.0/(m-1.0)foriinrange(c):ratio(dist[i:i1,:]/dist)**exponent U_new[i,:]1.0/np.sum(ratio,axis0)returnU_new# 6. FCM主函数 deffcm(X,c8,m2.0,max_iter200,tol1e-5,seed42):np.random.seed(seed)n_samplesX.shape[0]Uinitialize_membership(n_samples,c)foriterationinrange(max_iter):U_oldU.copy()centersupdate_centers(X,U,m)Uupdate_membership(X,centers,m)diffnp.linalg.norm(U-U_old)print(f第{iteration1}次迭代, 隶属度变化量 {diff:.8f})ifdifftol:print(FCM 收敛)breakcentersupdate_centers(X,U,m)returncenters,U# 7. 解码 / 重构 defreconstruct_data(centers,U,m):UmU**m numeratorUm.T centers# (N, d)denominatornp.sum(Um,axis0,keepdimsTrue).T# (N, 1)X_hatnumerator/denominatorreturnX_hat# 8. 重构误差 defreconstruction_error(X,X_hat):returnnp.mean(np.sum((X-X_hat)**2,axis1))# 9. 画图 defplot_result(X,X_hat,centers):plt.figure(figsize(7,6))plt.scatter(X[:,0],X[:,1],markerx,s12,alpha0.45,labelOriginal data)plt.scatter(X_hat[:,0],X_hat[:,1],marker,s18,alpha0.95,labelReconstruction data)plt.scatter(centers[:,0],centers[:,1],markero,s80,alpha0.9,labelCenters)plt.xlabel(r$x_1$)plt.ylabel(r$x_2$)plt.xlim(0,1)plt.ylim(0,1)plt.legend()plt.title(FCM Granulation-Degranulation)plt.show()# 10. 主程序 if__name____main__:Xgenerate_data(seed42)# 论文二维图常用参数c8m2.0centers,Ufcm(X,cc,mm,max_iter200,tol1e-5,seed42)X_hatreconstruct_data(centers,U,m)Vreconstruction_error(X,X_hat)print(\n 结果输出 )print(聚类中心 centers )print(centers)print(\n隶属度矩阵 U 的形状 ,U.shape)print(重构误差 V ,V)plot_result(X,X_hat,centers)

相关文章:

使用FCM进行编码解码Python实现代码

文章目录代码整体结构第 1 部分:生成二维合成数据固定随机种子means中心位置covs形状sizes点数生成数据裁剪到[0,1]第 2 部分:初始化隶属度矩阵为什么要按列归一化?这一步的意义第 3 部分:更新聚类中心第 4 部分:计算距离&#x…...

RPC项目

KrpcProvider的Run()整体理解服务端(RPC Provider)将自身提供的「服务 方法」注册到 ZooKeeper;客户端(RPC Consumer)调用服务前,先去 ZooKeeper 查对应「服务方法」绑定的 IP:Port;客户端拿到…...

FreeCAD 六角扳手建模教程

1. 新建实体 打开 FreeCAD,进入 Part Design 工作台。点击 “创建新零件” 或点击 “新建实体” 按钮。2. 新建草图 在实体激活状态下,点击 “创建草图”。 在弹出的对话框中选择一个基准平面(如 XY 平面),然后点击 OK…...

技术文档写作风格 - 图形

1. 图形类型 1.1 架构图子类型适用场景核心元素系统架构图展示系统整体结构模块、层次、交互关系部署架构图展示物理或逻辑部署服务器、网络、存储、地域数据架构图展示数据流转与存储数据源、处理节点、存储、流向✅ 正确示例:系统架构图应清晰展示接入层、业务层、…...

用STM32和RC522做个智能门禁:从硬件接线到代码调试的保姆级教程

用STM32和RC522打造智能门禁系统:从硬件搭建到软件调试全流程 1. 项目概述与核心组件 在物联网技术快速发展的今天,智能门禁系统已经成为现代安防领域的重要组成部分。基于STM32微控制器和RC522射频识别模块的解决方案,以其高性价比和可靠性能…...

real-anime-z应用场景:动漫社团微信公众号推文配图自动化生成流程

real-anime-z应用场景:动漫社团微信公众号推文配图自动化生成流程 1. 引言:动漫社团的配图痛点 运营动漫社团微信公众号的小伙伴们,是否经常遇到这样的困扰: 每周需要制作大量推文配图,但社团美编人手有限原创插画成…...

五子棋游戏开发详解:基于鸿蒙Electron框架和HTML5 Canvas

欢迎加入开源鸿蒙PC社区: https://harmonypc.csdn.net/ 开源atomgit仓库地址: https://atomgit.com/feng8403000/wuziqi 演示效果 项目背景 五子棋是一种古老而经典的策略棋类游戏,深受人们喜爱。在现代数字化时代,将传统游戏搬…...

基于鸿蒙Electron框架的文字战斗系统开发详解

欢迎加入开源鸿蒙PC社区: https://harmonypc.csdn.net/ atomgit开源仓库地址: https://atomgit.com/feng8403000/TextPK 示例效果 项目背景 在游戏开发中,战斗系统是一个核心组件,它直接影响游戏的可玩性和趣味性。传统的战斗系…...

鸿蒙 Electron 跨平台应用开发:文字游戏中的大魔王参战影响的战局走向

欢迎加入开源鸿蒙PC社区: https://harmonypc.csdn.net/ atomgit开源仓库地址: https://atomgit.com/feng8403000/TextAddHero 示例效果 具体效果可以观看开源仓库的GIF,CSDN只能5M,atomgit可以正常显示大的GIF 项目背景 在游…...

智能体可观察性:日志追踪与任务回溯

智能体可观察性:日志追踪与任务回溯 标题选项 从“黑箱”到“白窗”:LLM智能体生产化的核心——日志追踪与任务回溯实战指南告别智能体的“失控”时刻:手把手教你构建全链路可观察性系统DevOps AIOps:智能体日志追踪与任务回溯…...

基于鸿蒙Electron框架的碰撞效果测试与战斗系统——实战模拟

欢迎加入开源鸿蒙PC社区: https://harmonypc.csdn.net/ atomgit开源仓库地址: https://atomgit.com/feng8403000/BattleSimulator 示例效果 项目背景 在游戏开发中,碰撞检测和战斗系统是两个核心组件。碰撞检测负责检测物体之间的交互&…...

别再只懂线性了!用Van der Pol方程和庞加莱图,带你直观理解‘自激振动’与‘混沌’

非线性动力学的艺术:从自激振动到混沌的视觉探索 想象一下,当你轻轻推动一个秋千,它会逐渐停下来——这是线性系统的典型行为。但如果秋千不仅不停下,反而越荡越高,最终稳定在一个固定幅度上,这就是非线性…...

Producer 视频下载 API 集成指南

在数字音乐时代,视频和音频的结合为用户提供了丰富的体验。Ace Data Cloud 提供了 Producer API,允许我们下载与歌曲相关的视频。本文将为您详细讲解如何集成此 API。 简介 Producer API 是 Ace Data Cloud 的一部分,专注于音频相关的内容管…...

别再死记硬背PDR/PPDR了!用这个‘攻防时间赛跑’比喻,5分钟搞懂网络安全核心模型

用“攻防赛跑”故事轻松掌握PDR/PPDR安全模型 想象一下,你正在参加一场特殊的田径比赛——不过这场比赛的主角不是运动员,而是安全工程师和黑客。赛道上的每个环节都对应着网络安全的关键时刻:防护措施是起跑线上的障碍物,检测系统…...

AI Agent的抗干扰能力:复杂环境下的决策稳定性设计

AI Agent的抗干扰能力:复杂环境下的决策稳定性设计 副标题:从理论到实践,构建鲁棒性强的智能体系统 第一部分:引言与基础 1. 摘要/引言 问题陈述:在现实世界的复杂环境中部署AI Agent时,我们常常面临一个令人头疼的挑战:环境干扰。这些干扰可能来自传感器噪声、不完美…...

告别黑窗口:用QT+STKX为你的航天仿真软件做个现代化GUI界面(实战分享)

告别黑窗口:用QTSTKX为你的航天仿真软件做个现代化GUI界面(实战分享) 航天仿真领域长期被命令行工具主导,黑窗口里闪烁的光标和密密麻麻的参数让非专业用户望而生畏。STK作为行业标杆工具,其强大的计算引擎往往被埋没在…...

使用爱毕业(aibiye),数学建模论文的复现和排版优化不再是难题

AI工具在数学建模论文复现与排版中能大幅提升效率。通过评测10款热门AI论文助手发现,部分工具可自动生成LaTeX代码、优化公式排版,甚至能基于草图快速复现复杂模型。智能改写功能可避免查重问题,而文献管理模块能自动整理参考文献格式。针对时…...

**TEE安全环境下的可信执行流程实现与代码解析**在现代计算体系中,**可信执行环境(Trusted Execution Envi

TEE安全环境下的可信执行流程实现与代码解析 在现代计算体系中,可信执行环境(Trusted Execution Environment, TEE) 已成为保护敏感数据和关键逻辑的核心技术之一。尤其是在移动支付、身份认证、隐私计算等场景下,如何在非受信操作…...

通过爱毕业(aibiye),用户可以智能优化数学建模论文的复现与排版

AI工具在数学建模论文复现与排版中能大幅提升效率。通过评测10款热门AI论文助手发现,部分工具可自动生成LaTeX代码、优化公式排版,甚至能基于草图快速复现复杂模型。智能改写功能可避免查重问题,而文献管理模块能自动整理参考文献格式。针对时…...

**RPA自动化实战:用Python实现企业流程智能化改造**在当今数字化转型浪潮中,**

RPA自动化实战:用Python实现企业流程智能化改造 在当今数字化转型浪潮中,RPA(Robotic Process Automation) 已成为提升运营效率、降低人力成本的关键技术。不同于传统脚本工具,RPA强调“模拟人工操作”,可无…...

ROS Action从入门到精通:一个自定义Timer.action的完整开发、编译与调试避坑指南

ROS Action深度实战:从Timer.action开发到高级调试技巧全解析 在机器人开发中,任务执行往往需要长时间运行且状态可监控。想象一下让机器人移动到指定位置的任务——如果使用传统的服务调用,开发者无法获知移动进度,也无法中途取消…...

7个技巧彻底释放你的硬件潜能:原神帧率解锁工具深度解析

7个技巧彻底释放你的硬件潜能:原神帧率解锁工具深度解析 【免费下载链接】genshin-fps-unlock unlocks the 60 fps cap 项目地址: https://gitcode.com/gh_mirrors/ge/genshin-fps-unlock 当你的显卡和显示器都支持144Hz甚至更高刷新率,而游戏却被…...

RS-485 以太网 CAN总线 应用场景差异

结论RS‑485:低成本、远距离、低速、半双工、简单工控,小设备点对点 / 小组网CAN 总线:多主、抗干扰、高可靠、实时性强,汽车、工业现场总线首选以太网:高速、大带宽、通用互联,大数据、远程、IT/OT 融合、…...

3个核心痛点解决方案:为什么Dev-CPP仍是C++初学者的最佳选择

3个核心痛点解决方案:为什么Dev-CPP仍是C初学者的最佳选择 【免费下载链接】Dev-CPP A greatly improved Dev-Cpp 项目地址: https://gitcode.com/gh_mirrors/dev/Dev-CPP 在当今C开发工具百花齐放的时代,面对Visual Studio的庞大体积、VS Code的…...

串口电平标准及设计原理

串口通信的本质是传输“0”和“1”的电信号,但不同的标准对这两个逻辑状态的定义(电压范围、表示方式)完全不同。最核心的三个标准是:TTL、RS-232 和 RS-485。一、三大核心标准详解1. TTL(晶体管-晶体管逻辑&#xff0…...

反序列化漏洞详解(第二期):实战利用、工具实操与防御方案

反序列化漏洞详解(第二期):实战利用、工具实操与防御方案 摘要:承接反序列化漏洞第一期(基础认知与原理),本期聚焦实战落地——拆解Java、PHP反序列化漏洞的具体利用方法,结合DVWA、…...

用UniApp蓝牙控制智能硬件?从智能家居到健康设备,一个项目讲透跨平台蓝牙应用开发

UniApp蓝牙智能硬件控制实战:从协议解析到多设备管理 在智能家居和健康监测领域,蓝牙技术正成为连接移动应用与硬件设备的重要桥梁。想象一下,用同一个App控制客厅的智能灯泡、读取卧室的温湿度传感器数据、同步体脂秤的测量结果——这正是跨…...

从用户爱好到商品属性:手把手教你用 Vue3 + Element Plus 的 el-tag 搭建动态标签管理系统

从用户爱好到商品属性:手把手教你用 Vue3 Element Plus 的 el-tag 搭建动态标签管理系统 在当今数据驱动的应用开发中,标签系统已成为用户画像构建、内容分类和商品属性管理的重要工具。无论是社交平台中的用户兴趣标签,还是电商系统中的商品…...

Unity UGUI Canvas组件:从基础渲染到高级适配的实战解析

1. Canvas组件:UI系统的基石 第一次接触Unity UGUI系统时,我被Canvas组件搞得晕头转向。记得当时做了一个简单的血条UI,在不同设备上显示效果天差地别——在PC上完美显示,到了手机上却变得模糊不清。后来才发现,问题出…...

如何增加RAC节点_addnode.sh脚本执行与实例扩展全流程

addnode.sh执行失败主因是网络与权限未对齐:需验证SSH免密、/etc/hosts双向解析、GI用户一致性;CRS启动失败多因OCR/Voting磁盘权限或路径问题;实例未注册需手动srvctl add/start;连接ORA-12514系监听缺静态注册。addnode.sh 执行…...