QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2703|回复: 1
打印 上一主题 下一主题

[问题求助] 因子分析中因子旋转用matlab怎么实现?

[复制链接]
字体大小: 正常 放大

52

主题

6

听众

495

积分

升级  65%

  • TA的每日心情
    开心
    2014-7-12 17:09
  • 签到天数: 115 天

    [LV.6]常住居民II

    自我介绍
    数学本科

    群组数学建模培训课堂1

    跳转到指定楼层
    1#
    发表于 2013-8-28 20:05 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    在线等,谢谢
    zan
    转播转播 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    madio        

    3万

    主题

    1311

    听众

    5万

    积分

  • TA的每日心情
    奋斗
    2024-7-1 22:21
  • 签到天数: 2014 天

    [LV.Master]伴坛终老

    自我介绍
    数学中国站长

    社区QQ达人 邮箱绑定达人 优秀斑竹奖 发帖功臣 风雨历程奖 新人进步奖 最具活力勋章

    群组数学建模培训课堂1

    群组数学中国美赛辅助报名

    群组Matlab讨论组

    群组2013认证赛A题讨论群组

    群组2013认证赛C题讨论群组

    %--------------------------------------------------------------------------
    %                   从相关系数矩阵出发进行因子分析
    %--------------------------------------------------------------------------   
    %***************************定义相关系数矩阵PHO*****************************
    PHO = [1     0.79    0.36    0.76    0.25    0.51           
           0.79  1       0.31    0.55    0.17    0.35           
           0.36  0.31    1       0.35    0.64    0.58           
           0.76  0.55    0.35    1       0.16    0.38           
           0.25  0.17    0.64    0.16    1       0.63           
           0.51  0.35    0.58    0.38    0.63    1    ];   

    %******************调用factoran函数根据相关系数矩阵作因子分析*****************
    % 从相关系数矩阵出发,进行因子分析,公共因子数为2,设置特殊方差的下限为0,
    % 不进行因子旋转  
    [lambda,psi,T] = factoran(PHO,2,'xtype','covariance','delta',0,'rotate','none')   

    % 定义元胞数组,以元胞数组形式显示结果
    % 表头  
    head = {'变量', '因子f1', '因子f2'};
    % 变量名  
    varname = {'身高','坐高','胸围','手臂长','肋围','腰围','<贡献率>','<累积贡献率>'}';  
    Contribut = 100*sum(lambda.^2)/6;    % 计算贡献率,因子载荷阵的列元素之和除以维数
    CumCont = cumsum(Contribut);    % 计算累积贡献率  
    % 将因子载荷阵,贡献率和累积贡献率放在一起,转为元胞数组
    result1 = num2cell([lambda; Contribut; CumCont]);
    % 加上表头和变量名,然后显示结果
    result1 = [head; varname, result1]   

    %从相关系数矩阵出发,进行因子分析,公共因子数为2,设置特殊方差的下限为0,
    %进行因子旋转(最大方差旋转法)  
    [lambda,psi,T] =factoran(PHO,2,'xtype','covariance','delta',0)  
    Contribut = 100*sum(lambda.^2)/6    %计算贡献率,因子载荷阵的列元素之和除以维数
    CumCont = cumsum(Contribut)    %计算累积贡献率   

    % 从相关系数矩阵出发,进行因子分析,公共因子数为3,设置特殊方差的下限为0,
    % 进行因子旋转(最大方差旋转法)  
    [lambda,psi,T] = factoran(PHO,3,'xtype','covariance','delta',0)  
    Contribut = 100*sum(lambda.^2)/6    % 计算贡献率,因子载荷阵的列元素之和除以维数
    CumCont = cumsum(Contribut)    % 计算累积贡献率

    %--------------------------------------------------------------------------
    %               读取examp12_02.xls中数据,进行因子分析
    %--------------------------------------------------------------------------   
    %*********************************读取数据*********************************
    [X,textdata] = xlsread('examp12_02.xls');    % 从Excel文件中读取数据
    X = X(:,3:end);    % 提取X的第3至最后一列,即要分析的数据  
    varname = textdata(4,3:end);  %提取textdata的第4行,第3至最后一列,即变量名  
    obsname = textdata(5:end,2);  %提取textdata的第2列,第5至最后一行,即国家或地区名   

    %******************调用factoran函数根据原始观测数据作因子分析*****************
    % 从原始数据(实质还是相关系数矩阵)出发,进行因子分析,公共因子数为4
    % 进行因子旋转(最大方差旋转法)
    [lambda,psi,T,stats] = factoran(X,4)
    Contribut = 100*sum(lambda.^2)/8    %计算贡献率,因子载荷阵的列元素之和除以维数
    CumCont = cumsum(Contribut)    %计算累积贡献率     

    % 从原始数据(实质还是相关系数矩阵)出发,进行因子分析,公共因子数为2
    % 进行因子旋转(最大方差旋转法)
    [lambda,psi,T,stats,F] = factoran(X, 2)  
    Contribut = 100*sum(lambda.^2)/8    %计算贡献率,因子载荷阵的列元素之和除以维数
    CumCont = cumsum(Contribut)    %计算累积贡献率   
    [varname' num2cell(lambda)]   

    %**************将因子得分F分别按耐力因子得分和速度因子得分进行排序*************  
    obsF = [obsname, num2cell(F)];    % 将国家和地区名与因子得分放在一个元胞数组中显示
    F1 = sortrows(obsF, 2);    % 按耐力因子得分排序
    F2 = sortrows(obsF, 3);    % 按速度因子得分排序
    head = {'国家/地区','耐力因子','速度因子'};  
    result1 = [head; F1];    % 显示按耐力因子得分排序的结果
    result2 = [head; F2];    % 显示按速度因子得分排序的结果   

    %*************************绘制因子得分负值的散点图***************************
    plot(-F(:,1),-F(:,2),'k.')     %作因子得分负值的散点图
    xlabel('耐力因子得分(负值)');    %为X轴加标签
    ylabel('速度因子得分(负值)');    %为Y轴加标签
    box off     %去掉坐标系右上的边框
    gname(obsname);    %交互式添加各散点的标注

    数学建模社会化
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-10-13 04:58 , Processed in 0.560265 second(s), 60 queries .

    回顶部