<email@example.com> wrote in message <firstname.lastname@example.org>... > class (handle (0)) == 'root'; > class (libpointer) == 'lib.pointer'; > class ([ libpointer, (handle (0)) ]) == 'handle'; > % Why? The documentation says: MATLAB does not convert objects to a common > superclass unless those objects derive from a member of a heterogeneous > hierarchy. > % This is not the case: > isa (libpointer, 'math.mixin.Heterogeneous') == 0; > % So what is going on here? Moreover: > numel (superclasses (libpointer)) == 0; > numel (superclasses (handle (0))) == 0; > % So if they were heterogeneous, the superclass would be hidden. I am not > sure how to test for that.
handle is a multifaceted and unique term for The MathWorks. There are both UDD and MCOS handle classes. There is a UDD handle package. In terms of the tools we need, handle() is also an undocumented function which converts a numeric handle into a UDD handle object. Depending on your background you may want to think of handle as a cast operator which casts a numeric handle into a UDD object.
By using handle(), you can thus concatenate objects of different types. This can be very useful, as you have seen.
Matlab always shows the array as having the common type. If the concatenated objects are all alike, then their specific common type is displayed; otherwise, the common type is simply the base UDD handle class, which is basically the superclass you were looking for.
The mechanism you're using may be undocumented, but has worked consistently for the past decade or so, and I suspect (although I can't be certain) it will continue to work in the near future.
Note that a fully documented alternative is to use a cell-array, or a struct: