Semantic Learning algorithm based on Inflate and deflate Mutation (SLIM GSGP)
Project description
SLIM (Semantic Learning algorithm based on Inflate and deflate Mutation)
slim_gsgp is a Python library that implements the SLIM algorithm, which is a variant of the Geometric Semantic Genetic Programming (GSGP). This library includes functions for running standard Genetic Programming (GP), GSGP, and all developed versions of the SLIM algorithm. Users can specify the version of SLIM they wish to use and obtain results accordingly. Slim's documentation can be accessed in Slim Documentation.
Installation
To install the library, use the following command:
pip install slim_gsgp
Usage
Running GP
To use the GP algorithm, you can use the following example:
from slim_gsgp.main_gp import gp # import the slim_gsgp library
from slim_gsgp.datasets.data_loader import load_ppb # import the loader for the dataset PPB
from slim_gsgp.evaluators.fitness_functions import rmse # import the rmse fitness metric
from slim_gsgp.utils.utils import train_test_split # import the train-test split function
# Load the PPB dataset
X, y = load_ppb(X_y=True)
# Split into train and test sets
X_train, X_test, y_train, y_test = train_test_split(X, y, p_test=0.4)
# Split the test set into validation and test sets
X_val, X_test, y_val, y_test = train_test_split(X_test, y_test, p_test=0.5)
# Apply the GP algorithm
final_tree = gp(X_train=X_train, y_train=y_train,
X_test=X_val, y_test=y_val,
dataset_name='ppb', pop_size=100, n_iter=100)
# Show the best individual structure at the last generation
final_tree.print_tree_representation()
# Get the prediction of the best individual on the test set
predictions = final_tree.predict(X_test)
# Compute and print the RMSE on the test set
print(float(rmse(y_true=y_test, y_pred=predictions)))
Running standard GSGP
To use the GSGP algorithm, you can use the following example:
from slim_gsgp.main_gsgp import gsgp # import the slim_gsgp library
from slim_gsgp.datasets.data_loader import load_ppb # import the loader for the dataset PPB
from slim_gsgp.evaluators.fitness_functions import rmse # import the rmse fitness metric
from slim_gsgp.utils.utils import train_test_split # import the train-test split function
# Load the PPB dataset
X, y = load_ppb(X_y=True)
# Split into train and test sets
X_train, X_test, y_train, y_test = train_test_split(X, y, p_test=0.4)
# Split the test set into validation and test sets
X_val, X_test, y_val, y_test = train_test_split(X_test, y_test, p_test=0.5)
# Apply the Standard GSGP algorithm
final_tree = gsgp(X_train=X_train, y_train=y_train,
X_test=X_val, y_test=y_val,
dataset_name='ppb', pop_size=100, n_iter=100,
reconstruct=True, ms_lower=0, ms_upper=1)
# Get the prediction of the best individual on the test set
predictions = final_tree.predict(X_test)
# Compute and print the RMSE on the test set
print(float(rmse(y_true=y_test, y_pred=predictions)))
Running SLIM
To use the SLIM GSGP algorithm, you can use the following example:
from slim_gsgp.main_slim import slim # import the slim_gsgp library
from slim_gsgp.datasets.data_loader import load_ppb # import the loader for the dataset PPB
from slim_gsgp.evaluators.fitness_functions import rmse # import the rmse fitness metric
from slim_gsgp.utils.utils import train_test_split # import the train-test split function
from slim_gsgp.utils.utils import generate_random_uniform # import the mutation step function
# Load the PPB dataset
X, y = load_ppb(X_y=True)
# Split into train and test sets
X_train, X_test, y_train, y_test = train_test_split(X, y, p_test=0.4)
# Split the test set into validation and test sets
X_val, X_test, y_val, y_test = train_test_split(X_test, y_test, p_test=0.5)
# Apply the SLIM GSGP algorithm
final_tree = slim(X_train=X_train, y_train=y_train,
X_test=X_val, y_test=y_val,
dataset_name='ppb', slim_version='SLIM+SIG2', pop_size=100, n_iter=100,
ms_lower=0, ms_upper=1, p_inflate=0.5)
# Show the best individual structure at the last generation
final_tree.get_tree_representation()
# Get the prediction of the best individual on the test set
predictions = final_tree.predict(X_test, slim_version='SLIM+SIG2')
# Compute and print the RMSE on the test set
print(float(rmse(y_true=y_test, y_pred=predictions)))
Arguments for the gp, gsgp and slim function
Common arguments
X_train
: A torch tensor with the training input data (default: None).y_train
: A torch tensor with the training output data (default: None).X_test
: A torch tensor with the testing input data (default: None).y_test
: A torch tensor with the testing output data (default: None).dataset_name
: A string specifying how the results will be logged (default: None).pop_size
: An integer specifying the population size (default: 100).n_iter
: An integer specifying the number of iterations (default: 1000).elitism
: A boolean specifying the presence of elitism (default: True).n_elites
: An integer specifying the number of elites (default: 1).init_depth
: An integer specifying the initial depth of the GP tree- default: 6 for gp and slim
- default: 8 for gsgp
log_path
: A string specifying where the results are going to be saved- default:
os.path.join(os.getcwd(), "log", "gp.csv")
for slim - default:
os.path.join(os.getcwd(), "log", "gsgp.csv")
for slim - default:
os.path.join(os.getcwd(), "log", "slim.csv")
for slim
- default:
seed
: An integer specifying the seed for randomness (default: 1).
Specific for gp
p_xo
: A float specifying the crossover probability (default: 0.8).max_depth
: An integer specifying the maximum depth of the GP tree (default: 17).
Specific for gsgp
p_xo
: A float specifying the crossover probability (default: 0.0).-
ms
: A callable function to generate the mutation step (default: generate_random_uniform(0, 1)).
Specific for slim
slim_version
: A string specifying the version of SLIM-GSGP to run (default: "SLIM+SIG2").ms
: A callable function to generate the mutation step (default: generate_random_uniform(0, 1)).p_inflate
: A float specifying the probability to apply the inflate mutation (default: 0.5).
Additional Notes
If a user wishes to use their own dataset rather than one of the sixteen benchmarking datasets included with the slim
library, they can load their data into a Pandas DataFrame, ensuring that the target variable is the last column. They can then call the load_pandas_df
function from datasets.data_loader
as follows:
from slim_gsgp.datasets.data_loader import load_pandas_df # import the loader for the dataset PPB
import pandas as pd
# Reading the desired dataset
df = pd.read_csv("path/your_data.csv")
# Turning df into X and y torch.Tensors
X, y = load_pandas_df(df, X_y=True)
# Split into train and test sets
X_train, X_test, y_train, y_test = train_test_split(X, y, p_test=0.4)
# Split the test set into validation and test sets
X_val, X_test, y_val, y_test = t
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file slim_gsgp-0.1.4.tar.gz
.
File metadata
- Download URL: slim_gsgp-0.1.4.tar.gz
- Upload date:
- Size: 56.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.15
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4eb934457dc40a0b6391cb426c708bea8dc6ede4509cfc49e9c251c992e4c49e |
|
MD5 | 22a22308781c359fe1482966a157233c |
|
BLAKE2b-256 | c14996a4bb09a169139d0445f1a1ea4c32be6aea053710578adcf5b66973d8fa |
File details
Details for the file slim_gsgp-0.1.4-py3-none-any.whl
.
File metadata
- Download URL: slim_gsgp-0.1.4-py3-none-any.whl
- Upload date:
- Size: 101.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.15
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8ced181384b1a13882639f5e77fb38a4982822305022176ac6b421008078e8be |
|
MD5 | 7005a110d86ee31da308707a7893550e |
|
BLAKE2b-256 | cfe3a669404a0e70a26527822870e73e5ab2b05a4d5a2fc3e0dab557f480cc4a |