1.17、基于竞争层的竞争学习(matlab)

1、基于竞争层的竞争学习简介及原理

竞争学习是一种无监督学习方法,其中的竞争层神经元之间互相竞争以学习输入模式的表示。竞争学习的一个经典模型是竞争神经网络(Competitive Neural Network,简称CNN),其核心部分是竞争层,包含多个竞争神经元,它们通过竞争机制来学习输入数据的特征。

竞争学习的原理如下:

  1. 模型初始化:竞争层中的每个竞争神经元具有随机初始化的权重向量,用于与输入数据进行比较。
  2. 竞争机制:当接收到输入数据时,竞争神经元之间进行竞争,即各自计算与输入数据的相似度,并选择最能代表输入数据的神经元作为胜者。
  3. 胜者更新:胜者神经元会调整自己的权重向量,使其更好地匹配输入数据,同时关闭其他神经元的更新过程,以保证只有一个胜者。
  4. 学习规则:竞争学习过程中的权重更新规则通常遵循希伯来学习规则(Hebbian Learning Rule),即“同胞竞争,异胞挤压”,即强化与输入模式相符的权重,抑制与输入模式不符的权重。
  5. 学习迭代:重复上述竞争和胜者更新过程,直到模型收敛或达到设定的迭代次数。

竞争学习在模式分类、特征提取等领域有着广泛的应用,能够有效地从输入数据中提取关键特征,并生成对应的内部表示。竞争学习的训练过程是无监督的,只依赖于输入数据的统计特性,具有较强的自组织和特征抽取能力。

2、基于竞争层的竞争学习说明

1)说明

竞争层中的神经元可通过学习来表示输入向量在输入空间中出现的不同区域

2)解决案例

P 是一组随机生成但聚类的测试数据点。竞争网络将用于将这些点分成若干自然类。

3、数据集

数据集生成代码

bounds = [0 1; 0 1];   % 聚类中心在这些范围内
clusters = 8;          % 簇数量
points = 10;           % 每个簇中的点数
std_dev = 0.05;        % 每个聚类的标准差
x = nngenc(bounds,clusters,points,std_dev);

数据集显示代码

% 绘图
figure(1)
plot(x(1,:),x(2,:),'+r');
title('Input Vectors');
xlabel('x(1)');
ylabel('x(2)');

视图效果

4、 COMPETLAYER 接受两个参量,即神经元数量和学习率。

说明

配置网络输入(通常由 TRAIN 自动完成),并绘制初始权重向量以查看其分类尝试过程。

代码

figure(2)
net = competlayer(8,.1);
net = configure(net,x);
w = net.IW{1};
plot(x(1,:),x(2,:),'+r');
hold on;
circles = plot(w(:,1),w(:,2),'ob');

视图效果

5、训练竞争层

在训练竞争层网络时,有一些注意事项需要注意:

  1. 数据预处理:在输入数据集训练之前,需要对数据进行预处理,如归一化处理,以确保不同特征之间的数值范围相同,避免某些特征对竞争过程产生过大影响。

  2. 初始权重选择:竞争层的初始权重设置可能会影响网络的收敛速度和收敛质量,因此需要仔细选择初始权重。常见的初始化方法包括随机初始化和基于数据的初始化方法。

  3. 学习率和邻域函数的选择:学习率和邻域函数的选择对竞争层的训练过程至关重要。学习率的选择会影响权重调整的速度,而邻域函数的选择则会影响胜者神经元周围神经元的权重调整程度。

  4. 迭代次数:需要根据数据集的特点和网络的复杂度来确定训练的迭代次数,以确保网络能够充分学习数据集的特征。

  5. 模型评估:在训练过程中,需要对模型进行评估,监测模型的收敛情况,以及绘制训练过程中的损失函数曲线等,以便及时调整网络参数和模型结构。

  6. 参数调优:在网络训练过程中,可能需要调整学习率、邻域函数的衰减率及初始值等参数,以达到更好的训练效果。

  7. 可视化分析:最后,可以通过可视化分析来观察竞争层的训练效果,例如可视化竞争层的权重矩阵,观察不同输入数据在竞争层的分布情况,以验证模型的有效性。

在训练竞争层网络时,注意以上事项可以帮助提高模型的训练效果,加快网络的收敛速度,并确保竞争层能够充分学习输入数据的特征。

代码

net.trainParam.epochs = 7;
net = train(net,x);

视图效果

 

6、 图上绘制更新后的层权重

代码

w = net.IW{1};
delete(circles);
plot(w(:,1),w(:,2),'ob');

视图效果

7、 使用竞争层作为分类器

1)说明

使用竞争层作为分类器,其中每个神经元都对应于一个不同的类别。将一个输入向量 X1 定义为 [0; 0.2]
输出 Y 指示哪个神经元正在响应,从而指示输入属于哪个类。

代码

x1 = [0; 0.2];
y = net(x1)y =10000000

8、总结

在MATLAB中实现基于竞争层的竞争学习可以利用自组织特征映射(Self-Organizing Map,简称SOM)算法。SOM是竞争学习的一种形式,其将输入数据在一个高维网格网络中进行竞争学习,从而实现特征提取和数据可视化。

以下是使用MATLAB实现基于竞争层的竞争学习的一般步骤总结:

  1. 准备数据:准备输入数据集,确保数据已经进行归一化处理。
  2. 初始化权重:初始化竞争层(SOM)网络的权重矩阵,每个神经元对应一个权重向量,与输入数据的维度相同。
  3. 训练模型:迭代输入数据集,对每个输入数据计算与各个神经元的距离,并选择最近的神经元作为胜者,根据胜者神经元和邻域函数更新权重矩阵。
  4. 学习率调整:随着模型训练的进行,逐渐减小学习率和邻域函数的大小,以便在后期更加精细地调整权重。
  5. 可视化结果:可视化训练后的竞争层权重矩阵,观察不同输入数据在竞争层上的分布情况。

在MATLAB中,可以利用自带的SOM工具箱或者编写自定义代码的方式实现基于竞争层的竞争学习。通过调整模型参数、学习率和迭代次数,可以对模型进行优化和调整,以获得更好的特征提取效果。此外,可以通过可视化竞争层学习后的特征表示,进一步理解模型学习到的数据结构和特征。

9、源代码

代码

%% 基于竞争层的竞争学习
%竞争层中的神经元可通过学习来表示输入向量在输入空间中出现的不同区域
%P 是一组随机生成但聚类的测试数据点。竞争网络将用于将这些点分成若干自然类。
%% 数据集
bounds = [0 1; 0 1];   % 聚类中心在这些范围内
clusters = 8;          % 簇数量
points = 10;           % 每个簇中的点数
std_dev = 0.05;        % 每个聚类的标准差
x = nngenc(bounds,clusters,points,std_dev);% 绘图
figure(1)
plot(x(1,:),x(2,:),'+r');
title('Input Vectors');
xlabel('x(1)');
ylabel('x(2)');
%COMPETLAYER 接受两个参量,即神经元数量和学习率。
%配置网络输入(通常由 TRAIN 自动完成),并绘制初始权重向量以查看其分类尝试过程。
figure(2)
net = competlayer(8,.1);
net = configure(net,x);
w = net.IW{1};
plot(x(1,:),x(2,:),'+r');
hold on;
circles = plot(w(:,1),w(:,2),'ob');
%训练竞争层
net.trainParam.epochs = 7;
net = train(net,x);
%图上绘制更新后的层权重
w = net.IW{1};
delete(circles);
plot(w(:,1),w(:,2),'ob');
%使用竞争层作为分类器
%使用竞争层作为分类器,其中每个神经元都对应于一个不同的类别。将一个输入向量 X1 定义为 [0; 0.2]
%输出 Y 指示哪个神经元正在响应,从而指示输入属于哪个类。
x1 = [0; 0.2];
y = net(x1)

工程文件

https://download.csdn.net/download/XU157303764/89498417

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【JavaScript 算法】拓扑排序:有向无环图的应用

🔥 个人主页:空白诗 文章目录 一、算法原理二、算法实现方法一:Kahn算法方法二:深度优先搜索(DFS)注释说明: 三、应用场景四、总结 拓扑排序(Topological Sorting)是一种…

《汇编语言 基于x86处理器》- 读书笔记 - Visual Studio 2019 配置 MASM环境

安装 Visual Studio 2019 配置 MASM环境 下载 Visual Studio Installer安装 Visual Studio 20191. 双击运行2. 自定义安装内容3. 修改 MSVC 工具集版本4. 设置主题(可选)5. 安装代码高亮插件 AsmDude(可选)6. 通义灵码&#xff08…

2024年第二季度 DDoS 威胁趋势报告

2024 年上半年,Cloudflare 缓解了 850 万次 DDoS 攻击:第一季度 450 万次,第二季度 400 万次。总体而言,第二季度 DDoS 攻击数量环比下降了 11%,但同比增长了 20%。 DDoS 攻击分布(按类型和手段&#xff09…

面试官听了我说的单例设计模式,让我出门右转

⭐简单说两句⭐ ✨ 正在努力的小叮当~ 💖 超级爱分享,分享各种有趣干货! 👩‍💻 提供:模拟面试 | 简历诊断 | 独家简历模板 🌈 感谢关注,关注了你就是我的超级粉丝啦! &a…

Go语言之参数传递

文章收录在网站:http://hardyfish.top/ 文章收录在网站:http://hardyfish.top/ 文章收录在网站:http://hardyfish.top/ 文章收录在网站:http://hardyfish.top/ 修改参数 假设你定义了一个函数,并在函数里对参数进行…

机器人开源调度系统OpenTcs6-架构运行分析

系统启动 启动 Kernel:加载核心应用,初始化系统配置和状态。 启动 Plant Overview:加载图形用户界面,初始化模型和用户界面。 模型导入和配置 在 Plant Overview 中导入或创建工厂布局模型。 配置路径、位置和车辆信息。 车辆连…

C语言 | Leetcode C语言题解之第240题搜索二维矩阵II

题目&#xff1a; 题解&#xff1a; bool searchMatrix(int** matrix, int matrixSize, int* matrixColSize, int target){int i 0;int j matrixColSize[0] - 1;while(j > 0 && i < matrixSize){if(target < matrix[i][j])j--;else if(target > matrix[…

达梦数据库的系统视图v$mal_link_status

达梦数据库的系统视图v$mal_link_status 在达梦数据库&#xff08;DM Database&#xff09;中&#xff0c;V$MAL_LINK_STATUS 是一个动态性能视图&#xff08;Dynamic Performance View&#xff09;&#xff0c;用于显示MAL&#xff08;Multi-threaded Architecture Link&…

cs224w笔记(p5)

链接预测任务的两种类型&#xff1a;随机缺失边&#xff1b;随时间演化边。 第一种假设可以以蛋白质之间的交互作用举例&#xff0c;缺失的是研究者还没有发现的交互作用。 第二种假设可以以社交网络举例&#xff0c;随着时间流转&#xff0c;人们认识更多朋友。 基于相似性进…

【北京迅为】《i.MX8MM嵌入式Linux开发指南》-第三篇 嵌入式Linux驱动开发篇-第三十六章 Linux驱动初探

i.MX8MM处理器采用了先进的14LPCFinFET工艺&#xff0c;提供更快的速度和更高的电源效率;四核Cortex-A53&#xff0c;单核Cortex-M4&#xff0c;多达五个内核 &#xff0c;主频高达1.8GHz&#xff0c;2G DDR4内存、8G EMMC存储。千兆工业级以太网、MIPI-DSI、USB HOST、WIFI/BT…

Android 小白菜鸟从入门到精通教程

前言 Android一词最早出现于法国作家利尔亚当&#xff08;Auguste Villiers de l’Isle-Adam&#xff09;在1886年发表的科幻小说《未来的夏娃》&#xff08;L’ve future&#xff09;中。他将外表像人的机器起名为Android。从初学者的角度出发&#xff0c;通过通俗易懂的语言…

使用 useLazyAsyncData 提升数据加载体验

title: 使用 useLazyAsyncData 提升数据加载体验 date: 2024/7/19 updated: 2024/7/19 author: cmdragon excerpt: 摘要&#xff1a;本文介绍useLazyAsyncData函数在Nuxt 3中的使用&#xff0c;以提升数据加载体验。此函数支持异步获取数据并在组件中处理挂起与错误状态&…

[网鼎杯 2018]Fakebook

解法一 在robots.txt&#xff0c;可以发现/user.php.bak 下载下来是一段代码 <?phpclass UserInfo {public $name "";public $age 0;public $blog "";public function __construct($name, $age, $blog){$this->name $name;$this->age (…

spring-boot 整合 redisson 实现延时队列(文末有彩蛋)

应用场景 通常在一些需要经历一段时间或者到达某个指定时间节点才会执行的功能&#xff0c;比如以下这些场景&#xff1a; 订单超时提醒收货自动确认会议提醒代办事项提醒 为什么使用延时队列 对于数据量小且实时性要求不高的需求来说&#xff0c;最简单的方法就是定时扫描数据…

电机泵盖机器人打磨去毛刺,选德国进口高精度主轴

机器人打磨去毛刺该如何选择主轴呢&#xff1f;首先我们需要考虑的是工件的材质&#xff0c;电机泵盖通常使用铸铁、不锈钢、合金钢等金属材质&#xff0c;因此这类保持的硬度较高&#xff0c;一般会选择功率、扭矩较大的德国进口高精度主轴Kasite 4060 ER-S。 Kasite 4060 ER-…

【Espressif-ESP32S3】【VScode】安装【ESP-IDF】插件及相关工具链

一、ESP-IDF简介 二、VScode安装ESP-IDF插件 三、安装ESP-IDF、ESP-IDF-Tools以及相关工具链 四、测试例程&编译烧录 五、IDF常用指令 资料下载&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/15Q2rl2jpIaKfj5rATkYE6g?pwdGLNG 提取码&#xff1a;GLNG 一、ESP-…

浏览器缓存:强缓存与协商缓存实现原理有哪些?

1、强缓存&#xff1a;设置缓存时间的&#xff0c;那么在这个时间内浏览器向服务器发送请求更新数据&#xff0c;但是服务器会让其从缓存中获取数据。 可参考&#xff1a;彻底弄懂强缓存与协商缓存 - 简书 2、协商缓存每次都会向浏览器询问&#xff0c;那么是怎么询问的呢&…

「MQTT over QUIC」与「MQTT over TCP」与 「TCP 」通信测试报告

一、结论 在实车5G测试中「MQTT Over QUIC」整体表现优于「TCP」&#xff0c;可在系统架构升级时采用MQTT Over QUIC替换原有的TCP通讯&#xff1b;从实现原理上基于QUIC比基于TCP在弱网、网络抖动导致频繁重连场景延迟更低。 二、测试方案 网络类型&#xff1a;实车5G、实车…

【Apache Doris】周FAQ集锦:第 14 期

【Apache Doris】周FAQ集锦&#xff1a;第 14 期 SQL问题数据操作问题运维常见问题其它问题关于社区 欢迎查阅本周的 Apache Doris 社区 FAQ 栏目&#xff01; 在这个栏目中&#xff0c;每周将筛选社区反馈的热门问题和话题&#xff0c;重点回答并进行深入探讨。旨在为广大用户…

【VUE】v-if和v-for的优先级

v-if和v-for v-if 用来显示和隐藏元素 flag为true时&#xff0c;dom元素会被删除达到隐藏效果 <div class"boxIf" v-if"flag"></div>v-for用来进行遍历&#xff0c;可以遍历数字对象数组&#xff0c;会将整个元素遍历指定次数 <!-- 遍…