Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

adds scikit core to build arrayfire binaries #12

Merged
merged 9 commits into from
Feb 8, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
43 changes: 43 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
cmake_minimum_required(VERSION 3.20)

project(
${SKBUILD_PROJECT_NAME}
LANGUAGES C CXX
VERSION ${SKBUILD_PROJECT_VERSION})

find_package(Python COMPONENTS Interpreter Development.Module)


if(DEFINED ENV{AF_BUILD_LOCAL_LIBS})
include(FetchContent)

#set(NO_SONAME)
FetchContent_Declare(
arrayfire
GIT_REPOSITORY https://github.com/arrayfire/arrayfire.git
GIT_TAG v3.9
)
#TODO: change package name to match repository/project name?
#set(AF_INSTALL_CMAKE_DIR "${SKBUILD_PROJECT_NAME}")

set(AF_INSTALL_BIN_DIR "arrayfire_wrapper/binaries")
set(AF_INSTALL_CMAKE_DIR "arrayfire_wrapper/binaries")
set(AF_INSTALL_DOC_DIR "arrayfire_wrapper/binaries")
set(AF_INSTALL_EXAMPLE_DIR "arrayfire_wrapper/binaries")
set(AF_INSTALL_INC_DIR "arrayfire_wrapper/binaries")
set(AF_INSTALL_LIB_DIR "arrayfire_wrapper/binaries")
set(FG_INSTALL_LIB_DIR "arrayfire_wrapper/binaries")

FetchContent_MakeAvailable(arrayfire)
endif()

# Testing artifacts
file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/generated.txt "Testing")
install(
FILES ${CMAKE_CURRENT_BINARY_DIR}/generated.txt
DESTINATION arrayfire_wrapper
COMPONENT Generated)

file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/generated_ignored.txt "Testing")
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/generated_ignored.txt
DESTINATION arrayfire_wrapper)
2 changes: 1 addition & 1 deletion LICENSE
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
BSD 3-Clause License

Copyright (c) 2023, Anton
Copyright (c) 2023, ArrayFire

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
Expand Down
94 changes: 75 additions & 19 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,21 +1,77 @@
# arrayfire-binary-python-wrapper

Arrayfire python C library wrapper

## Coverage

- [x] Computer Vision
- [x] Events
- [x] Functions to Create and Modify Arrays
- [x] Functions to Work with Internal Array Layout
- [x] Image Processing
- [x] Features
- [x] Input and Output Functions
- [x] Interface Functions
- [x] Linear Algebra
- [x] Machine Learning
- [x] Mathematical Functions
- [x] Signal Processing
- [x] Statistics
- [x] Unified API Functions
- [x] Vector Algorithms
[ArrayFire](https://github.com/arrayfire/arrayfire) is a high performance library for parallel computing with an easy-to-use API. It enables users to write scientific computing code that is portable across CUDA, OpenCL and CPU devices.

This project is meant to provide thin Python bindings for the ArrayFire C library. It also decouples releases of the main C/C++ library from the Python library by acting as a intermediate library and only wrapping the provided C calls.

This allows the building of large binary wheels only when the underlying ArrayFire version is increased, and the fully-featured Python library can be developed atop independently. The package is not intended to be used directly and merely exposes the
C functionality required by downstream implementations. This package can exist in two forms, with a bundled binary distribution, or merely as a loader that will load the ArrayFire library from a system or user level install.

# Installing

The arrayfire-binary-python-wrapper can be installed from a variety of sources. [Pre-built wheels](https://repo.arrayfire.com/python/wheels/3.9.0/) are available for a number of systems and toolkits. These will include a binary distribution of the ArrayFire libraries. Installing from PyPI directly will only include a wrapper-only, source distribution that will not contain binaries. In this case, wrapper-only installations will require a separate installation of the ArrayFire C/C++ libraries.
You can get the ArrayFire C/C++ library from the following sources:

- [Download and install binaries](https://arrayfire.com/download)
- [Build and install from source](https://github.com/arrayfire/arrayfire)


**Install the last stable version of python wrapper:**
```
pip install arrayfire-binary-python-wrapper
```

**Install a pre-built wheel:**
```
pip install arrayfire-binary-python-wrapper -f https://repo.arrayfire.com/python/wheels/3.9.0/
```

# Building
The arrayfire-binary-python-wrapper can build wheels in packaged-binary or in system-wrapper modes.
[scikit-build-core](https://github.com/scikit-build/scikit-build-core) is used to provide the python build backend.
The minimal, wrapper-only mode that relies on a system install will be built by default though the regular python build process. For example:
```
pipx run build --wheel
```
Building a full pre-packaged local binary is an involved process that will require referencing the regular ArrayFire [build](https://github.com/arrayfire/arrayfire/wiki/Build-Instructions-for-Linux) [procedures](https://github.com/arrayfire/arrayfire/wiki/Build-Instructions-for-Windows).
Besides the regular ArrayFire CMake configuration, building the binaries is an opt-in process that is set by an environment variable `AF_BUILD_LOCAL_LIBS=1`. Once that environment variable is set, scikit-build-core will take care of cloning ArrayFire, building, and including the necessary binaries.


# Contributing

The community of ArrayFire developers invites you to build with us if you are
interested and able to write top-performing tensor functions. Together we can
fulfill [The ArrayFire
Mission](https://github.com/arrayfire/arrayfire/wiki/The-ArrayFire-Mission-Statement)
for fast scientific computing for all.

Contributions of any kind are welcome! Please refer to [the
wiki](https://github.com/arrayfire/arrayfire/wiki) and our [Code of
Conduct](33) to learn more about how you can get involved with the ArrayFire
Community through
[Sponsorship](https://github.com/arrayfire/arrayfire/wiki/Sponsorship),
[Developer
Commits](https://github.com/arrayfire/arrayfire/wiki/Contributing-Code-to-ArrayFire),
or [Governance](https://github.com/arrayfire/arrayfire/wiki/Governance).

# Citations and Acknowledgements

If you redistribute ArrayFire, please follow the terms established in [the
license](LICENSE).

ArrayFire development is funded by AccelerEyes LLC and several third parties,
please see the list of [acknowledgements](ACKNOWLEDGEMENTS.md) for an
expression of our gratitude.

# Support and Contact Info

* [Slack Chat](https://join.slack.com/t/arrayfire-org/shared_invite/MjI4MjIzMDMzMTczLTE1MDI5ODg4NzYtN2QwNGE3ODA5OQ)
* [Google Groups](https://groups.google.com/forum/#!forum/arrayfire-users)
* ArrayFire Services: [Consulting](http://arrayfire.com/consulting) | [Support](http://arrayfire.com/download) | [Training](http://arrayfire.com/training)

# Trademark Policy

The literal mark "ArrayFire" and ArrayFire logos are trademarks of AccelerEyes
LLC (dba ArrayFire). If you wish to use either of these marks in your own
project, please consult [ArrayFire's Trademark
Policy](http://arrayfire.com/trademark-policy/)
3 changes: 2 additions & 1 deletion arrayfire_wrapper/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,9 @@
"Backend",
"BackendType",
"get_backend",
"set_backend",
]
from ._backend import Backend, BackendType, get_backend
from ._backend import Backend, BackendType, get_backend, set_backend

__all__ += [
"Dtype",
Expand Down
Loading