++ed by:
Kevin Ryde
and 1 contributors

# SYNOPSIS

`````` use Math::NumSeq::RadixConversion;
my (\$i, \$value) = \$seq->next;``````

# DESCRIPTION

This sequence is the index i converted from one radix to another. The default is from binary to decimal,

``````    starting i=0
0, 1, 10, 11, 100, 101, 110, 111, 1000, 1001, 1010, 1011, ...``````

For example i=3 in binary is 0b11 which is interpreted as decimal for value 11, ie. eleven.

When `from_radix < to_radix` the effect is to give values which in `to_radix` use only the digits of `from_radix`. The default is all integers which in decimal use only the binary digits, ie. 0 and 1.

When `from_radix > to_radix` the conversion is a reduction. The calculation is still a breakdown and re-assembly

``````    i = d[k]*from_radix^k + ... + d[1]*from_radix + d[0]

but because `to_radix` is smaller the value is smaller than the index i. For example from_radix=10 and to_radix=8 turns i=345 into value=3*8^2+4*8+5=229.

# FUNCTIONS

See "FUNCTIONS" in Math::NumSeq for behaviour common to all sequence classes.

`\$seq = Math::NumSeq::RadixConversion->new ()`
`\$seq = Math::NumSeq::RadixConversion->new (from_radix => \$r, to_radix => \$t)`

Create and return a new sequence object.

## Random Access

`\$value = \$seq->ith(\$i)`

Return `\$i` as digits of base `radix` encoded in `to_radix`.

`\$bool = \$seq->pred(\$value)`

Return true if `\$value` occurs in the sequence.

If `to_radix <= from_radix` then all integer `\$value` occurs. If `to_radix > from_radix` then `\$value` written in `to_radix` must use only digits 0 to `from_radix - 1` inclusive.