Skip to main content

SeFEF: Seizure Forecast Evaluation Framework

Project description

SeFEF logo

SeFEF is a Seizure Forecast Evaluation Framework written in Python. The framework standardizes the development, evaluation, and reporting of individualized algorithms for seizure likelihood forecast. SeFEF aims to decrease development time and minimize implementation errors by automating key procedures within data preparation, training/testing, and computation of evaluation metrics.

Highlights:

  • evaluation module: implements time series cross-validation.

  • labeling module: automatically labels samples according to the desired pre-ictal duration and prediction latency.

  • postprocessing module: processes individual predicted probabilities into a unified forecast according to the desired forecast horizon.

  • scoring module: computes both deterministic and probabilistic metrics according to the horizon of the forecast.

Installation

Installation can be easily done with pip:

$ pip install sefef

Simple Example

The code below loads the metadata from an existing dataset from the examples folder, create a Dataset instance, and creates an adequate split for a time series cross-validation.

import json
import pandas as pd
from sefef import evaluation

# read example files
files_metadata = pd.read_csv('examples/files_metadata.csv')
with open('examples/sz_onsets.txt', 'r') as f:
     sz_onsets = json.load(f)

# create Dataset instance and perform TSCV
dataset = evaluation.Dataset(files_metadata, sz_onsets, sampling_frequency=128)
tscv = evaluation.TimeSeriesCV()
tscv.split(dataset, iteratively=False, plot=True)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sefef-2.3.2.tar.gz (122.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sefef-2.3.2-py3-none-any.whl (24.7 kB view details)

Uploaded Python 3

File details

Details for the file sefef-2.3.2.tar.gz.

File metadata

  • Download URL: sefef-2.3.2.tar.gz
  • Upload date:
  • Size: 122.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sefef-2.3.2.tar.gz
Algorithm Hash digest
SHA256 32ae89a017542edf380951b4b8f389e7874b5af013b2e5077942ab0ef64d67bf
MD5 f52439680012cf28c41949dbc33e1353
BLAKE2b-256 a39ba0d67f4b59356f658e7b09405ecec89a642938ba5a85bcd3ab459031d318

See more details on using hashes here.

Provenance

The following attestation bundles were made for sefef-2.3.2.tar.gz:

Publisher: release.yml on anascacais/SeFEF

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sefef-2.3.2-py3-none-any.whl.

File metadata

  • Download URL: sefef-2.3.2-py3-none-any.whl
  • Upload date:
  • Size: 24.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sefef-2.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 98c2ca66aa2c2825f4f3c9451e04904c54271a5a199ed0ed6b98929fcb27ef9f
MD5 749cd4756aca14a332847d796a5cfc8e
BLAKE2b-256 6498b141fc9195a358cf8e3f35b1cd67623be9d3fe8f8c0c9777f3e3111c6a3f

See more details on using hashes here.

Provenance

The following attestation bundles were made for sefef-2.3.2-py3-none-any.whl:

Publisher: release.yml on anascacais/SeFEF

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page