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

凡科建站源码成都旅游景点攻略自由行攻略

凡科建站源码,成都旅游景点攻略自由行攻略,大庆油田app下载安装官方版,如何建立网络销售平台Topsis优劣解 一种新的评价方法,特点就是利用原有数据,客观性强。 相较于模糊评价和层次评价 更加客观,充分利用原有数据,精确反映方案差距 基本原理 离最优解最近,离最劣解越远 具体步骤 正向化 代码与原理与熵权…

Topsis优劣解

一种新的评价方法,特点就是利用原有数据,客观性强。

相较于模糊评价和层次评价

更加客观,充分利用原有数据,精确反映方案差距
在这里插入图片描述

基本原理

离最优解最近,离最劣解越远
在这里插入图片描述

具体步骤

正向化

代码与原理与熵权法类同,不多赘述

标准化

标准化的目的是为了消除计量单位不同的影响
标准化的计算方式不是算数平均,而是平方数的平均

*优劣解打分

  • 1.优先计算最优解和最劣解,作为行向量存在
    在这里插入图片描述
  • 2.分别计算每一个对象i的j指标相对优劣解的距离
    在这里插入图片描述
  • 3.按照公式得出对象的得分进行归一化

带权值的优劣解计算

  • 距离之差表现在矩阵乘法上作为矩阵
  • 这个权值表现在矩阵乘法上是作为列向量,原因很简单:线性组合。这点很重要!
    在这里插入图片描述
    w向量形式如下图
    在这里插入图片描述
    公式中的"距离之差的平方"形式如下图
    在这里插入图片描述

如果你运行不成功可能是变量名不一样,matlab支持一步步运行代码。

权重的计算:

熵权法/层次分析法
在需要计算时,直接跳转熵权法代码运行这一节即可(保持变量名统一)

%% 概率矩阵P、计算信息熵和熵权
P=Stand_X./repmat(sum(Stand_X),n,1);
for i=1:nfor j=1:mif P(i,j)==0P(i,j)=0.000001endend
end
H=sum(-P.*log(P));
e=H./log(n);
d=1-e;
d=d./sum(d);
disp("计算完成,下面是计算得出的权重矩阵");
disp(d);
temp=input("是否需要正向矩阵、标准矩阵?输入1表示需要,其他表示不需要");
if temp==1disp(X);disp(Stand_X);
end

Topsis代码如下

%% 读取数据
X=xlsread("工作簿1.xlsx");
X=X(:,[2:5]);%注意读取时不要误读,可以直接范围所有
disp("成功读取!");
%% 正向化
disp("现在进行正向化操作,请按照提示操作")
vec_col=input("请输入需要正向化的列数,以数组的形式输入\n");
for i=1:size(vec_col,2)%1是行数2是列数
flag = input(['第' num2str(vec_col(i)) '列是哪类数据(【1】:极小型 【2】:中间型 【3】:区间型),请输入序号:\n']);if flag==1X(:,vec_col(i))=Min2Max(X(:,vec_col(i)));elseif flag==2best=input("请你传入最佳值\n");X(:,vec_col(i))=Mid2Max(X(:,vec_col(i)),best);elsearr=input("请你输入区间的左右端点,以数组的形式\n");X(:,vec_col(i))=Interval2Max(X(:,vec_col(i)),arr(1),arr(2));end
end
disp("正向化完成!");
%% 标准化
[n,m]=size(X);
Square_X=X.*X;
Sum_X=sum(Square_X).^0.5;
Stand_X=X./repmat(Sum_X,n,1);
disp("标准化完成!")
%% 优劣解打分
min_X=min(Stand_X,[],1);%[C,index] = max(A,[],dim);
max_X=max(Stand_X,[],1);
disp("正在使用优劣解打分");
temp=ones(m);
weight=temp(:,1);%默认权值
need_w_flag=input("是否需要手动输入权值?如果需要请输入1\n");
if need_w_flag==1weight=input("请将权值以列的形式给出!");
end
Z_plus=repmat(max_X,n,1);
Z_sub=repmat(min_X,n,1);
D_plus=sum((Z_plus-Stand_X).^2*weight,2).^2;
%根据公式weight一定要右乘
D_sub=sum((Z_sub-Stand_X).^2*weight,2).^2;
S=D_sub./(D_sub+D_plus);
%归一化
S=S./sum(S);
disp("评分如下");
disp(S);
xlswrite("工作簿1.xlsx",S,'F2:F26');

距离法

基本原理

根据每一个元素与最大值最小值的距离打分,比较朴素,一般不使用这个方法评

在这里插入图片描述

代码如下

%% 读取数据
X=xlsread("工作簿1.xlsx");
X=X(:,[2:5]);%注意读取时不要误读,可以直接范围所有
disp("成功读取!");
%% 正向化
disp("现在进行正向化操作,请按照提示操作")
vec_col=input("请输入需要正向化的列数,以数组的形式输入\n");
for i=1:size(vec_col,2)%1是行数2是列数
flag = input(['第' num2str(vec_col(i)) '列是哪类数据(【1】:极小型 【2】:中间型 【3】:区间型),请输入序号:\n']);if flag==1X(:,vec_col(i))=Min2Max(X(:,vec_col(i)));elseif flag==2best=input("请你传入最佳值\n");X(:,vec_col(i))=Mid2Max(X(:,vec_col(i)),best);elsearr=input("请你输入区间的左右端点,以数组的形式\n");X(:,vec_col(i))=Interval2Max(X(:,vec_col(i)),arr(1),arr(2));end
end
disp("正向化完成!");
%% 标准化
[n,m]=size(X);
Square_X=X.*X;
Sum_X=sum(Square_X).^0.5;
Stand_X=X./repmat(Sum_X,n,1);
disp("标准化完成!")
%% 距离法打分
min_X=min(Stand_X,[],1);%[C,index] = max(A,[],dim);
max_X=max(Stand_X,[],1);
res1=(Stand_X-repmat(min_X,n,1))./(repmat(max_X,n,1)-repmat(min_X,n,1));
disp(res1);
http://www.yayakq.cn/news/488759/

相关文章:

  • 网站如何提交给百度成都哪里好玩好吃
  • 网站建设与维护心得体会金融棋牌网站建设
  • 17一起做网站app去哪个网站做农产品推广
  • 网站管理程序北京外贸推广
  • 网页设计网站长沙温州建网站公司
  • 杭州网站建设(推荐乐云践新)制作企业网站要花多少钱
  • 湛江网站建设方案外包山西大同最新通告今天
  • 有没有免费的网站保定最大的网络公司
  • 网站建设与软件开发哪个好赚钱国际外贸网站建设
  • 网站模板下载地址ftps 网站怎么做
  • 网站开发大公司需要资格证吗html 路径 网站根路径
  • 如何做网站推广私人建设银行手机银行官方网站
  • 专业做房地产网站建设wordpress 生成目录
  • 建设一个私人视频网站个人网站做什么资源赚钱
  • 帝国cms添加网站地图企业年金退休后是一次性领取还是按月领取
  • 电脑做网站主机空间企业宣传网站建设模板
  • 有关网站建设的知识亳州做网站
  • 网站开发需要如何压缩代码物联网系统
  • 赣州网站建设费用房产门户网站平台搭建
  • 私人订制网站的建设的设计表高端的佛山网站建设价格
  • 建设网站是什么关系Wordpress导出成word
  • 网站建设为什么必须有服务器wordpress支付端口
  • 做网站的品牌公司西宁网站建设
  • 企业被网站收录怎么查网站的所有权
  • 营销型网站特征网站模板找超速云建站
  • 基础的网站建设平台网站怎么建设
  • wordpress用什么发post上海网站优化排名公司
  • 可商用图片素材网站北京搜索引擎推广服务
  • 网站入口百度湘潭网站建设 尖端磐石网络
  • 网站搭建费用计入什么科目网络推广平台代理