Reverted many changes from v0.10.0.
- Added static analysis coverage https://akielaries.github.io/openGPMP/analysis/index.html
- Added unit test coverage https://akielaries.github.io/openGPMP/testing/index.html
- Reworked CI/CD actions for building/generating documentation
- Updated some unit tests to increase overall coverage
- Included static analysis workflows with clang-tidy, clang-analyze, cppcheck, osv-scanner, and infer
- Base DataTable, Logging, Threading, and other miscellaneous utilities
- Added class related to graphs
- Mass rewrite to support AVX, SSE, and ARM platforms for now
- Support for matrices as arrays and vectors
- For now there are two main paths for this module. One is using somewhat naive methods that use naive blocking tricks and SIMD intrinsics, the other is the formal BLAS routine type of route that makes use of cache alignment, large blocking, assembly kernels, SIMD registers (AVX, SSE, MMX, ARM for now)
- Added methods for eigenvalues, SVD, and linear systems, and (tensor methods which are still a large TODO)
- Added several naive implementations for neural networks, classifiers, regression methods, and more
- These will need to be optimized and using the linalg module
- Added classes for probability distribution and descriptive statistics methods
- This is a subproject intended for MCUs (AVR and STM for now)
- Big TODO as there is nothing formally implemented and just tests for now
- Added options for building tinygpmp, including OpenBLAS in linking
- Additional options for building tests, specifying tinygpmp build and microarch
Some known issues and things that need attention:
- Majority of the project is not optimized and contains "naive" implementation with no regard for execution speed
- Use of clang/clang++ for compilation produces some issues not seen with gcc/g++
- Lots of duplicate code (everywhere for the most part, especially in the unit tests directory)
- Test coverage is minimal and many methods are not tested as strongly as they should be
- And some more...
New contributions from @eeddgg, @sidsbrmnn, @igorsteinmacher
-
Project renamed from openMTPK to openGPMP. Python API renamed from openmtpk to pygpmp. Experimental Julia API as gpmp.jl
-
Documentation layout + additions
-
gpmp::accl
namespace introduced hardware acceleration methods using GPUs with the help of OpenCL and CUDA for supported platforms (still very much experimental) and additional methods for CPU exploitation with Intel specific SIMD intrinsic functions. The acceleration unit is an optional install with openGPMP with the use ofcmake
.gpmp::accl::GPU()
class features methods of GPU acceleration using OpenCL. This class will house methods seen in the mathematical openGPMP modules that are ideal for GPU computation. The GPU functions themselves will be written inC
with wrapper methods for use inC++
usingextern "C" {/* function definitions */}
making them available under thegpmp::accl
namespace.gpmp::accl::SIMD()
class features accelerated functions seen in the core mathematical openGPMP modules ideal for wide register computations using Intel specific intrinsic functions.
-
gpmp::core::ThreadPool()
class capable of spawning a specific number of threads or the defaultstd::thread::hardware_concurrency()
.- view docs here
Note This class is not yet used innately within openGPMP and is provided as a user utility for now.
-
gpmp::core::ThreadDispatch()
class that dispatches functions to the threadpool.- view docs here
-
gpmp::core::DataTable()
class capable of reading in CSV files storing them as a pair of vector strings. For now, the DataTable class features very limited functionality, reading in CSVs(entirely, or specific columns), formatted displaying, and two conversion methods for thestring->int
&string->double
.- Solves open enhancement
#29 DataFrame/DataTable related functionality
- view docs here
- Solves open enhancement
-
gpmp::core::TypeCast()
class featuring several methods to convert C++std::
specific data types to C-compatible data types. This class is utilized for the C++ wrapping of the C-based acceleration methods. -
Created
rolling
branch that will update its commits from the gpmp-bot user on a nightly basis, using the#NIGHTLY:
commit message prefix. -
Introduced updates to calculus module in numerical differentation methods. First, second, and third order derivatives methods of a given polynomial in a function at a given value. For example f(x) = x^2ln(x) =
x*x*log(x)
. -
Updates to unit tests and additions for the new classes introduced.
-
Updates to namespaces, the core module containing the ThreadPool and DataTable related methods along with other miscellaneous tools lies under the
gpmp::core
namespace. -
Patches introduced for
#27 OSX Build reaches dead state
- This introduced additional testing and CICD work related to openGPMP on OSX
- Division between code for internal functionality vs. what is available to the user.
- CI/CD pipeline updates
clang-format
for linting/formatting C++ source code,autopep8
for Python.- Python PyPI packaging edits.
- Tag bump related commits will include a
#MAJOR
,#MINOR
, or#PATCH
prefix to the commit message. - Updates to certain directories run certain jobs.
- Continuous Machine Learning & Linear Algebra module updates.
- Stubbed out implementations for activation, regularization, optimization & model trainer methods, statistical helpers, random sorts + utilities.
Matrix
related methods are usable. More updates to come.- ML module is not currently usable aside from
Linear Regression
model on very select data sets.
- Updates to Primary and Secondary Multi-Layer Perceptron networks
- Updates to Python API
- Added support for Operating Systems, Kernels, Architectures, etc.
- Added tested support beyond x86 processors
- ARMV6, ARMV7, ARMV8, RISCV64, S390X, PPC64LE
- Raspberry Pi 3 & 4 support
- Fortran, OCaml, Go and Julia demoted to experimental APIs, focus remains on Python and now R bindings
- Fix CMake bugs for
OSX
installation. Issues with Googletest hangup - Update Machine Learning Module with more techniques
- Inject source code updates into APIs
- Create formal check/test process for Raspberry Pi hardware
- Continued changes to Linear Algebra Module + samples
- Continued updates to Python API, injecting new C++ source functionalities into the
setup.py
file used in packaging process for PyPI- Install with
pip install openmtpk==0.6.1
- Install with
- Updates to the
gpmp
namespace. Wrapped more classes in the namespace, does not affect Python API - Changes/updates to datatypes to allow for maximum precision while also avoiding potential overflow as well as for conciseness
Note Some int and char types will be updated later on to ensure nothing breaks
int
----------->int64_t
long long
-->int64_t
unsigned
---->uint64_t
double
------->long double
float
--------->long double
- Adding
make uninstall
option for the project's build process with CMake. See the install/uninstall directions here.
- Updates to Linear Algebra Module and samples
- See this example to view operations on matrices
- More updates to samples as development continues
- PyPI updates
- Adjusting SWIG process to accommodate for template based classes and methods
- pygpmp
0.5.14
release here
- Updated to CMake installation of source C++ code
- Create first of many Neural Network Models and Machine Learning techniques for the ml module
- Update the overarching
ml.hpp
header to make use of implemented models and techniques
Note So far the Linear Regression technique works on select two-column data
- Update the overarching
- Progress on CPP->R & OCaml language binding process
Note Do not expect much until v1.0.0 New contribution from @earies
- Builds wheels for OSX and Linux platforms (Windows will not be supported)
- See all supported platforms.
- Manually tested on Kali(latest), Ubuntu(latest) & macOS Ventura 13.1 (latest). Works for most OSX and Linux distro versions.
- New versions must be specified in the
setup.py
file and will be published to https://pypi.org/project/pygpmp/ on pushes toMAIN
. - Install with
pip install pygpmp
- Tools available:
- Arithmetic based operations
- Primes
- RC4
- Ciphers
- Bugs with googletest on OSX.
- Created Python pip package for Python API. Install with
pip install pygpmp
- Functionality is limited to Primes, RC4, Ciphers, and part of the Arithmetic module
- Fixes to template classes/methods cpp->python conversion
CMake installation make Googletest as a dependency.
- openGPMP tests must pass in order to build and install the static library
- TEST -> BUILD -> INSTALL
Minor Release with updates to CMake installation process.
- Headers are now installed in nested fashion with a parent-level header representing each module. For example:
- Files in a module directory such as the
ml/
directory (linreg.hpp, logreg.hpp, mlp_network.hpp, etc.) will make up that modules header file(ml.hpp).
- Files in a module directory such as the
- Will include googletest workflow into CMake installation
Build library -> Test library -> Install library
Formal documentation created with Doxygen deployed to github pages, see here.
- Documentation updates within headers
- Linear Regression model testing
- Additional work and plans for Machine/Deep Learning module
- Multi-Layer Perceptron, Linear Algebra Matrix, Scalar, and Vector manipulations + testing
- Formal API installation processes
- Automate API installations with Actions
As always refer to the project README.
Formal installation of source C++ API with CMake. See installation steps in the project README.
- Linux is supported.
- OSX testing is in progress.
- Working Python API, user installation mandatory.
- Unstable Fortran, OCaml, and R bindings.
Future
- Fixes + testing + formal installation of language bindings.
- Neural Networks, Classifiers
https://pygpmp-docs.readthedocs.io/en/latest/index.html
Open-source (intended) mathematics package written in C++ with a working Python API allowing for the use of algorithms and equations seen in many mathematical topics. See the README for more details
Module | Features | Status |
---|---|---|
Arithmetic | Operations, GCD, etc. | Working |
Calculus | Derivative at value | Limited |
Linear Algebra | Matrix Operations | Limited |
Machine/Deep Learning | Linear Regression | Limited |
Number Theory | Primes, Cryptography/Encryption | Working |
Issues:
- No formal installation method
- Test coverage
- OCaml & R bindings are unstable.
- C++->OCaml class translation