怎么用MATLAB实现argmin函数?

怎么用MATLAB实现argmin函数?,第1张

function x = Corresponding_index(A,B)

% Function: Determine the position of the element in array B corresponding to the equivalent element in array A

% Author:Gong Pf. Time:2019-7-2

% Remark: Only consider A and B is one or two dimension

% And x is a size(B,1)*size(B,2) cell

% Each cell x{i,j} is a t*2 array

% (t is the number of times that the element B(i,j) appears in A)

% And x{i,j}(n,1),x{i,j}(n,2) represent the row and column of the element in A

% Example1:A = [1 2 3 4 1 2 8]

% B = [0 1 2]

% x = argmax_min(A,B)

% x = [][2x2 double][2x2 double] = [] [1 11 5] [1 21 6]

% Example2:A = [1 2 42 4 25 9 83 9 3]

% B = [1 32 9]

% x = argmax_min(A,B)

% x = [1x2 double][2x2 double]= [1 1][4 14 3]

% [3x2 double][2x2 double] [1 22 12 3] [3 24 2]

% Interpret the result: (x{1,1}(1,1),x{1,1}(1,2))=(1,1)

%This is where B(1,1) appears in A

% (x{1,2}(1,1),x{1,2}(1,2))=(4,1) and (x{1,2}(2,1),x{1,2}(2,2))=(4,3)

% These are where B(1,2) appears in A

% Can be used to implement argmin and argmax functions

%% A and B array is less or equal two-dimensional

row_col = size(A)

ii = 1

jj = 1

% Count the number of occurrences of elements in one-dimensional array B in A

B_times = zeros(size(B))

for i = 1:size(B,1)

for j = 1:size(B,2)

B_times(i,j) = length(find(A == B(i,j)))

end

end

% Count the position of the element in B in A

for i = 1:size(B,1)

for j = 1:size(B,2)

for m = 1:row_col(1)

for n = 1:row_col(2)

if A(m,n) == B(i,j)

x{i,j}(1,ii) = m

x{i,j}(2,jj) = n

ii = ii + 1

jj = jj + 1

end

end

end

ii = 1

jj = 1

end

end

x=norm(y-ah,2)

x1=min(min(x))

x2=Corresponding_index(x,x1)

disp(x2)

y=λ*norm(h,1)

DataFrame对象:二维表数据结构,由行列数据组成的表格

常用index表示行,columns表示列

'''

  语文  数学  英语

0  110  105    99

1  105    88  115

2  109  120  130

'''

# print(df.columns)  # Index(['语文', '数学', '英语'], dtype='object')

# print(df.index)  # Int64Index([0, 1, 2], dtype='int64')

# 遍历DataFrame数据的每一列

'''

0    110

1    105

2    109

Name: 语文, dtype: int64

0    105

1    88

2    120

Name: 数学, dtype: int64

0    99

1    115

2    130

Name: 英语, dtype: int64

'''

1.创建一个DataFrame对象

pandas.DataFrame(data,index,columns,dtype,copy)

# data表示数据,可以是ndarray数组,series对象、列表、字典等

# index表示行标签(索引

# columns表示列标签(索引)

# dtype每一列数据的数据类型

# copy用于复制数据

# 返回值DataFrame

通过二维数组创建成绩表

'''

  语文  数学  英语

0  110  105    99

1  105    88  115

2  109  120  130

'''

2.通过字典创建DataFrame对象

value值只能是一维数组或单个的简单数据类型

# 数组,则要求所有的数组长度一致

# 单个数据,每行都需要添加相同数据

'''

  语文  数学  英语    班级

0  110  105  109  高一7班

1  105    88  120  高一7班

2    99  115  130  高一7班

'''

'''

【DataFrame属性】

values 查看所有元素的值  df.values

dtypes 查看所有元素的类型  df.dtypes

index 查看所有行名、重命名行名  df.index    df.index=[1,2,3]

columns 查看所有列名、重命名列名  df.columns  df.columns=['语','数']

T 行列数据转换  df.T

head 查看前n条数据,默认5条                df.head()  df.head(10)

tail 查看后n条数据,默认5条                df.tail()  df.tail(10)

shape 查看行数和列数,[0]表示行,[1]表示列    df.shape[0]  df.shape[1]

info 查看索引,数据类型和内存信息    df.info

【DataFrame函数】

describe 查看每列的统计汇总信息,DataFrame类型  df.describe()

count    返回每一列中的非空值的个数              df.count()

sum      返回每一列和和,无法计算返回空值      df.sum()

max      返回每一列的最大值                df.max()

min      返回每一列的最小值                df.min()

argmax  返回最大值所在的自动索引位置        df.argmax()

argmin  返回最小值所在的自动索引位置        df.argmin()

idxmax  返回最大值所在的自定义索引位置      df.idxmax()

idxmin  返回最小值所在的自定义索引位置      df.idxmin()

mean    返回每一列的平均值                df.mean()

median  返回每一列的中位数                df.median()

var      返回每一列的方差                  df.var()

std      返回每一列的标准差  df.std()

isnull  检查df中的空值,空值为True,否则为False,返回布尔型数组  df.isnull()

notnull  检查df中的空值,非空值为True,否则为False,返回布尔型数组  df.notnull()

中位数又称中值,是指按顺序排列的一组数据中居于中间位置的数

方差用于度量单个随机变量的离散程序(不连续程度)

标准差是方差的算术平方根,反映数据集的离散程度

'''

3. 导入.xls或.xlsx文件

# pandas.read_excel(io,sheetname=0,header=0,names=None,index_col=None,usecols=None,squeeze=False,dtype=None,engine=None,converters=None,true_values=None,false_values=None,skiprows=None,nrow=None,na_values=None,keep_defalut_na=True,verbose=False,parse_dates=False,date_parser=None,thousands=None,comment=None,skipfooter=0,conver_float=True,mangle_dupe_cols=True,**kwds)

'''

io 字符串,xls或xlsx文件路径或类文件对象

sheet_name:None、字符串、整数、字符串列表或整数列表,默认值为0

    字符串用于工作表名称;整数为索引,表示工作表位置

    字符串列表或整数列表用于请求多个工作表,为None时则获取所有的工作表

    sheet_name = 0 第一个Sheet页中的数据作为DataFrame对象

    sheet_name = 1 第二个Sheet页中的数据作为DataFrame对象

    sheet_name = 'Sheet1' 名为Sheet1的Sheet页中的数据作为DataFrame对象

    sheet_name = [0,1,'Sheet3'] 第一个,第二个和名为Sheet3的Sheet页中的数据作为DataFrame对象

header:指定作为列名的行,默认值为0,即取第一行的值为列名。或数据不包含列名,则为header=None

names:默认值为None,要使用的列名列表

index_col:指定列为索引列,默认值为None,索引0是DataFrame对象的行标签

usecols:int、list或字符串,默认值为None

    如为None,则解析所有列

    如为int,则解析最后一列

    如为list列表,则解析列号和列表的列

    如为字符串,则表示以逗号分隔的Excel列字母和列范围列表

squeeze:布尔值,默认为False,如果解析的数据只包含一列,则返回一个Series

dtype:列的数据类型名称为字典,默认值为None

skiprows:省略指定行数的数据,从第一行开始

skipfooter:省略指定行数的数据,从尾部数的行开始

4.导入指定Sheet页的数据

# sheet_name=0表示第一个sheet页的数据,以此类推,如果不指定,则导入第一页

5.指定行索引导入Excel数据

'''

Empty DataFrame

Columns: []

Index: [1, 3, 5]

'''

# 导入第一列数据

'''

Empty DataFrame

Columns: []

Index: [1, 3, 5]

'''


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11366998.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存