Changelog¶
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
Version 0.1.0 (2026-02-18)¶
Initial release.
Added¶
Complex Exponential Algorithm (CEA) implementation
complex_exponential_algorithm()- Main function for modal parameter estimationbuild_toeplitz_matrix()- Construct Toeplitz matrix from time seriessolve_polynomial_coefficients()- Least squares solution for characteristic polynomialfind_system_poles()- Extract poles from characteristic polynomialpoles_to_modal_frequencies()- Convert poles to modal frequenciesbuild_vandermonde_matrix()- Construct modal matrixsolve_mode_shapes()- Extract modal participation factorsreconstruct_response()- Reconstruct time series from modal parameters
Documentation
Complete API documentation with NumPy-style docstrings
Theoretical background and algorithm description
Quick start guide and examples
Sphinx documentation with Read the Docs theme
Examples
basic_usage.py- Simple single-mode exampledemo_cea.py- Comprehensive demonstration with visualizationTest scripts for validation
Testing
Test suite with multiple validation cases
Single-mode tests
Multi-mode tests
Phase handling tests
Package Infrastructure
Modern
pyproject.tomlconfigurationProper package structure with
src/layoutDevelopment and documentation dependencies
Build system configuration
README with installation and usage instructions
MIT License
Known Limitations¶
Algorithm is sensitive to measurement noise
Requires manual selection of number of modes
May struggle with closely spaced modes
Assumes proportional damping for real mode shapes
Future Plans¶
Version 0.2.0 (Planned)¶
Automatic model order selection
Stabilization diagrams
Multi-reference implementation
Additional time-domain methods (ERA, ITD)
Version 0.3.0 (Planned)¶
Frequency-domain methods
Uncertainty quantification
Signal pre-processing utilities
Extended visualization tools
Contributing¶
Contributions are welcome! Please see the repository for guidelines.