These methods should work as expected, although the off-by-one issue
might be a gotcha.
For the extract method, H[L], a hyper2 object is
returned. The replace method, H[L] <- value, the index
specifies the brackets whose powers are to be overwritten; standard
disordR protocol is used.
If the index argument is missing, viz H1[] <- H2, this is a
special case. Argument H1 must be a hyper2 object, and
the idiom effectively executes H1[brackets(H2)] <- powers(H2),
but more efficiently (note that this operation is well-defined even
though the order of the brackets is arbitrary). This special case is
included in the package because it has a very natural C++
expression [function overwrite() in the src/ directory]
that was too neat to omit.
Altering (incrementing or decrementing) the power of a single bracket
is possible using idiom like H[x] <- H[x] + 1; this is
documented at Ops.hyper2, specifically
hyper2_sum_numeric() and a discussion is given at
increment.Rd.
Functions assign_lowlevel() and overwrite_lowlevel() are
low-level helper functions and not really intended for the end-user.