A Comprehensive Python Package for Fractal Dimension Calculation and Multifractal Analysis
English | ็ฎไฝไธญๆ
FracDimPy is a powerful and easy-to-use Python package designed for fractal dimension calculation and multifractal analysis. Whether you are a researcher studying fractal geometry or an engineer analyzing complex data, FracDimPy provides professional and accurate analysis tools.
-
๐ข Multiple Monofractal Methods
- Hurst Exponent Method (R/S Analysis)
- Box-counting Method
- Information Dimension Method
- Correlation Dimension Method
- Structure Function Method
- Variogram Method
- Sandbox Method
- Detrended Fluctuation Analysis (DFA)
-
๐ Multifractal Analysis
- One-dimensional curve multifractal analysis
- Two-dimensional image multifractal analysis
- Multifractal Detrended Fluctuation Analysis (MF-DFA)
- Custom scale sequences
-
๐จ Fractal Generator
- Classical fractals: Cantor set, Sierpinski triangle/carpet, Koch curve, Menger sponge, etc.
- Random fractals: Brownian motion, Lรฉvy flight, self-avoiding walk, Diffusion-Limited Aggregation (DLA)
- Fractal curves: FBM curve, Weierstrass-Mandelbrot function, Takagi curve
- Fractal surfaces: FBM surface, Weierstrass-Mandelbrot surface, Takagi surface
-
๐ Rich Visualization
- Automatic generation of professional charts
- Log-log plot fitting
- Multifractal spectrum display
- Customizable plotting options
-
๐พ Flexible Data Processing
- Support for multiple data formats (CSV, Excel, TXT, NPY, images, etc.)
- Automatic data preprocessing
- Result export functionality
# Install complete package (with all dependencies)
pip install FracDimPyFor users in mainland China, we recommend using mirror sources for faster installation speed:
# Install using Tsinghua University mirror
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple FracDimPy
# Or permanently configure mirror source
pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple
pip install FracDimPyCommon Mirror Sources:
- Tsinghua University:
https://pypi.tuna.tsinghua.edu.cn/simple - Alibaba Cloud:
https://mirrors.aliyun.com/pypi/simple - USTC:
https://pypi.mirrors.ustc.edu.cn/simple - Douban:
https://pypi.douban.com/simple
# Note: Package name starts with lowercase letter
import fracDimPy
# Import specific functions from submodules
from fracDimPy.monofractal import *
from fracDimPy.multifractal import *
from fracDimPy.generator import *Important Note: Although the PyPI package name is FracDimPy (uppercase F), you need to use import fracDimPy (lowercase f) in your Python code.
from fracDimPy import hurst_dimension, box_counting, dfa
from fracDimPy import multifractal_curve, mf_dfa
from fracDimPy import generate_fbm_curve
import numpy as np
# Generate a fractal curve (returns curve, actual_dimension)
curve, actual_dim = generate_fbm_curve(dimension=1.5, length=2048)
# Monofractal analysis
D, result = hurst_dimension(curve)
print(f"Hurst dimension: {D:.4f}, Rยฒ: {result['R2']:.4f}")
D, result = dfa(curve)
print(f"DFA Hurst exponent: {result['alpha']:.4f}, Rยฒ: {result['r_squared']:.4f}")
# Box-counting on curve coordinates
x = np.arange(len(curve))
D, result = box_counting((x, curve), data_type="curve")
print(f"Box-counting dimension: {D:.4f}, Rยฒ: {result['R2']:.4f}")
# Multifractal analysis (single column)
metrics, figure_data = multifractal_curve(curve, data_type="single")
print(f"D(0)={metrics[' D(0)'][0]:.4f}, D(1)={metrics[' D(1)'][0]:.4f}, D(2)={metrics[' D(2)'][0]:.4f}")
# MF-DFA
hq, spectrum = mf_dfa(curve)
q_arr = np.array(hq['q_list'])
idx_2 = np.where(np.abs(q_arr - 2) < 1e-10)[0][0]
print(f"h(2)={hq['h_q'][idx_2]:.4f}, spectrum width={spectrum['width']:.4f}")Provides various monofractal dimension calculation methods:
| Method | Function Name | Data Type | Description |
|---|---|---|---|
| Hurst Exponent | hurst_dimension() |
1D time series | R/S analysis, modified R/S, DFA |
| Box-counting | box_counting() |
1D/2D/3D | Most commonly used fractal dimension calculation method |
| Information Dimension | information_dimension() |
Point set data | Dimension based on information entropy |
| Correlation Dimension | correlation_dimension() |
Point set data | Based on correlation integral |
| Structure Function | structural_function() |
1D curve | Suitable for self-affine curves |
| Variogram | variogram_method() |
1D/2D | Geostatistical method |
| Sandbox | sandbox_method() |
Point set/image | Local scale analysis |
| DFA | dfa() |
1D time series | Detrended Fluctuation Analysis |
Provides multifractal analysis tools:
| Function | Description | Output |
|---|---|---|
multifractal_curve() |
One-dimensional curve multifractal analysis | Partition function, generalized dimension, multifractal spectrum |
multifractal_image() |
Two-dimensional image multifractal analysis | Singularity index, multifractal characteristics |
mf_dfa() |
Multifractal DFA | Fluctuation function, Hurst exponent spectrum |
Generates various theoretical and random fractals:
Curve Class (1D):
generate_fbm_curve()- Fractional Brownian Motion curvegenerate_wm_curve()- Weierstrass-Mandelbrot functiongenerate_takagi_curve()- Takagi curvegenerate_koch_curve()- Koch curvegenerate_brownian_motion()- Brownian motiongenerate_levy_flight()- Lรฉvy flight
Surface Class (2D):
generate_fbm_surface()- Fractional Brownian Motion surfacegenerate_wm_surface()- WM surfacegenerate_takagi_surface()- Takagi surface
Pattern Class (Geometric fractals):
generate_cantor_set()- Cantor setgenerate_sierpinski()- Sierpinski trianglegenerate_sierpinski_carpet()- Sierpinski carpetgenerate_vicsek_fractal()- Vicsek fractalgenerate_koch_snowflake()- Koch snowflakegenerate_dla()- Diffusion-Limited Aggregationgenerate_menger_sponge()- Menger sponge (3D)
- Data I/O (
data_io) - Visualization tools (
plotting) - Shared computation utilities:
fitting- Log-log linear regression and R-squared computationscales- Power-of-two scale generationbox_counting_core- Dimension-agnostic box counting primitivesmultifractal_common- Shared multifractal partition/metrics computationimage_drawing- Bresenham line drawing and coordinate normalizationconversion- Coordinate-to-matrix, grayscale conversion, boundary padding
src/fracDimPy/
โโโ __init__.py # Package entry, exports all public functions
โโโ monofractal/ # Monofractal dimension methods
โ โโโ hurst.py # Hurst exponent (R/S analysis)
โ โโโ box_counting.py # Box-counting (1D/2D/3D)
โ โโโ information_dimension.py
โ โโโ correlation_dimension.py
โ โโโ structural_function.py
โ โโโ variogram.py
โ โโโ sandbox.py
โ โโโ dfa.py # Detrended Fluctuation Analysis
โโโ multifractal/ # Multifractal analysis
โ โโโ mf_curve.py # 1D curve multifractal
โ โโโ mf_image.py # 2D image multifractal
โ โโโ mf_dfa.py # Multifractal DFA
โ โโโ custom_epsilon.py # Custom scale support
โโโ generator/ # Fractal generators
โ โโโ curves.py # FBM, WM, Takagi curves
โ โโโ surfaces.py # FBM, WM, Takagi surfaces
โ โโโ patterns.py # Cantor, Sierpinski, Koch, DLA, Menger...
โ โโโ random_fractals.py # Brownian motion, Lรฉvy flight, etc.
โโโ utils/ # Shared utilities
โโโ data_io.py # Data loading and saving
โโโ plotting.py # Visualization tools
โโโ fitting.py # Log-log regression and Rยฒ
โโโ scales.py # Power-of-two scale generation
โโโ box_counting_core.py # Dimension-agnostic box counting
โโโ multifractal_common.py # Shared multifractal computation
โโโ image_drawing.py # Bresenham line drawing
โโโ conversion.py # Coordinate/grayscale/boundary utilities
FracDimPy can be applied to multiple scientific and engineering fields:
- Earth Sciences: Terrain analysis, seismic data, fracture networks
- Materials Science: Porous media, surface roughness, nanostructures
- Biomedical: DNA sequences, protein folding, medical imaging
- Financial Analysis: Stock prices, market volatility, risk assessment
- Image Processing: Texture analysis, pattern recognition, image segmentation
- Environmental Science: River networks, cloud pattern analysis, pollution diffusion
- Physics: Turbulence, phase transitions, chaotic systems
The tests directory contains rich example code and test data:
tests/
โโโ monofractal/ # Monofractal method examples
โ โโโ test_hurst.py
โ โโโ test_box_counting_*.py
โ โโโ ...
โโโ multifractal/ # Multifractal examples
โ โโโ test_mf_curve_*.py
โ โโโ test_mf_image.py
โ โโโ ...
โโโ generator/ # Fractal generation examples
โโโ test_koch.py
โโโ test_dla.py
โโโ ...
Run examples:
cd tests/monofractal
python test_hurst.py- Python >= 3.8
- NumPy >= 1.20.0
- SciPy >= 1.7.0
- Matplotlib >= 3.3.0
- Pandas >= 1.3.0
- NumPy >= 1.20.0 - Numerical computing foundation
- SciPy >= 1.7.0 - Scientific computing tools
- Matplotlib >= 3.3.0 - Data visualization
- Pandas >= 1.3.0 - Data processing
- Pillow >= 9.0.0 - Image I/O
- openpyxl >= 3.0.0 - Excel file support
All dependencies are automatically installed. No manual installation needed for full functionality.
For the complete dependency list, please refer to pyproject.toml
Contributions of all kinds are welcome! Whether it's reporting bugs, suggesting new features, or submitting code improvements.
Please refer to CONTRIBUTING.md for detailed contribution guidelines.
- Zhile Han - Main Developer - Zhihu Profile
This project is licensed under the GNU General Public License v3.0 - see the LICENSE file for details
- Author: Zhile Han
- Email: 2667032759@qq.com
- Address: State Key Laboratory of Oil and Gas Reservoir Geology and Exploitation, Southwest Petroleum University, Chengdu 610500, China
- Zhihu: ๅฐๅญฆ็ไนๆณๅไนฆ
- GitHub: https://github.com/Kecoya/FracDimPy
If you use FracDimPy in your research, please cite:
@software{fracdimpy2024,
author = {Zhile Han},
title = {FracDimPy: A Comprehensive Python Package for Fractal Dimension Calculation and Multifractal Analysis},
year = {2024},
url = {https://github.com/Kecoya/FracDimPy},
version = {0.1.4}
}Architecture Refactoring
- Extracted 6 shared utility modules (
fitting,scales,box_counting_core,multifractal_common,image_drawing,conversion) to eliminate ~1000 lines of duplicated code across 16 source files - Unified box-counting implementation into a single dimension-agnostic core, replacing 4 separate copies
- Consolidated all log-log regression patterns (15+ occurrences) into
log_log_fit()andlinear_fit() - Shared multifractal partition function computation between
mf_curveandmf_image
Configuration Cleanup
- Consolidated
mypyconfiguration intopyproject.toml(removedmypy.ini) - Simplified
setup.pyto a minimal shim delegating topyproject.toml - Fixed
pyproject.tomlreadme path, unified line-length settings
Bug Fixes
- Fixed
multifractal_imageprint block referencing non-existent empty-string keys - Fixed coordinate-to-matrix conversion in multifractal curve analysis
Test Suite
- All 384 tests passing (previously 297 pass / 88 fail)
- Expanded shared fixtures and signal generators in
conftest.py - Fixed generator test assertions (dtype checks, shape assertions, statistical thresholds)
- Aligned multifractal test key names with actual API return values
- Relaxed monofractal numerical tolerances to match algorithm capabilities
Thanks to all researchers and open-source community members who have contributed to fractal theory and algorithm implementation.
If this project is helpful to you, please give it a โญ๏ธ!
- NumPy - Numerical computing foundation
- SciPy - Scientific computing tools
- Matplotlib - Data visualization
Made with โค๏ธ by Zhile Han