Fisher线性判别与感知器算法Matlab实现

2024-05-31 11:38

本文主要是介绍Fisher线性判别与感知器算法Matlab实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考用书:


本文是在学习此书Chapter4时,跑的实验。

4.1.4 Fisher‘s Linear Discriminate


[plain]  view plain copy
  1. function [w y1 y2 Jw] = FisherLinearDiscriminat(data, label)  
  2. % FLD Fisher Linear Discriminant.  
  3. % data : D*N data  
  4. % label : {+1,-1}  
  5. % Reference:M.Bishop Pattern Recognition and Machine Learning p186-p189  
  6.   
  7. % compute means and scatter matrix  
  8. %-------------------------------  
  9. inx1 = find( label == 1);  
  10. inx2 = find( label == -1);  
  11. n1 = length(inx1);  
  12. n2 = length(inx2);  
  13.   
  14. m1 = mean(data(:,inx1),2);  
  15. m2 = mean(data(:,inx2),2);  
  16.   
  17. S1 = (data(:,inx1)-m1*ones(1,n1))*(data(:,inx1)-m1*ones(1,n1))';  
  18. S2 = (data(:,inx2)-m2*ones(1,n2))*(data(:,inx2)-m2*ones(1,n2))';  
  19. Sw = S1 + S2;  
  20.   
  21. % compute FLD   
  22. %-------------------------------  
  23. W = inv(Sw)*(m1-m2);  
  24.   
  25. y1 = W'*m1;  %label=+1  
  26. y2 = W'*m2;  %label=-1  
  27. w = W;  
  28. Jw = (y1-y2)^2/(W'*Sw*W);  


4.1.7 The perceptron algorithm 

[plain]  view plain copy
  1. function [w, mis_class] = perceptron(X,t)  
  2. % The perceptron algorithm   
  3. %by LiFeiteng   email:lifeiteng0422@gmail.com  
  4. %   X : D*N维输入数据  
  5. %   t : {+1,-1}标签  
  6. %     
  7. %   w : [w0 w1 w2]     
  8. %   mis_class : 错误分类数据点数  
  9.   
  10. %  对t做简单的检查  
  11. if size(unique(t),2)~=2  
  12.     return  
  13. elseif max(t)~=1  
  14.     return  
  15. elseif min(t)~=-1  
  16.     return  
  17. end  
  18.   
  19. [dim num_data] = size(X);  
  20. w = ones(dim+1,1);%%w = [w0 w1 w2]'  
  21. X = [ones(1,num_data); X];  
  22. maxiter = 100000;  
  23. mis_class = 0;  
  24. iter = 0;  
  25.   
  26. while iter<maxiter  
  27.     iter = iter+1;  
  28.     y = w'*X;  
  29.     label = ones(1, num_data);%{+1,-1}  
  30.     label(y<=0) = -1;    
  31.     index = find(label~=t); %错误分类的点  
  32.     mis_class = numel(index); %错误分类点的数目     
  33.     if mis_class==0  
  34.         break  
  35.     end  
  36.     for i = 1:mis_class  
  37.         w = w + X(:,index(i))*t(index(i));  
  38.     end  
  39. end  
  40. if iter==maxiter  
  41.     disp(['达到最大迭代次数' num2str(maxiter)])  
  42. end  


这篇关于Fisher线性判别与感知器算法Matlab实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1017817

相关文章

Golang实现基于角色的访问控制(RBAC)的项目实践

《Golang实现基于角色的访问控制(RBAC)的项目实践》基于角色的访问控制(RBAC)是一种安全机制,通过角色来管理用户权限,本文介绍了一种可落地、易扩展的GolangRBAC实现方案,具有一定... 目录一、RBAC 核心模型设计二、RBAC 核心逻辑实现RBAC 管理器定义基础 CRUD:添加用户

Python使用Spire.PDF实现为PDF添加水印

《Python使用Spire.PDF实现为PDF添加水印》在现代数字化办公环境中,PDF已成为一种广泛使用的文件格式,尤其是在需要保持文档格式时,下面我们就来看看如何使用Python为PDF文件添加水... 目录一、准备工作二、实现步骤1. 导入必要的库2. 创建 PdfDocument 对象3. 设置水印

python在word中插入目录和更新目录实现方式

《python在word中插入目录和更新目录实现方式》文章主要介绍了如何在Word文档中插入和更新目录,并提供了具体的代码示例,插入目录时,需要使用`TablesOfContents`对象,并设置使用... 目录1、插入目录2、更新目录总结1、插入目录需要用到对象:TablesOfContents目录的

PostgreSQ数据库实现在Windows上异地自动备份指南的详细教程

《PostgreSQ数据库实现在Windows上异地自动备份指南的详细教程》这篇文章主要为大家详细介绍了如何在Windows系统上实现PostgreSQL数据库的异地自动备份,文中的示例代码讲解详细,... 目录前期准备实现步骤步骤一:创建备份脚本步骤二:配置免密登录(可选但推荐)步骤三:设置任务计划程序步

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

Java中Map的五种遍历方式实现与对比

《Java中Map的五种遍历方式实现与对比》其实Map遍历藏着多种玩法,有的优雅简洁,有的性能拉满,今天咱们盘一盘这些进阶偏基础的遍历方式,告别重复又臃肿的代码,感兴趣的小伙伴可以了解下... 目录一、先搞懂:Map遍历的核心目标二、几种遍历方式的对比1. 传统EntrySet遍历(最通用)2. Lambd

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso

SpringBoo WebFlux+MongoDB实现非阻塞API过程

《SpringBooWebFlux+MongoDB实现非阻塞API过程》本文介绍了如何使用SpringBootWebFlux和MongoDB实现非阻塞API,通过响应式编程提高系统的吞吐量和响应性能... 目录一、引言二、响应式编程基础2.1 响应式编程概念2.2 响应式编程的优势2.3 响应式编程相关技术