Skip to main content

Custom utility functions for exploratory factor analysis with the factor_analyzer package.

Project description

efa_utils

Custom utility functions for exploratory factor analysis with the factor_analyzer package.

Installation

Install with pip:

pip install efa_utils

For optional dependencies:

pip install efa_utils[optional]

Requirements

  • Python 3.11+
  • numpy
  • pandas
  • factor-analyzer
  • statsmodels (for reduce_multicoll and kmo_check)
  • matplotlib (optional, for parallel_analysis and iterative_efa with parallel analysis option)
  • reliabilipy (optional, for factor_int_reliability)

Functions

efa_utils.reduce_multicoll

Reduces multicollinearity in a dataset intended for EFA. Uses the determinant of the correlation matrix to determine if multicollinearity is present. If the determinant is below a threshold (0.00001 by default), the function will drop the variable with the highest VIF until the determinant is above the threshold.

efa_utils.kmo_check

Checks the Kaiser-Meyer-Olkin measure of sampling adequacy (KMO) and Bartlett's test of sphericity for a dataset. Main use is to print a report of total KMO and item KMOs, but can also return the KMO values.

efa_utils.parallel_analysis

Performs parallel analysis to determine the number of factors to retain. Requires matplotlib (optional dependency).

efa_utils.iterative_efa

Performs iterative exploratory factor analysis. Runs EFA with an iterative process, eliminating variables with low communality, low main loadings or high cross loadings in a stepwise process. If parallel analysis option is used, it requires matplotlib (optional dependency).

efa_utils.print_sorted_loadings

Prints strongly loading variables for each factor. Will only print loadings above a specified threshold for each factor.

efa_utils.rev_items_and_return

Takes an EFA object and automatically reverse-codes (Likert-scale) items where necessary and adds the reverse-coded version to a new dataframe. Returns the new dataframe.

efa_utils.factor_int_reliability

Calculates and prints the internal reliability for each factor. Takes a pandas dataframe and dictionary with name of factors as keys and list of variables as values. Requires reliabilipy (optional dependency).

Usage

Here's a basic example of how to use efa_utils:

import pandas as pd
from efa_utils import reduce_multicoll, kmo_check, parallel_analysis, iterative_efa

# Load your data
data = pd.read_csv('your_data.csv')

# Reduce multicollinearity
reduced_vars = reduce_multicoll(data, data.columns)

# Check KMO
kmo_check(data, reduced_vars)

# Perform parallel analysis
n_factors = parallel_analysis(data, reduced_vars)

# Perform iterative EFA
efa, final_vars = iterative_efa(data, reduced_vars, n_facs=n_factors)

# Print results
print(f"Final variables: {final_vars}")
print(efa.loadings_)

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the GNU General Public License v3.0 - see the LICENSE file for details.

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

efa_utils-0.7.23.tar.gz (23.9 kB view details)

Uploaded Source

Built Distribution

efa_utils-0.7.23-py3-none-any.whl (24.5 kB view details)

Uploaded Python 3

File details

Details for the file efa_utils-0.7.23.tar.gz.

File metadata

  • Download URL: efa_utils-0.7.23.tar.gz
  • Upload date:
  • Size: 23.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.5 Windows/11

File hashes

Hashes for efa_utils-0.7.23.tar.gz
Algorithm Hash digest
SHA256 7796cb92e16b751f0b61f015ad3c5f26b14155eed43bd30faabb9bc57f7d2f6a
MD5 e72bf80206f56b1d86e225bba0cdeae7
BLAKE2b-256 32df607a298e85e9536aae198c47094676550f9a6b85ef741e88adcb42c2d0d1

See more details on using hashes here.

File details

Details for the file efa_utils-0.7.23-py3-none-any.whl.

File metadata

  • Download URL: efa_utils-0.7.23-py3-none-any.whl
  • Upload date:
  • Size: 24.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.5 Windows/11

File hashes

Hashes for efa_utils-0.7.23-py3-none-any.whl
Algorithm Hash digest
SHA256 70f2c0d130cb34a751a25c443d0fab39d7525654968c033c16614d3d78803c41
MD5 a31f1ae3a1c539c643e1ab9fcf3a447f
BLAKE2b-256 ca0defa4dbf1be2173bcb17b3adf86af97fdb59f5655b283c4b3b9b73fd7da3d

See more details on using hashes here.

Supported by

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