Find function misbehaves when Indexing into array
古いコメントを表示
I have a function which searches an array for the first value which is below a given tolerance. First, it creates a logic array using the input and a "less than" condition. Then it finds the index of the first instance of "True" in the LogicArray using the find function. If no "True" value could be found, it sets the index to be the last value in the array (in this case, 125). Then it uses the found index value to return a corresponding array value.
function [FindIndex, RxComplete] = IndexCheck(x,y)
Tolerance = 100;
LogicArray = x < Tolerance;
FindIndex = find(LogicArray,1,'first');
if isempty(FindIndex)
FindIndex = 125;
end
RxComplete = y(FindIndex,1);
end
The function is then applied to a cell array using cellfun.
[Index_output, Array_output] = cellfun(@IndexCheck, x, y, 'UniformOutput',false);
The code works for the above application, but it mesbehaves when I try to only search certain elements of my input array. For example, I want the function to skip the first 5 elements of the array so I index into LogicArray with (5:end). This should tell the find function to only start searching for a "True" after the first 5 elements.
function [FindIndex, RxComplete] = IndexCheck(x,y)
Tolerance = 100;
LogicArray = x < Tolerance;
FindIndex = find(LogicArray(5:end),1,'first');
if isempty(FindIndex)
FindIndex = 125;
end
RxComplete = y(FindIndex,1);
end
But when I include this indexing condition for FindIndex, the function no long works and returns index and array values that do not satisfy the Tolerance condition. (i.e index values which correspond to an array value that is greater than 100).
I can trim the data to remove the first five elements, but this feels like a bandaid solution which doesn't address the issue. I'm hoping someone can help me understand why this is happening.
採用された回答
その他の回答 (1 件)
%{
if isempty(FindIndex)
FindIndex = 125;
end
%}
Rather than assuming that your x array (and your y array) has exactly 125 rows (which if you pass in only a subset of your data may not be a valid assumption) I would compute this value using either the size function or (since you want the index of the last row) the height function. [For columns the corresponding function is width or you can still use size.]
x = ones(3, 4)
size(x, 1)
height(x)
size(x, 2)
width(x)
カテゴリ
ヘルプ センター および File Exchange で Matrix Indexing についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!