-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Jinxiaolong1129
committed
Mar 8, 2024
0 parents
commit 4cb9a1c
Showing
2,669 changed files
with
63,864 additions
and
0 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,233 @@ | ||
name: Build AutoAWQ Wheels with CUDA | ||
|
||
on: | ||
push: | ||
tags: | ||
- "v*" | ||
|
||
jobs: | ||
release: | ||
# Retrieve tag and create release | ||
name: Create Release | ||
runs-on: ubuntu-latest | ||
outputs: | ||
upload_url: ${{ steps.create_release.outputs.upload_url }} | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v3 | ||
|
||
- name: Extract branch info | ||
shell: bash | ||
run: | | ||
echo "release_tag=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV | ||
- name: Create Release | ||
id: create_release | ||
uses: "actions/github-script@v6" | ||
env: | ||
RELEASE_TAG: ${{ env.release_tag }} | ||
with: | ||
github-token: "${{ secrets.GITHUB_TOKEN }}" | ||
script: | | ||
const script = require('.github/workflows/scripts/github_create_release.js') | ||
await script(github, context, core) | ||
build_cuda_wheels: | ||
name: Build AWQ with CUDA | ||
runs-on: ${{ matrix.os }} | ||
needs: release | ||
|
||
strategy: | ||
matrix: | ||
os: [ubuntu-20.04, windows-latest] | ||
pyver: ["3.8", "3.9", "3.10", "3.11"] | ||
cuda: ["11.8.0", "12.1.1"] | ||
defaults: | ||
run: | ||
shell: pwsh | ||
env: | ||
PYPI_CUDA_VERSION: "12.1.1" | ||
CUDA_VERSION: ${{ matrix.cuda }} | ||
|
||
steps: | ||
- name: Free Disk Space | ||
uses: jlumbroso/[email protected] | ||
if: runner.os == 'Linux' | ||
with: | ||
tool-cache: false | ||
android: true | ||
dotnet: true | ||
haskell: true | ||
large-packages: false | ||
docker-images: true | ||
swap-storage: false | ||
|
||
- uses: actions/checkout@v3 | ||
|
||
- uses: actions/setup-python@v3 | ||
with: | ||
python-version: ${{ matrix.pyver }} | ||
|
||
- name: Setup Mamba | ||
uses: conda-incubator/[email protected] | ||
with: | ||
activate-environment: "build" | ||
python-version: ${{ matrix.pyver }} | ||
miniforge-variant: Mambaforge | ||
miniforge-version: latest | ||
use-mamba: true | ||
add-pip-as-python-dependency: true | ||
auto-activate-base: false | ||
|
||
- name: Install Dependencies | ||
run: | | ||
# Install CUDA toolkit | ||
mamba install -y 'cuda' -c "nvidia/label/cuda-${env:CUDA_VERSION}" | ||
# Env variables | ||
$env:CUDA_PATH = $env:CONDA_PREFIX | ||
$env:CUDA_HOME = $env:CONDA_PREFIX | ||
# Install torch | ||
$cudaVersion = $env:CUDA_VERSION.Replace('.', '') | ||
$cudaVersionPytorch = $cudaVersion.Substring(0, $cudaVersion.Length - 1) | ||
if ([int]$cudaVersionPytorch -gt 118) { $pytorchVersion = "torch==2.2.0" } else {$pytorchVersion = "torch==2.0.1"} | ||
python -m pip install --upgrade --no-cache-dir $pytorchVersion+cu$cudaVersionPytorch --index-url https://download.pytorch.org/whl/cu$cudaVersionPytorch | ||
python -m pip install build setuptools wheel ninja requests | ||
# Print version information | ||
python --version | ||
python -c "import torch; print('PyTorch:', torch.__version__)" | ||
python -c "import torch; print('CUDA:', torch.version.cuda)" | ||
python -c "import os; print('CUDA_HOME:', os.getenv('CUDA_HOME', None))" | ||
python -c "from torch.utils import cpp_extension; print (cpp_extension.CUDA_HOME)" | ||
- name: Build Wheel | ||
run: | | ||
$env:CUDA_PATH = $env:CONDA_PREFIX | ||
$env:CUDA_HOME = $env:CONDA_PREFIX | ||
# Only add +cu118 to wheel if not releasing on PyPi | ||
if ( $env:CUDA_VERSION -eq $env:PYPI_CUDA_VERSION ){ | ||
$env:PYPI_BUILD = 1 | ||
} | ||
$env:PYPI_FORCE_TAGS = 1 | ||
python setup.py sdist bdist_wheel | ||
- name: Upload Assets | ||
uses: shogo82148/actions-upload-release-asset@v1 | ||
with: | ||
upload_url: ${{ needs.release.outputs.upload_url }} | ||
asset_path: ./dist/*.whl | ||
|
||
build_rocm_wheels: | ||
name: Build AWQ with ROCm | ||
runs-on: ${{ matrix.os }} | ||
needs: release | ||
|
||
strategy: | ||
matrix: | ||
os: [ubuntu-20.04] | ||
python: ["3.8", "3.9", "3.10", "3.11"] | ||
rocm: ["5.6.1", "5.7.1"] | ||
defaults: | ||
run: | ||
shell: bash | ||
env: | ||
ROCM_VERSION: ${{ matrix.rocm }} | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
|
||
- name: Free Disk Space | ||
run: | | ||
df -h | ||
echo "Removing large packages" | ||
sudo apt-get remove -y '^dotnet-.*' | ||
sudo apt-get remove -y 'php.*' | ||
sudo apt-get remove -y azure-cli google-chrome-stable firefox powershell mono-devel | ||
df -h | ||
sudo apt-get autoremove -y >/dev/null 2>&1 | ||
sudo apt-get clean | ||
sudo apt-get autoremove -y >/dev/null 2>&1 | ||
sudo apt-get autoclean -y >/dev/null 2>&1 | ||
df -h | ||
echo "https://github.com/actions/virtual-environments/issues/709" | ||
sudo rm -rf "$AGENT_TOOLSDIRECTORY" | ||
df -h | ||
echo "remove big /usr/local" | ||
sudo rm -rf "/usr/local/share/boost" | ||
sudo rm -rf /usr/local/lib/android >/dev/null 2>&1 | ||
df -h | ||
sudo rm -rf /usr/share/dotnet/sdk > /dev/null 2>&1 | ||
sudo rm -rf /usr/share/dotnet/shared > /dev/null 2>&1 | ||
sudo rm -rf /usr/share/swift > /dev/null 2>&1 | ||
df -h | ||
- uses: actions/setup-python@v3 | ||
with: | ||
python-version: ${{ matrix.python }} | ||
|
||
- name: Setup Mamba | ||
uses: conda-incubator/[email protected] | ||
with: | ||
activate-environment: "build" | ||
python-version: ${{ matrix.python }} | ||
mamba-version: "*" | ||
use-mamba: false | ||
channels: conda-forge,defaults | ||
channel-priority: true | ||
add-pip-as-python-dependency: true | ||
auto-activate-base: false | ||
|
||
- name: Set up ROCm | ||
run: | | ||
echo "Using python:" | ||
python --version | ||
which python | ||
if [[ "${{ matrix.rocm }}" == "5.4.2" ]]; then | ||
export ROCM_DL_FILE=amdgpu-install_5.4.50402-1_all.deb | ||
elif [[ "${{ matrix.rocm }}" == "5.6.1" ]]; then | ||
export ROCM_DL_FILE=amdgpu-install_5.6.50601-1_all.deb | ||
elif [[ "${{ matrix.rocm }}" == "5.7.1" ]]; then | ||
export ROCM_DL_FILE=amdgpu-install_5.7.50701-1_all.deb | ||
else | ||
echo Unknown rocm version | ||
exit 1 | ||
fi | ||
curl -O https://repo.radeon.com/amdgpu-install/${{ matrix.rocm }}/ubuntu/focal/$ROCM_DL_FILE | ||
sudo dpkg -i $ROCM_DL_FILE | ||
sudo DEBIAN_FRONTEND=noninteractive amdgpu-install --usecase=rocm --no-dkms --no-32 -y | ||
- name: Install Dependencies | ||
run: | | ||
sudo apt-get update | ||
sudo apt-get install -y --no-install-recommends rocsparse-dev rocthrust-dev rocblas-dev hipblas-dev hipsparse-dev | ||
python -m pip install --upgrade build setuptools wheel requests | ||
if [[ "${{ matrix.rocm }}" == "5.7.1" ]]; then | ||
python -m pip install torch==2.2.0 --index-url https://download.pytorch.org/whl/rocm5.7 | ||
elif [[ "${{ matrix.rocm }}" == "5.6.1" ]]; then | ||
python -m pip install torch==2.2.0 --index-url https://download.pytorch.org/whl/rocm5.6 | ||
else | ||
echo Unknown rocm version for python install | ||
exit 1 | ||
fi | ||
- name: Build Wheel | ||
run: | | ||
echo "Using python for build:" | ||
python --version | ||
which python | ||
ROCM_VERSION=${{ matrix.rocm }} PYPI_FORCE_TAGS=1 python setup.py sdist bdist_wheel | ||
- name: Upload Assets | ||
uses: shogo82148/actions-upload-release-asset@v1 | ||
with: | ||
upload_url: ${{ needs.release.outputs.upload_url }} | ||
asset_path: ./dist/*.whl |
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,28 @@ | ||
name: Documentation | ||
on: | ||
push: | ||
branches: | ||
- main | ||
permissions: | ||
contents: write | ||
jobs: | ||
deploy: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Git Credentials | ||
run: | | ||
git config user.name github-actions[bot] | ||
git config user.email 41898282+github-actions[bot]@users.noreply.github.com | ||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: 3.x | ||
- run: echo "cache_id=$(date --utc '+%V')" >> $GITHUB_ENV | ||
- uses: actions/cache@v3 | ||
with: | ||
key: mkdocs-material-${{ env.cache_id }} | ||
path: .cache | ||
restore-keys: | | ||
mkdocs-material-docs | ||
- run: pip install mkdocstrings-python mkdocs-material griffe-typingdoc | ||
- run: mkdocs gh-deploy --force |
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,17 @@ | ||
module.exports = async (github, context, core) => { | ||
try { | ||
const response = await github.rest.repos.createRelease({ | ||
draft: false, | ||
generate_release_notes: true, | ||
name: process.env.RELEASE_TAG, | ||
owner: context.repo.owner, | ||
prerelease: false, | ||
repo: context.repo.repo, | ||
tag_name: process.env.RELEASE_TAG, | ||
}); | ||
|
||
core.setOutput('upload_url', response.data.upload_url); | ||
} catch (error) { | ||
core.setFailed(error.message); | ||
} | ||
} |
Oops, something went wrong.