为什么我的逻辑掩码不能正确处理 matlab 中的二维矩阵?

Why is my logical mask not working on a 2D matrix in matlab properly?

X(100,371) 
%% contains 100 datapoints for 371 variables

我只想保留均值+标准deviation:mean-标准差范围内的数据。

我是这样处理的:

mx=mean(X);sx=std(X);      
%%generate mean, std 
%%this generates mx(1,371) and sx(1,371)

mx=double(repmat(mx,100,1));
%%this fills a matrix with the same datapoints, 
%%100 times
sx=double(repmat(sx,100,1));
%% this gives mx(100,371) and sx(100,371)


g=X>mx-sx & X<mx+sx;        
%%this creates a logical mask g(100,371)
%%filled with 1s and 0s 

test(g)=X(g);               
%%this should give me test(100,371), but I get 
%%test(37100), which is wrong as it doesnt maintain 
%%the shape of X

test=reshape(test,100,371)  
%% but when I compare this to the my original matrix
%% X(100,371) I hardly see a difference (datapoints 
%% in test are still outside the range I want.

我做错了什么?

该行有一点语法问题

test(g) = X(g);

当编译器执行 X(g) 时,它 returns Xg 表示 1 的所有元素,并在执行 [=17= 时赋值] 它创建了一个 test 变量,其大小足以被 g 索引,即 1x37100,然后将所有元素分配到正确的位置。长话短说,在作业之前,您可以添加如下内容:

test = zeros(size(X));

此时,您可以使用 bsxfun 获取逻辑索引,而无需执行 repmat

g = bsxfun(@gt,X,mx - sx) & bsxfun(@lt,X,mx + sx)

在 R2016b 或最近有隐式 bsxfun 扩展

g = X > mx - sx & X < mx + sx