• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

MATLAB自定义函数

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

如果你刚接触matlab,可以看这篇Matlab自定义函数详解

MATLAB自定义函数形式

function [a,b,c] = funname(x1,x2,x3)

输入变量

对于输入变量,MATLAB可以识别输入变量的个数,通过nargin来记录当前输入变量个数。

if nargin == 1
	···
elseif nargin == 2
	····
elseif nargin == 3
	···
end

通过nargin判断变量个数,然后再写对应的程序。

输出变量

对于输出变量,MATLAB可以根据调用情况来输出结果

y = funname(x1)
[y1,y2] = funname(x1)
[y1,y2,y3] = funnamr(x1)

根据调用的格式,自动忽略没匹配上的输出结果。

函数调用帮助

函数做好之后,需要写好说明,否则代码的通用性会很差!matlab自动将函数下的注释当作函数说明,通过help来查看帮助文档

help funname
function y = mean(x,dim,flag,flag2)
%MEAN   Average or mean value.
%   S = MEAN(X) is the mean value of the elements in X if X is a vector. 
%   For matrices, S is a row vector containing the mean value of each 
%   column. 
%   For N-D arrays, S is the mean value of the elements along the first 
%   array dimension whose size does not equal 1.

上面是mean函数的帮助说明。

自己动手写一个函数

这里我们来动手写一个数据标准化的函数,具体要求是这样的

对于一组数据 $$ x_{1}, x_{2}, \cdots, x_{m} $$, 分高优指标(越大越好),低优指标(越小越好),中优指标(越趋近于某个值越好),均优指标(越趋近于某个区间越好),四种标准化方式对数据标准化。

function [x] = standlize(v,type,q)
%STANDLIZE   对列向量v 进行归一化 返回归一化后的向量 x
%  x = STANDLIZE(v,\'low\') 对列向量按低优指标进行归一化
%  x = STANDLIZE(v,\'high\') 对列向量按高优指标进行归一化
%  x = STANDLIZE(v,\'middle\',q) 对列向量按中优指标进行归一化
%  x = STANDLIZE(v,\'between\',q) 其中 q = [a , b] 对列向量按均优指标进行归一化
m = length(v);
if nargin==2
    if strcmp(type,\'low\') %低优指标
        for i=1:m
            x(i) = (max(v)-v(i))/(max(v)-min(v));
        end
    elseif  strcmp(type,\'high\') %高优指标
        for i=1:m
            x(i) = (v(i)-min(v))/(max(v)-min(v));
        end
    end
elseif nargin==3
    if strcmp(type,\'middle\')&&length(q)==1 %中优指标
        for i=1:m
            if v(i) < q
                x(i) = 1 - (q-v(i))/max([q-min(v),max(v)-q]);
            elseif  v(i) > q
                x(i) = 1 - (v(i)-q)/max([q-min(v),max(v)-q]);
            else
                x(i) = 1;
            end
        end
    elseif strcmp(type,\'between\')&&length(q)==2 %均优指标
        for i=1:m
            if v(i) < q(1)
                x(i) = 1-(q(1)-v(i))/(max([q(1)-min(v),max(v)-q(2)]));
            elseif v(i) > q(2)
                x(i) = 1-(v(i)-q(2))/(max([q(1)-min(v),max(v)-q(2)]));
            else
                x(i)=1;
            end
        end
    end
end
x = reshape(x,size(v));
end

运行测试

可以看到,对于1到10这样一组数据,通过standlize这个函数的不同调用方式,实现了数据的指标标准化。通过help可以查看用法。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
理解Delphi的类(十)-深入方法[20]-静态数组参数发布时间:2022-07-18
下一篇:
动画演示Delphi2007IDE功能[2]-定义变量发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap