Radiate 1.4.3
See the version list below for details.
dotnet add package Radiate --version 1.4.3
NuGet\Install-Package Radiate -Version 1.4.3
<PackageReference Include="Radiate" Version="1.4.3" />
paket add Radiate --version 1.4.3
#r "nuget: Radiate, 1.4.3"
// Install Radiate as a Cake Addin #addin nuget:?package=Radiate&version=1.4.3 // Install Radiate as a Cake Tool #tool nuget:?package=Radiate&version=1.4.3
.NET port of Rust crate radiate.
Algorithms
- Random Forest
- Support Vector Machine
- MultiLayer Perceptron
- Dense Layer
- Dropout Layer
- Flatten Layer
- LSTM Layer
- RNN Layer
- Convolutional Layer
- MaxPooling Layer
- KMeans Clustering
- KNearestNeighbors
- Evolution Engine
- Evolve any object which implements the IGenome interface.
- Implementation of NEAT for evolving NeuralNetworks is included.
- Implementation of evolutionarily generated RandomForest/DecisionTree.
- Evolve any object which implements the IGenome interface.
Callbacks
Similar to Keras Callbacks. Hook into the training loop with custom code. Create an object that implements any or all of the following:
- IEpochStartedCallback
- IBatchCompletedCallback
- IEpochCompletedCallback
- ITrainingCompletedCallback
- IGenerationEvolvedCallback
- IEarlyStopCallback
- ILossCalculatedCallback
- ITrainingFailedCallback
- ITrainingStartedCallback
See this for example callbacks or this for a VerboseTrainingCallback
to print training progress to the Console.
Feature Engineering
Functional feature engineering with TensorDataSet
. Transform input data (featurs, targets) with specific options below.
- Batch - Set a batch size to train on.
- Layer - Layer data by n rows.
- Split - Split the data into a training set and testing set. Default is 75% split training, 25% testing.
- Reshape - Reshape the row vector to a shape of (height, width, depth), useful for images.
- Pad - Pad an image Tensor with n zeros.
- Shuffle - Shuffle the rows of the dataset randomly.
- Kernel - Add kernel transform for the features, possible options are RBF, Polynomial, and Linear (None).
- TransformFeatures - Transform the feature data. Options are Normalize, Standardize, OHE (One Hot Encode), and Image (divide data point by 255).
- TransformTargets - Transform the target data. Options same as above.
Model saving and loading
The Optimizer
is not Json serializable, but the OptimizerWrap
is, so the Optimizer
must be converted to a concrete object before serializing.
OptimizerWrap
contains three items:
- TensorDataSet options, the options used to transform the input features/targets. During predicion the Optimizer uses these options to transform the input vector so it matches the trained features in order to get accurate predictions.
- LossFunction, the loss function used during training. If you save a model mid training, the loss function is needed when loading back in the model to continue training.
- ModelWrap, the machine learning model being trained/used for prediction.
// Create an Optimizer
var forest = new RandomForest(numTrees, new ForestInfo(minSampleSplit, maxDepth));
var optimizer = new Optimizer(forest, tensorDataSet);
// Generate a json serializable object.
var wrappedModel = optimizer.Save();
// The same model can be loaded back in for prediction/additional training.
var newOptimizer = new Optimizer(wrappedModel);
The Optimizer
can also be converted to a json string or a memory stream like so:
var optimizer = new Optimizer(forest, TensorDataSet);
var jsonString = ModelWriter.ToJson(optimizer);
var stream = ModelWriter.ToStream(optimizer);
// Loading in an Opimizer from the above options
var optimizer = ModelReader.FromJson(jsonString);
var optimizer = ModelReader.FromStream(stream);
Make predictions
Because the Optimizer
has TensorDataSet
, it can transform a given float[]
to acceptable input to the model even after saving/loading a model. This makes making predictions as easy as
var vectorToPredict = new float[] { 1f, 2f, 3f, 4f, 5f };
var prediction = trainedOptimizer.Predict(vectorToPredict);
// Prediction(Tensor Result, int Classification = 0, float Confidence = 0f);
The prediction created returns a Prediction
record which holds:
- Result, the Model's predicted output vector
- Classification value.
- Confidence value which can be used as the regression value.
Random
All random numbers are generated by calling RandomGenerator.Next
. This allows for random seeds to be set for model building.
RandomGenerator.Seed = 3;
Will set a random seed for the Optimizer
.
Execution Strategies
Choose to execute model training & predicting synchronously or asyncronously. This is extremely helpful in models with large weight Tensors
or large training dataset. However,
choosing to execute asynchronously in certain situations can result in a slower training time than synchronous execution. It is best to experiment with this and choose
the best option for your problem. The default option for every model is ExecutionStrategy.Sync
.
// MultiLayerPerceptron
var lstm = new MultiLayerPerceptron(new GradientInfo(Gradient.Adam, 1e-4f), ExecutionStrategy.Async)
.Add(new LSTMInfo(128)) // Because no ExecutionStrategy is defined, the layer inherits the MultiLayerPerceptron's ExecutionStrategy
.Add(new DenseInfo(1, Activation.Linear)
.WithExecutionStrategy(ExecutionStrategy.Sync)); // override the network's ExecutionStrategy in favor of executing just this layer synchronously
// RandomForest
var randomForest = new RandomForest(new ForestInfo(25, 2, 10), ExecutionStrategy.Async);
// SupportVectorMachine
var svm = new SupportVectorMachine(new SVMInfo(new Shape(28), 10, 1e-3f), ExecutionStrategy.Async);
// KNearestNeighbors
var knn = new KNN(new KNNInfo(3, ExecutionStrategy.Sync, DistanceMetric.Euclidean));
// Population - The Population takes PopulationSettings as an argument, so ExecutionStrategy is available for any IGenome implementation.
var info = new PopulationInfo<Neat, NeatEnvironment>()
.AddSettings(settings => settings.ExecutionStrategy = ExecutionStrategy.Async);
var population = new Population<Neat, NeatEnvironment>(info);
Examples
Datasets coming from Radiate.Data which provides easily accessable common machine learning datasets.
Convolutional Neural Network on MNist handwritten digets dataset
<img src="https://camo.githubusercontent.com/01c057a753e92a9bc70b8c45d62b295431851c09cffadf53106fc0aea7e2843f/687474703a2f2f692e7974696d672e636f6d2f76692f3051493378675875422d512f687164656661756c742e6a7067" width="300px">
const int FeatureLimit = 5000;
const int BatchSize = 128;
const int MaxEpochs = 10;
var (rawInputs, rawLabels) = await new Mnist(FeatureLimit).GetDataSet();
var data = new TensorDataSet(rawInputs, rawLabels)
.Reshape(new Shape(28, 28, 1))
.Transform(Norm.Image, Norm.OHE)
.Batch(BatchSize)
.Split();
var neuralNet = new MultilayerPerceptron(ExecutionStrategy.Async)
.Layer(new ConvInfo(32, 3))
.Layer(new MaxPoolInfo(2))
.Layer(new FlattenInfo())
.Layer(new DenseInfo(64, Activation.Sigmoid))
.Layer(new DenseInfo(data.OutputCategories, Activation.SoftMax));
var epoch = neuralNet.Fit(data).ToEpoch(MaxEpochs);
Console.WriteLine($"{epoch.ToValidation()}");
Random Forest on Iris Flowers dataset
<img src="https://upload.wikimedia.org/wikipedia/commons/5/56/Iris_dataset_scatterplot.svg" width="300px">
const int NumTrees = 10;
const int MaxDepth = 10;
const int MinSampleSplit = 2;
var (rawFeatures, rawLabels) = dataSet;
var pair = new TensorDataSet(rawFeatures, rawLabels).Shuffle().Split();
var validation = new RandomForest(NumTrees, MinSampleSplit, MaxDepth).Fit(pair).ToValidation();
Console.WriteLine($"{validation}");
More
See the examples for how to use the API.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net7.0
- No dependencies.
NuGet packages (5)
Showing the top 5 NuGet packages that depend on Radiate:
Package | Downloads |
---|---|
Radiate.Extensions
Package Description |
|
Radiate.Data
Package Description |
|
Souk
Package Description |
|
Souk.Radiate
Package Description |
|
Radiate.Genetics
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.6.4 | 128 | 7/8/2024 |
1.6.3 | 106 | 6/6/2024 |
1.6.2 | 95 | 5/8/2024 |
1.6.1 | 115 | 4/27/2024 |
1.6.0 | 130 | 4/27/2024 |
1.5.9 | 126 | 4/27/2024 |
1.5.8 | 120 | 4/27/2024 |
1.5.7 | 124 | 4/22/2024 |
1.5.6 | 132 | 4/21/2024 |
1.5.5 | 136 | 4/11/2024 |
1.5.4 | 114 | 3/24/2024 |
1.5.3 | 160 | 2/27/2024 |
1.5.2 | 131 | 2/26/2024 |
1.5.1 | 139 | 2/26/2024 |
1.5.0 | 141 | 1/31/2024 |
1.4.9 | 131 | 1/25/2024 |
1.4.8 | 109 | 1/24/2024 |
1.4.7 | 101 | 1/24/2024 |
1.4.6 | 161 | 1/23/2024 |
1.4.5 | 209 | 12/17/2023 |
1.4.4 | 203 | 8/10/2023 |
1.4.3 | 193 | 8/6/2023 |
1.4.2 | 190 | 6/5/2023 |
1.4.1 | 254 | 3/14/2023 |
1.4.0 | 251 | 3/8/2023 |
1.3.9 | 265 | 3/2/2023 |
1.3.8 | 275 | 3/1/2023 |
1.3.7 | 278 | 2/27/2023 |
1.3.6 | 270 | 2/15/2023 |
1.3.5 | 342 | 11/29/2022 |
1.3.4 | 325 | 11/29/2022 |
1.3.3 | 426 | 11/28/2022 |
1.3.2 | 331 | 11/28/2022 |
1.3.1 | 345 | 11/28/2022 |
1.3.0 | 325 | 11/27/2022 |
1.2.9 | 349 | 11/27/2022 |
1.2.8 | 496 | 11/26/2022 |
1.2.7 | 342 | 11/26/2022 |
1.2.6 | 442 | 7/25/2022 |
1.2.5 | 436 | 7/25/2022 |
1.2.4 | 443 | 7/25/2022 |
1.2.3 | 440 | 7/25/2022 |
1.2.2 | 433 | 7/25/2022 |
1.2.1 | 453 | 6/22/2022 |
1.2.0 | 422 | 6/21/2022 |
1.1.9 | 460 | 6/21/2022 |
1.1.8 | 477 | 6/21/2022 |
1.1.7 | 447 | 6/20/2022 |
1.1.6 | 490 | 4/14/2022 |
1.1.5 | 452 | 4/14/2022 |
1.1.4 | 455 | 4/14/2022 |
1.1.3 | 456 | 4/14/2022 |
1.1.2 | 425 | 4/14/2022 |
1.1.1 | 454 | 4/14/2022 |
1.1.0 | 462 | 4/14/2022 |
1.0.9 | 478 | 2/14/2022 |
1.0.8 | 458 | 2/14/2022 |
1.0.7 | 449 | 2/14/2022 |
1.0.6 | 477 | 1/20/2022 |
1.0.5 | 314 | 1/15/2022 |
1.0.4 | 301 | 1/15/2022 |
1.0.3 | 520 | 1/12/2022 |
1.0.2 | 487 | 1/12/2022 |
1.0.1 | 360 | 1/12/2022 |
1.0.0 | 455 | 1/12/2022 |