Is there an efficient way to calculate hash for objects
26 次查看(过去 30 天)
显示 更早的评论
Hey,
I have objects ("Sequence") on which I need to do some heavy calculations, the result is another object of the same kind (a different, fixed, "Sequence").
These calculations are often repeated, so I want to save the results in a Map, such that they will only be done once (for each Sequence).
The problem: The keys for the map have to be numbers or strings...
Is there any Efficient way to calculate some sort of unique Hash for an object?
If it matters, "Sequence" contains only a single property: a cell array of "Pulse" (another object). "Pulse" has several primitive properties and a struct.
Small clarification, I need the hash to be the same for different handles if internal structs are the same (same as isequal, and not as ==).
For example:
a = Sequence() % Default constructor
b = Sequence() % Default constructor
Hash(a) == Hash(b) % Should be true
Of course, I can calculate some sort of hash myself, but I wonder if there is some other way which might be more efficient...
0 个评论
采纳的回答
Ameer Hamza
2020-4-27
Have a look at the memorized function: https://www.mathworks.com/help/matlab/ref/memoizedfunction.html. This might be helpful. The submission by Jan, you linked in your question, will also work for objects, not just structs. You may also want to have a look at jsonencode(): https://www.mathworks.com/help/matlab/ref/jsonencode.html
7 个评论
Alan Frankel
2024-6-20
Folks: please note the difference between the words "memorized" and "memoized" (no "r"). The name of the function is "MemoizedFunction".
更多回答(0 个)
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!