这里我有两个矩阵,一个表示成本,另一个决定何时进行比较。
cost = [0.2 0.0 0.3; 0.4 0 0; 0.5 0 0];
available = [1 1 0 ; 1 0 0; 0 0 0];
available = logical(available);
我想获取成本矩阵中最小可用元素的索引,在这种情况下将比较0.2
,0.0
并0.4
返回 的索引0.0
,即成本矩阵中的(1, 2)
或4
。
我试过
mul = cost .* available; % Zero if not available, but I can't know if it is zero because cost is zero
mul(~mul) = nan; % Set zero to be NaN
[minVal, minId] = min(mul)
这将有助于获得最小的非零成本,但如果存在可用的零元素,那将是错误的。
那么有没有更好的方法呢?