0

我是 MATLAB 的初学者。我创建了一个代码,它读取 JPG 类型(相同文件类型)但每个文件大小不同的数据集文件。我做了什么,我随机读取了 10 个文件,并将这些文件的内容放入一个名为“fr”的矩阵(具有单元格数组类型)中(如下所示)。此“fr”包含 10 列,表示已读取 10 个文件。我提取(读取)的文件内容是二进制文件字节(0-255)但是,我提取了每个文件的内容并将它们放入一个名为“out1”的变量中,但问题是如何使用不同的文件访问这些内容每个文件的大小,我已经通过使用函数(cellfun)解决了它,我通过添加零填充了空白单元格。最终,矩阵起作用了,但我现在面临的问题是如何减去这个矩阵'out1' 从读取的整个文件中?我被困在这部分。此错误表示矩阵尺寸必须一致:如最后所述。

这是输出:???错误使用 ==> 减去矩阵尺寸必须一致。

Error in ==> PCATEST2 at 50
B = (out1 - repmat(AMean,[n 1])) / repmat(AStd,[n 1]);

EDU>> whos
  Name                Size              Bytes  Class     Attributes

  AMean               1x10                 80  double              
  AStd                1x10                 80  double              
  ans                 1x1                   8  double              
  f                   1x57                114  char                
  fid                 1x1                   8  double              
  files              50x1               32870  struct              
  fr                  1x10            6715472  cell                
  i                   1x1                   8  double              
  j                   1x1                   8  double              
  m                   1x1                   8  double              
  maxLength           1x1                   8  double              
  n                   1x1                   8  double              
  out1           101077x10            8086160  double              
  ridx               50x1                 400  double              
  st1                 1x10               1460  cell

这是代码:

f ='/Users/nsa/Documents/MATLAB/jpg-data1/';
files = dir(fullfile(f,'*.jpg'));
ridx = randi(numel(files),size(files)); %choose files from f randomly

 for i = 1:10  %randomly pick 10 files
 st1(i) = {files(ridx(i)).name}; 

  for j= i:length(st1)

    fid = fopen(fullfile(f, st1{i}),'rt');

    fr{j} = fread(fullfile(fid));

    fclose(fid); 

 end

end
maxLength=max(cellfun(@(fr)numel(fr),fr));
out1 = cell2mat(cellfun(@(fr)cat(1,fr,zeros(maxLength-length(fr),1)),fr,'UniformOutput',false));

[n m] = size(fr);

AMean = cellfun(@mean,fr);

AStd = cellfun(@std,fr);

B = (out1 - repmat(AMean,[n 1])) / repmat(AStd,[n 1]);


??? Error using ==> minus
Matrix dimensions must agree.

Error in ==> TEST2 at 50
B = (out1 - repmat(AMean,[n 1])) / repmat(AStd,[n 1]);

谁能帮助我并指导我修复和克服这个错误?

4

1 回答 1

1

你应该做:

[n m] = size(out1); 

因为fr只有 1 行而且out1很多。

但是,您甚至可以使用以下命令跳过重新匹配bsxfun()

B = bsxfun(@rdivide, bsxfun(@minus,out1,AMean), AStd);
于 2013-05-16T20:20:54.527 回答