Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
|ProjectStatus|_ |Version|_ |BuildStatus|_ |Coverage|_ |License|_ |PythonVersions|_ |Paper|_
.. |ProjectStatus| image:: http://www.repostatus.org/badges/latest/active.svg .. _ProjectStatus: https://www.repostatus.org/#active
.. |Version| image:: https://img.shields.io/pypi/v/fooof.svg .. _Version: https://pypi.python.org/pypi/fooof/
.. |BuildStatus| image:: https://github.com/fooof-tools/fooof/actions/workflows/build.yml/badge.svg .. _BuildStatus: https://github.com/fooof-tools/fooof/actions/workflows/build.yml
.. |Coverage| image:: https://codecov.io/gh/fooof-tools/fooof/branch/main/graph/badge.svg .. _Coverage: https://codecov.io/gh/fooof-tools/fooof
.. |License| image:: https://img.shields.io/pypi/l/fooof.svg .. _License: https://opensource.org/licenses/Apache-2.0
.. |PythonVersions| image:: https://img.shields.io/pypi/pyversions/fooof.svg .. _PythonVersions: https://pypi.python.org/pypi/fooof/
.. |Paper| image:: https://img.shields.io/badge/paper-nn10.1038-informational.svg .. _Paper: https://doi.org/10.1038/s41593-020-00744-x
FOOOF is a fast, efficient, and physiologically-informed tool to parameterize neural power spectra.
The power spectrum model conceives of a model of the power spectrum as a combination of two distinct functional processes:
This model driven approach can be used to measure periodic and aperiodic properties of electrophysiological data, including EEG, MEG, ECoG and LFP data.
The benefit of fitting a model in order to measure putative oscillations, is that peaks in the power spectrum are characterized in terms of their specific center frequency, power and bandwidth without requiring predefining specific bands of interest and controlling for the aperiodic component. The model also returns a measure of this aperiodic components of the signal, allowing for measuring and comparison of 1/f-like components of the signal within and between subjects.
Documentation is available on the
documentation site <https://fooof-tools.github.io/fooof/index.html>
_.
This documentation includes:
Motivations <https://fooof-tools.github.io/fooof/auto_motivations/index.html>
_:
with motivating examples of why we recommend parameterizing neural power spectraTutorials <https://fooof-tools.github.io/fooof/auto_tutorials/index.html>
_:
with a step-by-step guide through the model and how to apply itExamples <https://fooof-tools.github.io/fooof/auto_examples/index.html>
_:
demonstrating example analyses and use cases, and other functionalityAPI list <https://fooof-tools.github.io/fooof/api.html>
_:
which lists and describes all the code and functionality available in the moduleFAQ <https://fooof-tools.github.io/fooof/faq.html>
_:
answering frequency asked questionsGlossary <https://fooof-tools.github.io/fooof/glossary.html>
_:
which defines all the key terms used in the moduleReference <https://fooof-tools.github.io/fooof/reference.html>
_:
with information for how to reference and report on using the moduleFOOOF is written in Python, and requires Python >= 3.6 to run.
It has the following required dependencies:
numpy <https://github.com/numpy/numpy>
_scipy <https://github.com/scipy/scipy>
_ >= 0.19There are also optional dependencies, which are not required for model fitting itself, but offer extra functionality:
matplotlib <https://github.com/matplotlib/matplotlib>
_ is needed to visualize data and model fitstqdm <https://github.com/tqdm/tqdm>
_ is needed to print progress bars when fitting many modelspandas <https://github.com/pandas-dev/pandas>
_ is needed to for exporting model fit results to dataframespytest <https://github.com/pytest-dev/pytest>
_ is needed to run the test suite locallyWe recommend using the Anaconda <https://www.anaconda.com/distribution/>
_ distribution to manage these requirements.
The current major release is the 1.X.X series, which is a breaking change from the prior 0.X.X series.
Check the changelog <https://fooof-tools.github.io/fooof/changelog.html>
_ for notes on updating to the new version.
Stable Version
To install the latest stable release, use pip:
.. code-block:: shell
$ pip install fooof
The module can also be installed with conda, from the conda-forge channel:
.. code-block:: shell
$ conda install -c conda-forge fooof
Development Version
To get the current development version, first clone this repository:
.. code-block:: shell
$ git clone https://github.com/fooof-tools/fooof
To install this cloned copy, move into the directory you just cloned, and run:
.. code-block:: shell
$ pip install .
Editable Version
To install an editable version, download the development version as above, and run:
.. code-block:: shell
$ pip install -e .
The original implementation of FOOOF, available in this repository, is implemented in Python.
If you wish to run FOOOF from another language, there are a couple potential options:
wrapper
, which allows for running the Python code from another languagereimplementation
, which reflects a new implementation of the fooof algorithm in another languageBelow are listed some examples of wrappers and/or reimplementations in other languages (non-exhaustive).
Matlab
In Matlab, there is a reimplementation available in common toolboxes:
- The `Brainstorm <https://neuroimage.usc.edu/brainstorm/Introduction>`_ toolbox has a reimplementation of fooof (see the `Brainstorm fooof tutorial <https://neuroimage.usc.edu/brainstorm/Tutorials/Fooof>`_)
- The `Fieldtrip <https://www.fieldtriptoolbox.org/>`_ also uses the same reimplementation (see the `Fieldtrip fooof tutorial <https://www.fieldtriptoolbox.org/example/fooof/>`_)
There is also a Matlab wrapper in the `fooof_mat <http://github.com/fooof-tools/fooof_mat>`_ repository.
Note that another option is to use Python FOOOF within a Matlab pipeline, as explored in the
`mat_py_mat <https://github.com/fooof-tools/mat_py_mat>`_ repository.
Other Languages
Other languages with wrappers include:
fooof wrapper <https://juliahub.com/ui/Packages/PyFOOOF/Ng8hN/0.1.0>
_reticulate <https://rstudio.github.io/reticulate/>
, as shown here <https://github.com/fooof-tools/DevelopmentalDemo/tree/main/R>
If you use this code in your project, please cite::
Donoghue T, Haller M, Peterson EJ, Varma P, Sebastian P, Gao R, Noto T, Lara AH, Wallis JD,
Knight RT, Shestyuk A, & Voytek B (2020). Parameterizing neural power spectra into periodic
and aperiodic components. Nature Neuroscience, 23, 1655-1665.
DOI: 10.1038/s41593-020-00744-x
Direct link: https://doi.org/10.1038/s41593-020-00744-x
More information for how to cite this method can be found on the
reference page <https://fooof-tools.github.io/fooof/reference.html>
_.
Code and analyses from the paper are also available in the
paper repository <https://github.com/fooof-tools/Paper>
_.
This project welcomes and encourages contributions from the community!
To file bug reports and/or ask questions about this project, please use the
Github issue tracker <https://github.com/fooof-tools/fooof/issues>
_.
To see and get involved in discussions about the module, check out:
issues board <https://github.com/fooof-tools/fooof/issues>
_ for topics relating to code updates, bugs, and fixesdevelopment page <https://github.com/fooof-tools/Development>
_ for discussion of potential major updates to the moduleWhen interacting with this project, please use the
contribution guidelines <https://github.com/fooof-tools/fooof/blob/main/CONTRIBUTING.md>
_
and follow the
code of conduct <https://github.com/fooof-tools/fooof/blob/main/CODE_OF_CONDUCT.md>
_.
This module is object oriented, and uses a similar approach as used in scikit-learn.
The algorithm works on frequency representations, that is power spectra in linear space.
Fitting a Single Power Spectrum
With a power spectrum loaded (with 'freqs' storing frequency values, and 'spectrum' storing the power spectrum, both as 1D arrays in linear space) FOOOF can be used as follows:
.. code-block:: python
# Import the FOOOF object
from fooof import FOOOF
# Initialize FOOOF object
fm = FOOOF()
# Define frequency range across which to model the spectrum
freq_range = [3, 40]
# Model the power spectrum with FOOOF, and print out a report
fm.report(freqs, spectrum, freq_range)
FOOOF.report() fits the model, plots the original power spectrum with the associated FOOOF model fit, and prints out the parameters of the model fit for both the aperiodic component, and parameters for any identified peaks, reflecting periodic components.
Example output for the report of a FOOOF fit on an individual power spectrum:
.. image:: https://raw.githubusercontent.com/fooof-tools/fooof/main/doc/img/FOOOF_report.png
Defining the model Settings
The settings for the algorithm are:
peak_width_limits
sets the possible lower- and upper-bounds for the fitted peak widths.max_n_peaks
sets the maximum number of peaks to fit.min_peak_height
sets an absolute limit on the minimum height (above aperiodic) for any extracted peak.peak_threshold
sets a relative threshold above which a peak height must cross to be included in the model.aperiodic_mode
defines the approach to use to parameterize the aperiodic component.These settings can be defined when initializing the model, for example:
.. code-block:: python
# Initialize a FOOOF model object with defined settings
fm = FOOOF(peak_width_limits=[1.0, 8.0], max_n_peaks=6, min_peak_height=0.1,
peak_threshold=2.0, aperiodic_mode='fixed')
Fitting a Group of Power Spectra
Next is an example workflow for fitting a group of neural power spectra. In this case, 'freqs' is again a 1D array of frequency values, and 'spectra' is a 2D array of power spectra. We can fit the group of power spectra by doing:
.. code-block:: python
# Initialize a FOOOFGroup object, specifying some parameters
fg = FOOOFGroup(peak_width_limits=[1.0, 8.0], max_n_peaks=8)
# Fit FOOOF model across the matrix of power spectra
fg.fit(freqs, spectra)
# Create and save out a report summarizing the results across the group of power spectra
fg.save_report()
# Save out FOOOF results for further analysis later
fg.save(file_name='fooof_group_results', save_results=True)
Example output from using FOOOFGroup across a group of power spectra:
.. image:: https://raw.githubusercontent.com/fooof-tools/fooof/main/doc/img/FOOOFGroup_report.png
Other Functionality
The module also includes functionality for fitting the model to matrices of multiple power spectra,
saving and loading results, creating reports describing model fits, analyzing model outputs,
plotting models and parameters, and simulating power spectra, all of which is described in the
documentation <https://fooof-tools.github.io/fooof/>
_.
Supported by NIH award R01 GM134363 from the
NIGMS <https://www.nigms.nih.gov/>
_.
.. image:: https://www.nih.gov/sites/all/themes/nih/images/nih-logo-color.png :width: 400
|
FAQs
fitting oscillations & one-over f
We found that fooof demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.