import numpy as np


def split_dataset(train_samples, validation_split=0.0, random=True, bootstrap=False):
    """
    Split the dataset into training and validation sets.
    :param train_samples: Number of training samples
    :param validation_split: Fraction of training samples to use for validation
    :param random: Whether to randomly shuffle the samples
    :param bootstrap: Whether to sample with replacement
    """

    if random:
        indices = np.random.choice(train_samples, train_samples, replace=bootstrap)
    else:
        indices = np.arange(train_samples)

    # Split the indices into training and validation
    if bootstrap:
        train_indices = indices
        # Validation indices are the remaining indices
        validation_indices = np.setdiff1d(np.arange(train_samples), train_indices)
    else:
        split = int(np.floor(validation_split * train_samples))
        train_indices = indices[:-split]
        validation_indices = indices[-split:]

    return train_indices.tolist(), validation_indices.tolist()


if __name__ == '__main__':
    # Test the function
    train_samples = 100
    validation_split = 0.2
    split_dataset(train_samples, validation_split, bootstrap=False)
    split_dataset(train_samples, validation_split, bootstrap=True)
