This prepares general sparse to sparse conversions. The code that
needs to be generated using this new feature is now simply:
(1) coo = sparse_tensor_1->asCOO(); source format1
(2) sparse_tensor_2 = newSparseTensor(coo); destination format2
By using COO as an intermediate, we can do *all* conversions without
having to implement the full O(N^2) conversion matrix. Note that we
can always improve particular conversions individually if a faster
solution is required.
It could be nice if we can have a more specially names or/and documentation to help understanding of the two usages of "tmp".
the first tmp: Apply the reversed permutation to the storage sizes to get the sizes of the tensor.
the second tmp: Apply the reversed permutation to the permutation of the coo tensor to get the accumulated permutation from the tensor to the coo tensor.