Run a loop through multiple matrices
6 次查看(过去 30 天)
显示 更早的评论
Hi, I have 15 matrices, say A1, A2 and so on.. I want to remove all the values below 0.10 and above 0.30 from all of these matrices. Then, I want to replace all of those places with NaN. Can someone please help me with this?
This might be basic, but I am very new to matlab or any kind of coding. Thanks! NK
0 个评论
采纳的回答
Kelly Kearney
2014-1-16
编辑:Kelly Kearney
2014-1-16
To do the replacement on a single variable, you just need
x(x < 0.1 | x > 0.3) = NaN;
To apply it to all your variables, there are a few possibilities.
- Type that line 15 times, replacing x with whatever the names of your 15 variables are.
- If the variables are named systematically, as you suggested (i.e. A1, A2, A3), you could try using eval, as Amit suggests. But eval is usually recommended against, because it can cause unexpected outcomes if you're not careful (and it makes for very ugly code).
- My suggestion: just create a function that applies the NaN-replacement to any number of variables.
function varargout = addnans(varargin)
for ii = 1:length(varargin)
varargout{ii} = varargin{ii};
varargout{ii}(varargout{ii} < 0.1 | varargout{ii} > 0.3) = NaN;
end
Then you could call it as
[A1, A2, ...] = addnans(A1, A2, ...)
This will work regardless of the number of variables, or whether the variables follow a systematic naming convention or not. Just make sure your input variables always match your output variables.
更多回答(1 个)
Amit
2014-1-16
Something like this:
for i = 1:5
eval(['A' num2str(i) '(' 'A' num2str(i) '<0.1 | A' num2str(i) '>0.3)' '=' 'NaN'])
end
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Loops and Conditional Statements 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!