eq.m
来自「张量分析工具」· M 代码 · 共 89 行
M
89 行
function z = eq(x,y)%EQ Equal (==) for sptensors.%% A == B compares the elements of A and B for equality. The arguments can% be a pair of sptensors, an sptensor and a tensor, or an sptensor and a% scalar. Regardless, the result is always returned as a sparse tensor.%% See also SPTENSOR.%%MATLAB Tensor Toolbox.%Copyright 2007, Sandia Corporation. % This is the MATLAB Tensor Toolbox by Brett Bader and Tamara Kolda. % http://csmr.ca.sandia.gov/~tgkolda/TensorToolbox.% Copyright (2007) Sandia Corporation. Under the terms of Contract% DE-AC04-94AL85000, there is a non-exclusive license for use of this% work by or on behalf of the U.S. Government. Export of this data may% require a license from the United States Government.% The full license terms can be found in tensor_toolbox/LICENSE.txt% $Id: eq.m,v 1.3 2007/01/10 01:27:31 bwbader Exp $%% Observations for sparse matrix case.% The result of a == 5 is sparse.% The result of a == 0 is sparse.% The result of a == full(a) is sparse.%% Case 1: One argument is a scalarif isscalar(y) if y == 0 z = ~x; else idx = (x.vals == y); z = sptensor(x.subs(idx,:),true,size(x)); end return;end% Call back with the arguments reversed.if isscalar(x) z = eq(y,x); return;end%% Case 2: Both x and y are tensors of some sort% Check that the sizes matchif ~isequal(x.size,y.size) error('Size mismatch');end% Case 2a: Two sparse tensorsif isa(x,'sptensor') && isa(y,'sptensor') % Find where their zeros intersect xzerosubs = setdiff(allsubs(x),x.subs,'rows'); yzerosubs = setdiff(allsubs(y),y.subs,'rows'); zzerosubs = intersect(xzerosubs,yzerosubs,'rows'); % find where their nonzeros intersect [nzsubs,ix,iy] = intersect(x.subs,y.subs,'rows'); znzsubs = nzsubs(x.vals(ix) == y.vals(iy),:); % Build z z = sptensor([zzerosubs;znzsubs],true,x.size); return;end% Case 2b: One dense tensorif isa(y,'tensor') % Find where their zeros intersect yzerosubs = find(y == 0); zzerosubs = yzerosubs(extract(x,yzerosubs) == 0,:); % Find where their nonzeros intersect yvals = y(x.subs); znzsubs = x.subs(yvals == x.vals,:); % Build z z = sptensor([zzerosubs;znzsubs],true,x.size); return; end%% Otherwiseerror('The arguments must be two sptensors or an sptensor and a scalar.');
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?