A Python implementation of the Fisher Scoring algorithm for logistic regression, multinomial regression, and focal loss regression.
Project description
Fisher Scoring Logistic Regression Suite
Author: xRiskLab
GitHub: xRiskLab
Beta Version: 0.1
2024 MIT License
Overview
This repository contains Python implementations of the Fisher Scoring algorithm for various logistic regression models:
- Fisher Scoring Logistic Regression: Standard logistic regression using Fisher scoring.
- Fisher Scoring Multinomial Regression: Multinomial logistic regression for multi-class classification.
- Fisher Scoring Focal Loss Regression: Logistic regression with focal loss for imbalanced classification problems.
The Fisher Scoring algorithm is an iterative optimization algorithm that updates model parameters using the observed or expected Fisher information matrix.
Models
Fisher Scoring Logistic Regression
The FisherScoringLogisticRegression
class is a custom implementation of logistic regression using the Fisher scoring algorithm. It provides methods for fitting the model, making predictions, and computing model statistics, including standard errors, Wald statistic, p-values, and confidence intervals.
Parameters:
epsilon
: Convergence threshold for the algorithm.max_iter
: Maximum number of iterations for the algorithm.information
: Type of information matrix to use ('expected' or 'observed').use_bias
: Include a bias term in the model.significance
: Significance level for computing confidence intervals.
Methods:
fit(X, y)
: Fit the model to the data.predict(X)
: Predict target labels for input data.predict_proba(X)
: Predict class probabilities for input data.get_params()
: Get model parameters.set_params(**params)
: Set model parameters.summary()
: Get a summary of model parameters, standard errors, p-values, and confidence intervals.display_summary()
: Display a summary of model parameters, standard errors, p-values, and confidence intervals.
Fisher Scoring Multinomial Regression
The FisherScoringMultinomialRegression
class implements the Fisher Scoring algorithm for multinomial logistic regression, suitable for multi-class classification tasks.
Parameters:
epsilon
: Convergence threshold for the algorithm.max_iter
: Maximum number of iterations for the algorithm.information
: Type of information matrix to use ('expected' or 'observed').use_bias
: Include a bias term in the model.verbose
: Enable verbose output.
The algorithm is in a beta version and may require further testing and optimization.
Fisher Scoring Focal Loss Regression
The FisherScoringFocalRegression
class implements the Fisher Scoring algorithm with focal loss, designed for imbalanced classification problems where the positive class is rare.
Parameters:
gamma
: Focusing parameter for focal loss.epsilon
: Convergence threshold for the algorithm.max_iter
: Maximum number of iterations for the algorithm.information
: Type of information matrix to use ('expected' or 'observed').use_bias
: Include a bias term in the model.verbose
: Enable verbose output.
The algorithm is experimental and may require further testing and optimization.
Installation
To use the models, clone the repository and install the required dependencies.
git clone https://github.com/xRiskLab/fisher-scoring.git
cd fisher-scoring
pip install -r requirements.txt
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
Built Distribution
File details
Details for the file fisher_scoring-0.1.0.tar.gz
.
File metadata
- Download URL: fisher_scoring-0.1.0.tar.gz
- Upload date:
- Size: 9.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.6.1 CPython/3.10.12 Darwin/23.4.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | de04d9a56991438578b3f4c3635630d0655c1fb1b509daa19dfa097c81829a92 |
|
MD5 | 1dabd2d78fc24094d8418810acaee23f |
|
BLAKE2b-256 | b9252dd35fa16ed074779af10f4193e3b8d337c64d341c2a80ec838521762118 |
Provenance
File details
Details for the file fisher_scoring-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: fisher_scoring-0.1.0-py3-none-any.whl
- Upload date:
- Size: 13.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.6.1 CPython/3.10.12 Darwin/23.4.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8075fd14586a40dbb1ce8c6796124219df54291569d4c972d15f68404ec60166 |
|
MD5 | 190476c0514bafefb28dd86e97d79eee |
|
BLAKE2b-256 | 57ffb451af3731555459fabc5161572d2891c30d86c8e8ced57f995a2e587e6e |