Class BaseNEncoder<T>
- Namespace
- AiDotNet.Preprocessing.Encoders
- Assembly
- AiDotNet.dll
Encodes categorical features using base-N representation.
public class BaseNEncoder<T> : TransformerBase<T, Matrix<T>, Matrix<T>>, IDataTransformer<T, Matrix<T>, Matrix<T>>
Type Parameters
TThe numeric type for calculations (e.g., float, double).
- Inheritance
-
BaseNEncoder<T>
- Implements
- Inherited Members
Remarks
BaseNEncoder converts category indices to base-N representation, creating multiple columns with digits in the specified base. This is a generalization of binary encoding (base 2).
For example, with base=3 and 9 categories (0-8): - Category 0 → [0, 0] - Category 4 → [1, 1] (4 = 1*3 + 1) - Category 8 → [2, 2] (8 = 2*3 + 2)
For Beginners: BaseNEncoder is like counting in different number systems: - Base 2 (binary): Uses 0 and 1 → most compact - Base 3 (ternary): Uses 0, 1, 2 → slightly more columns - Higher bases = fewer columns but more possible values per column
Constructors
BaseNEncoder(int, BaseNHandleUnknown, int[]?)
Creates a new instance of BaseNEncoder<T>.
public BaseNEncoder(int base_ = 2, BaseNHandleUnknown handleUnknown = BaseNHandleUnknown.UseZeros, int[]? columnIndices = null)
Parameters
base_intThe base to use for encoding. Defaults to 2 (binary).
handleUnknownBaseNHandleUnknownHow to handle unknown categories. Defaults to UseZeros.
columnIndicesint[]The column indices to encode, or null for all columns.
Properties
Base
Gets the base used for encoding.
public int Base { get; }
Property Value
HandleUnknown
Gets how unknown categories are handled.
public BaseNHandleUnknown HandleUnknown { get; }
Property Value
NOutputFeatures
Gets the number of output features.
public int NOutputFeatures { get; }
Property Value
SupportsInverseTransform
Gets whether this transformer supports inverse transformation.
public override bool SupportsInverseTransform { get; }
Property Value
Methods
FitCore(Matrix<T>)
Fits the encoder by learning categories.
protected override void FitCore(Matrix<T> data)
Parameters
dataMatrix<T>
GetFeatureNamesOut(string[]?)
Gets the output feature names after transformation.
public override string[] GetFeatureNamesOut(string[]? inputFeatureNames = null)
Parameters
inputFeatureNamesstring[]
Returns
- string[]
InverseTransformCore(Matrix<T>)
Inverse transformation is not supported.
protected override Matrix<T> InverseTransformCore(Matrix<T> data)
Parameters
dataMatrix<T>
Returns
- Matrix<T>
TransformCore(Matrix<T>)
Transforms the data using base-N encoding.
protected override Matrix<T> TransformCore(Matrix<T> data)
Parameters
dataMatrix<T>
Returns
- Matrix<T>