Skip to content

Commit

Permalink
Resolves seg faults and removes unnecessary code
Browse files Browse the repository at this point in the history
  • Loading branch information
DrPaulSharp committed Sep 10, 2024
1 parent c926895 commit 6cca217
Show file tree
Hide file tree
Showing 25 changed files with 12 additions and 62 deletions.
52 changes: 5 additions & 47 deletions API/parseClassToStructs.m
Original file line number Diff line number Diff line change
Expand Up @@ -90,34 +90,16 @@
% Each cell is {1 x Inf char}


% First parse the class to a structure variable.
%% First parse the class to a structure variable.
inputStruct = project.toStruct();

%% Start by removing the cell arrays
contrastLayers = inputStruct.contrastLayers;
layerDetails = inputStruct.layerDetails;

% If any of the contrastLayers are empty, replace the empty cells by zero
% thickness layers
for i = 1:length(contrastLayers)
thisLayer = contrastLayers{i};
if isempty(thisLayer)
contrastLayers{i} = 0;
end
end

% Do the same for layerDetails
if isempty(layerDetails)
layerDetails = {0};
end

% Pull out all the cell arrays (except priors) into one array
%% Pull out all the cell arrays (except priors) into one array
problemCells{1} = inputStruct.contrastRepeatSLDs;
problemCells{2} = inputStruct.data;
problemCells{3} = inputStruct.dataLimits;
problemCells{4} = inputStruct.simLimits;
problemCells{5} = contrastLayers;
problemCells{6} = layerDetails;
problemCells{5} = inputStruct.contrastLayers;
problemCells{6} = inputStruct.layerDetails;
problemCells{7} = inputStruct.paramNames;
problemCells{8} = inputStruct.backgroundParamNames;
problemCells{9} = inputStruct.scalefactorNames;
Expand All @@ -137,39 +119,15 @@

% Now deal with domains cell arrays
if isa(project, 'domainsClass') && isa(project.domainContrasts, 'domainContrastsClass')

domainContrastLayers = inputStruct.domainContrastLayers;

% If any of the domainContrastLayers are empty, replace the empty
% cells by zero thickness layers
for i = 1:length(domainContrastLayers)
thisLayer = domainContrastLayers{i};
if isempty(thisLayer)
domainContrastLayers{i} = 0;
end
end

problemCells{18} = inputStruct.domainContrastRepeatSLDs;
problemCells{19} = domainContrastLayers;
problemCells{19} = inputStruct.domainContrastLayers;
end

if isa(project, 'domainsClass')
problemCells{20} = inputStruct.domainRatioNames;
end

% Fix for cell array bug with custom layers - is this needed still??
if strcmpi(inputStruct.modelType,'custom layers') || strcmpi(inputStruct.modelType,'custom xy')
for i = 1:length(problemCells{5})
problemCells{5}{i} = 0;
end
for i = 1:length(problemCells{19})
problemCells{19}{i} = 0;
end

problemCells{6} = {0};

end

% Also the custom files array..
if isempty(problemCells{14})
problemCells{14} = {''};
Expand Down
2 changes: 1 addition & 1 deletion API/projectClass/contrastsClass.m
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@
contrastLayers{i} = thisArray;
contrastCustomFile(i) = NaN;
otherwise
contrastLayers{i} = {};
contrastLayers{i} = [];
whichFile = thisContrast.model;
thisContrastFileNum = find(strcmpi(whichFile, allowedNames.customFileNames));
contrastCustomFile(i) = thisContrastFileNum;
Expand Down
10 changes: 2 additions & 8 deletions targetFunctions/common/groupLayers/allocateLayersForContrast.m
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
function thisContrastLayers = allocateLayersForContrast(contrastLayers,outParameterisedLayers,useImaginary)
function thisContrastLayers = allocateLayersForContrast(contrastLayers,outParameterisedLayers,useImaginary)
% Decide which layers are needed for a particular contrast.
% This function takes the master array of all layers
% and extracts which parameters are required for
Expand All @@ -8,20 +8,14 @@
% outParameterisedLayers - List of all the available layers
% thisContrastLayers - Array detailing which layers are required for this contrast

coder.varsize('thisContrastLayers',[1000 6],[1 1]);

if useImaginary
thisContrastLayers = zeros(length(contrastLayers),6);
else
thisContrastLayers = zeros(length(contrastLayers),5);
end

for i = 1:length(contrastLayers)
if (contrastLayers(i) ~= 0)
thisContrastLayers(i,:) = outParameterisedLayers{contrastLayers(i)};
else
thisContrastLayers(i,:) = [];
end
thisContrastLayers(i,:) = outParameterisedLayers{contrastLayers(i)};
end

end
8 changes: 3 additions & 5 deletions targetFunctions/common/resampleLayers/SLDFunction.m
Original file line number Diff line number Diff line change
Expand Up @@ -26,11 +26,9 @@
if ~isempty(where)
sldVal = rho(where);
else
belowVals = find(x > z);
aboveVals = find(x < z);
below = belowVals(end);
above = aboveVals(1);

below = find(x > z, 1, 'last');
above = find(x < z, 1);

belowY = rho(below);
aboveY = rho(above);

Expand Down
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file modified tests/domainsTFReflectivityCalculation/domainsCustomXYInputs.mat
Binary file not shown.
Binary file modified tests/domainsTFReflectivityCalculation/domainsCustomXYOutputs.mat
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file modified tests/nonPolarisedTFReflectivityCalculation/customLayersInputs.mat
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file modified tests/nonPolarisedTFReflectivityCalculation/customXYInputs.mat
Binary file not shown.
Binary file modified tests/nonPolarisedTFReflectivityCalculation/customXYOutputs.mat
Binary file not shown.
Binary file modified tests/nonPolarisedTFReflectivityCalculation/customXYTFParams.mat
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
2 changes: 1 addition & 1 deletion tests/testContrastsClass.m
Original file line number Diff line number Diff line change
Expand Up @@ -499,7 +499,7 @@ function testToStructCustomLayers(testCase)
for i=1:testCase.numContrasts
testCase.exampleClass.contrasts{i}.model = {'DSPC Model'};
end
testCase.exampleStruct.contrastLayers = {{} {} {}};
testCase.exampleStruct.contrastLayers = {[] [] []};
testCase.exampleStruct.contrastCustomFile = [1 1 1];

testCase.verifyEqual(testCase.exampleClass.toStruct(testCase.allowedNames, 'custom layers', testCase.varTable), testCase.exampleStruct);
Expand Down
Binary file modified tests/testProjectConversion/DSPCBilayerProjectClass.mat
Binary file not shown.
Binary file modified tests/testProjectConversion/monolayerVolumeModelProjectClass.mat
Binary file not shown.

0 comments on commit 6cca217

Please sign in to comment.