-
Notifications
You must be signed in to change notification settings - Fork 231
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Python build with a far more portable wheel (#396)
* Identified the appropriate build flags to get a working python build that doesn't rely on -march=native or -mtune=native. We've run benchmarks on multiple computers that indicate the only important flag other than -mavx2 -msse2 -mfma is -funroll-loops. Optimization levels such as -O1, -O2, or -O3 actually makes for less performant code. -Ofast is unavailble for use in Python, as it causes problems with floating point math in Python * 1.22 was left in a comment despite 1.25 being the value specified * Python 3.8 is not supported by numpy 1.25, so we're removing it.
- Loading branch information
Showing
4 changed files
with
56 additions
and
15 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,22 +3,22 @@ requires = [ | |
"setuptools>=59.6", | ||
"pybind11>=2.10.0", | ||
"cmake>=3.22", | ||
"numpy>=1.21", | ||
"numpy==1.25", # this is important to keep fixed. It also means anyone using something other than 1.25 won't be able to use this library | ||
"wheel", | ||
"ninja" | ||
] | ||
build-backend = "setuptools.build_meta" | ||
|
||
[project] | ||
name = "diskannpy" | ||
version = "0.5.0.rc2" | ||
version = "0.5.0.rc4" | ||
|
||
description = "DiskANN Python extension module" | ||
# readme = "../README.md" | ||
requires-python = ">=3.8" | ||
readme = "README.md" | ||
requires-python = ">=3.9" | ||
license = {text = "MIT License"} | ||
dependencies = [ | ||
"numpy" | ||
"numpy==1.25" | ||
] | ||
authors = [ | ||
{name = "Harsha Vardhan Simhadri", email = "[email protected]"}, | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
# diskannpy | ||
|
||
## Installation | ||
Packages published to PyPI will always be built using the latest numpy major.minor release (at this time, 1.25). | ||
|
||
Conda distributions for versions 1.19-1.25 will be completed as a future effort. In the meantime, feel free to | ||
clone this repository and build it yourself. | ||
|
||
## Local Build Instructions | ||
Please see the [Project README](https://github.com/microsoft/DiskANN/blob/main/README.md) for system dependencies and requirements. | ||
|
||
After ensuring you've followed the directions to build the project library and executables, you will be ready to also | ||
build `diskannpy` with these additional instructions. | ||
|
||
### Changing Numpy Version | ||
In the root folder of DiskANN, there is a file `pyproject.toml`. You will need to edit the version of numpy in both the | ||
`[build-system.requires]` section, as well as the `[project.dependencies]` section. The version numbers must match. | ||
|
||
```bash | ||
python3.11 -m venv venv # versions from python3.8 and up should work. on windows, you might need to use py -3.11 -m venv venv | ||
source venv/bin/activate # linux | ||
# or | ||
venv\Scripts\Activate.{ps1, bat} # windows | ||
pip install build | ||
python -m build | ||
``` | ||
|
||
The built wheel will be placed in the `dist` directory in your DiskANN root. Install it using `pip install dist/<wheel name>.whl` | ||
|
||
## Citations | ||
Please cite this software in your work as: | ||
``` | ||
@misc{diskann-github, | ||
author = {Simhadri, Harsha Vardhan and Krishnaswamy, Ravishankar and Srinivasa, Gopal and Subramanya, Suhas Jayaram and Antonijevic, Andrija and Pryce, Dax and Kaczynski, David and Williams, Shane and Gollapudi, Siddarth and Sivashankar, Varun and Karia, Neel and Singh, Aditi and Jaiswal, Shikhar and Mahapatro, Neelam and Adams, Philip and Tower, Bryan}}, | ||
title = {{DiskANN: Graph-structured Indices for Scalable, Fast, Fresh and Filtered Approximate Nearest Neighbor Search}}, | ||
url = {https://github.com/Microsoft/DiskANN}, | ||
version = {0.5}, | ||
year = {2023} | ||
} | ||
``` |