How to find a unique indicator of a specific matrix?
2 views (last 30 days)
Show older comments
Can we find a unique indicator of a specific matrix?
for example, if there is the following matrix (generated by a specific case) , how can I find one indicator of it?
I tried to take the sumation of the absolute values of the Matrix, but it didnt work because it was similer or too close for other cases
M1 and M2 is the range that can the matrix M varies between them, they are generated from a one case but with a little variation in some parameters (I want to find indicator for each other and compare it with other cases)
in this case the indicator should be too close for these two matrices (they are generated from the same case)
M1 = [-0.321306015516281 -0.274347013364667 -0.244382392248534 -0.288238228952784;
0.0558620817276004 0.372558615192237 0.572777978587165 0.503058540034827;
0.879663610530521 -0.136530080441011 -0.146669343761813 -0.155051653631985;
-0.176098379345313 0.737213426291489 -0.317456953062300 -0.314726433029229;
-0.211259054671114 -0.342511568755319 0.574666860881602 -0.415568275258076;
-0.210220781888802 -0.326336514970413 -0.399587060803839 0.606679564783506]
M2 = [-0.329410894346382 -0.282164376523392 -0.250593904107229 -0.300770395163912;
0.0391745398039566 0.367487954611743 0.578801050109399 0.490318907952166;
0.880000126456464 -0.133241897165618 -0.141354513303187 -0.151019721814831;
-0.173510462331790 0.738010210780251 -0.318373231341420 -0.312738411276027;
-0.207557875879909 -0.344447577135199 0.568108475231932 -0.416369292422166;
-0.205833532679448 -0.322922994018591 -0.397620657310764 0.612493983612021]
4 Comments
Answers (2)
Walter Roberson
on 8 Feb 2023
https://www.mathworks.com/matlabcentral/fileexchange/31272-datahash but see https://stackoverflow.com/questions/48667340/matlab-fast-hash-of-a-matrix for faster Java based code.
3 Comments
Walter Roberson
on 8 Feb 2023
No. All cases involving summarizing multiple values as a single value are mathematically classed as "hashing". Some hashing methods are better for particular purposes than other methods are, but all deterministic functions are classified as hash functions.
dpb
on 8 Feb 2023
Moved: dpb
on 8 Feb 2023
M1 = [-0.321306015516281 -0.274347013364667 -0.244382392248534 -0.288238228952784;
0.0558620817276004 0.372558615192237 0.572777978587165 0.503058540034827;
0.879663610530521 -0.136530080441011 -0.146669343761813 -0.155051653631985;
-0.176098379345313 0.737213426291489 -0.317456953062300 -0.314726433029229;
-0.211259054671114 -0.342511568755319 0.574666860881602 -0.415568275258076;
-0.210220781888802 -0.326336514970413 -0.399587060803839 0.606679564783506];
M2 = [-0.329410894346382 -0.282164376523392 -0.250593904107229 -0.300770395163912;
0.0391745398039566 0.367487954611743 0.578801050109399 0.490318907952166;
0.880000126456464 -0.133241897165618 -0.141354513303187 -0.151019721814831;
-0.173510462331790 0.738010210780251 -0.318373231341420 -0.312738411276027;
-0.207557875879909 -0.344447577135199 0.568108475231932 -0.416369292422166;
-0.205833532679448 -0.322922994018591 -0.397620657310764 0.612493983612021];
100*(M2-M1)./M1 % percentage difference
tol0=1E-4; % set initial tolerance tightly...
N=numel(M1); % check for when all are outside tol
i=1;
t{i,1}=tol0;
n{i,1}=sum(ismembertol(M1,M2,t{i}),'all');
while n{i}<N
i=i+1;
t{i}=2*t{i-1};
n{i}=sum(ismembertol(M1,M2,t{i}),'all');
if i>10, break, end
end
semilogx(cell2mat(t),cell2mat(n),'x-','linewidth',1.5)
grid
You can 'spearmint with alternatives on max points or all or whatever suits....
We have no basis for any idea of what is/is not important here from which to judge.
7 Comments
dpb
on 8 Feb 2023
Yeah, @Walter Roberson; I don't know why I tend to forget about nnz -- just 30-yr old habits die slowly, I guess, mostly. It's the better idiom; I should remember using it.
Walter Roberson
on 8 Feb 2023
A = [1 2 3]
B = [18 42 17 3 14 11 (1+eps)]
[found, idx] = ismembertol(A,B)
You can see from this that ismembertol() does not operate element-wise. Each member of the first matrix is compared to each element of the second matrix.
If you want to compare element-by-element then if all of the elements are in the same range, then
num_matches = nnz(abs(A-B) <= tolerance)
ismembertol() is for the case where each element of A is to be compared to all elements of B
When you do not pass a tolerance factor into ismembertol() then it uses 1e-12 (double) or 1e-6 (single) . If you use the datascale option you can specify a tolerance per column when ByRows option is used.
See Also
Categories
Find more on Data Preprocessing in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!