This is a static copy of a profile report

Home

genpath (Calls: 1935, Time: 2.863 s)
Generated 16-Jul-2020 17:08:24 using performance time.
function in file /Applications/MATLAB_R2020a.app/toolbox/matlab/general/genpath.m
Copy to new window for comparing multiple runs

Parents (calling functions)

Function NameFunction TypeCalls
hhsave_VFI_3OCfunction1
genpathfunction1930
hhsave_util_3OCfunction1
OC3function1
optiklfunction1
con_klfunction1
Lines where the most time was spent

Line NumberCodeCallsTotal Time% TimeTime Plot
38
files = dir(d);
19352.339 s81.7%
62
p = [p genpath(fullfile(d,dirn...
19300.266 s9.3%
47
isdir = logical(cat(1,files.is...
19350.098 s3.4%
44
p = [p d pathsep];
19350.051 s1.8%
64
end
58000.033 s1.2%
All other lines  0.075 s2.6%
Totals  2.863 s100% 
Children (called functions)

Function NameFunction TypeCallsTotal Time% TimeTime Plot
fullfilefunction19300.235 s8.2%
pathsepfunction19350.023 s0.8%
genpathfunction19300 s0%
Self time (built-ins, overhead, etc.)  2.606 s91.0%
Totals  2.863 s100% 
Code Analyzer results
Line numberMessage
26Extra comma is unnecessary in IF statement before newline.
62The variable 'p' appears to change size on every loop iteration. Consider preallocating for speed.
Coverage results
Show coverage for parent directory
Total lines in function64
Non-code lines (comments, blank lines)35
Code lines (lines that can run)29
Code lines that did run25
Code lines that did not run4
Coverage (did run/can run)86.21 %
Function listing
time 
Calls 
 line
   1 
function p = genpath(d)
   2 
%GENPATH Generate recursive toolbox path.
   3 
%   P = GENPATH returns a character vector containing a path name 
   4 
%   that includes all the folders and subfolders below MATLABROOT/toolbox, 
   5 
%   including empty subfolders.
   6 
%
   7 
%   P = GENPATH(FOLDERNAME) returns a character vector containing a path 
   8 
%   name that includes FOLDERNAME and all subfolders of FOLDERNAME, 
   9 
%   including empty subfolders.
  10 
%   
  11 
%   NOTE 1: GENPATH will not exactly recreate the original MATLAB path.
  12 
%
  13 
%   NOTE 2: GENPATH only includes subfolders allowed on the MATLAB
  14 
%   path.
  15 
%
  16 
%   See also PATH, ADDPATH, RMPATH, SAVEPATH.
  17 

  18 
%   Copyright 1984-2018 The MathWorks, Inc.
  19 
%------------------------------------------------------------------------------
  20 

  21 
% String Adoption
< 0.001 
   1935 
  22
if nargin > 0 
< 0.001 
   1935 
  23
    d = convertStringsToChars(d); 
< 0.001 
   1935 
  24
end 
  25 

< 0.001 
   1935 
  26
if nargin==0, 
  27 
  p = genpath(fullfile(matlabroot,'toolbox'));
  28 
  if length(p) > 1, p(end) = []; end % Remove trailing pathsep
  29 
  return
< 0.001 
   1935 
  30
end 
  31 

  32 
% initialise variables
< 0.001 
   1935 
  33
classsep = '@';  % qualifier for overloaded class directories 
< 0.001 
   1935 
  34
packagesep = '+';  % qualifier for overloaded package directories 
< 0.001 
   1935 
  35
p = '';           % path to be returned 
  36 

  37 
% Generate path based on given root directory
  2.339 
   1935 
  38
files = dir(d); 
< 0.001 
   1935 
  39
if isempty(files) 
  40 
  return
< 0.001 
   1935 
  41
end 
  42 

  43 
% Add d to the path even if it is empty.
  0.051 
   1935 
  44
p = [p d pathsep]; 
  45 

  46 
% set logical vector for subdirectory entries in d
  0.098 
   1935 
  47
isdir = logical(cat(1,files.isdir)); 
  48 
%
  49 
% Recursively descend through directories which are neither
  50 
% private nor "class" directories.
  51 
%
  0.018 
   1935 
  52
dirs = files(isdir); % select only directory entries from the current listing 
  53 

< 0.001 
   1935 
  54
for i=1:length(dirs) 
  0.016 
   5800 
  55
   dirname = dirs(i).name; 
  0.030 
   5800 
  56
   if    ~strcmp( dirname,'.')          && ... 
   3865 
  57
         ~strcmp( dirname,'..')         && ... 
   1930 
  58
         ~strncmp( dirname,classsep,1) && ... 
   1930 
  59
         ~strncmp( dirname,packagesep,1) && ... 
   1930 
  60
         ~strcmp( dirname,'private')    && ... 
   1930 
  61
         ~strcmp( dirname,'resources') 
  0.266 
   1930 
  62
      p = [p genpath(fullfile(d,dirname))]; % recursive calling of this function. 
< 0.001 
   5800 
  63
   end 
  0.033 
   5800 
  64
end 

Other subfunctions in this file are not included in this listing.