forked from hpcaitech/Open-Sora
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathinstall-pytorch23.sh
126 lines (108 loc) · 4.12 KB
/
install-pytorch23.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#!/bin/bash
# Description: Setup Open-Sora Environment
ENV_NAME="osora-12i"
PYTHON_VER="python=3.10"
export MAX_JOBS=$(nproc) && echo "MAX_JOBS set to $MAX_JOBS"
CONDA_HOME=$(conda info --base)
CUDA_HOME=$CONDA_HOME
conda_pip() {
"$CONDA_HOME/envs/$ENV_NAME/bin/python" -m pip "$@"
}
# Function to infer and set CUDA_HOME from the Conda environment
set_cuda_home() {
# Construct the path to the Conda environment
ENV_PATH="$CONDA_HOME/envs/$ENV_NAME"
# Check for common CUDA installation directories within the Conda environment
if [ -d "$ENV_PATH" ]; then
# Check for the existence of CUDA bin directory
if [ -d "$ENV_PATH/lib" ]; then
export CUDA_HOME="$ENV_PATH"
export PATH="$CUDA_HOME/bin:$PATH"
PROFILER_PATH=$(dirname $(find $CUDA_HOME -name "cuda_profiler_api.h"))
export LD_LIBRARY_PATH="$PROFILER_PATH/lib:$CUDA_HOME/lib:$CUDA_HOME/lib64:$LD_LIBRARY_PATH"
export CXXFLAGS="-I$PROFILER_PATH"
export CPPFLAGS="-I$PROFILER_PATH"
echo "CUDA_HOME set to $CUDA_HOME"
else
echo "CUDA installation not found in Conda environment $ENV_NAME"
fi
else
echo "Conda environment $ENV_NAME not found"
fi
}
# Create a virtual environment
conda init
conda create -y --name "$ENV_NAME" "$PYTHON_VER"
conda activate "$ENV_NAME"
# Install dependencies with CUDA 12.1.0 via the NVIDIA channel
conda install -n $ENV_NAME -c nvidia cuda-toolkit=12.1.0 \
cuda-command-line-tools=12.1.0 \
cuda-compiler=12.1.0 \
cuda-documentation=12.1.55 \
cuda-cuxxfilt=12.1.55 \
cuda-nvcc=12.1.66 \
cuda-tools=12.1.0 \
libnvvm-samples=12.1.55 \
libnvjitlink=12.1.105 \
cuda-libraries=12.1.0 \
cuda-libraries-dev=12.1.0 \
cuda-cccl=12.1.55 \
cuda-profiler-api=12.1.55 \
cuda-nvprof=12.1.55 \
cuda-cudart=12.1 \
cuda-cudart-dev=12.1 \
cuda-cudart-static=12.1 \
cuda-cupti=12.1 \
cuda-nvrtc=12.1 \
cuda-nvrtc-dev=12.1 \
cuda-nvtx=12.1 \
cuda-driver-dev=12.1 \
cuda-gdb=12.1 \
cuda-cuobjdump=12.1 \
cuda-libraries-dev=12.1 \
cuda-libraries-static=12.1 \
cuda-nvml-dev=12.1 \
cuda-nvprune=12.1 \
cuda-nvrtc-dev=12.1 \
cuda-nvrtc-static=12.1 \
cuda-nvvp=12.1 \
cuda-opencl=12.1 \
cuda-opencl-dev=12.1 \
cuda-sanitizer-api=12.1 \
cuda-nsight=12.1 \
cuda-nsight-compute=12.1 \
cuda-version=12.1
set_cuda_home
# install nccl
if [ ! -d "$CONDA_HOME/../tools" ]; then
mkdir -p $CONDA_HOME/../tools/
fi
git clone https://github.com/NVIDIA/nccl $CONDA_HOME/../tools/nccl
cd nccl
git checkout v2.20.5-1
make -j`nproc`
export NCCL_INCLUDE_DIR="$CONDA_HOME/../tools/nccl/build/include/"
export NCCL_LIB_DIR="$CONDA_HOME/../tools/nccl/build/lib/"
export CUDA_NVCC_EXECUTABLE=$(which nvcc)
# Install PyTorch for CUDA 12.1.0
# conda install -n $ENV_NAME pytorch==2.3.1 torchvision pytorch-cuda=12.1 -c pytorch -c nvidia -y
USE_SYSTEM_NCCL=1 && pip3 install --force-reinstall --no-cache-dir torch==2.3.1 torchvision
# Optional installations
conda_pip install --force packaging
conda_pip install --force ninja
# xformers
LD_PRELOAD=$(gcc -print-file-name=libstdc++.so.6) TORCH_CUDA_ARCH_LIST=9.0 PATH="$CUDA_HOME/bin:$PATH" LD_LIBRARY_PATH="$CUDA_HOME/lib" conda_pip install --force --no-deps -U xformers==0.0.26.post1 --index-url https://download.pytorch.org/whl/cu121
# apex
conda_pip install --force -v --disable-pip-version-check --no-cache-dir --no-build-isolation --config-settings '--build-option=--cpp_ext' --config-settings '--build-option=--cuda_ext' git+https://github.com/NVIDIA/apex.git
# flash_attn
FLASH_ATTN_WHEEL=flash_attn-2.5.8+cu122torch2.3cxx11abiFALSE-cp310-cp310-linux_x86_64.whl
wget https://github.com/Dao-AILab/flash-attention/releases/download/v2.5.8/$FLASH_ATTN_WHEEL
conda_pip install --no-deps $FLASH_ATTN_WHEEL
rm $FLASH_ATTN_WHEEL
# install open-sora dependencies
conda_pip install -r requirements/requirements.txt
# Clone and install Open-Sora
CUDA_EXT=1 BUILD_EXT=1 conda_pip install -v -e .
conda_pip install --force protobuf==3.20.3
conda_pip install yapf==0.32
echo "Open-Sora (LambdaLabsML branch) environment setup completed. Please check success using check_install.sh"