Merge pull request #20 from joelmathewthomas/refactor/venv
refactor/venv
This commit is contained in:
@@ -6,6 +6,7 @@ __pycache__/
|
|||||||
|
|
||||||
# Ignore virtual environment folder
|
# Ignore virtual environment folder
|
||||||
venv/
|
venv/
|
||||||
|
envs/
|
||||||
|
|
||||||
# Ignore other common files
|
# Ignore other common files
|
||||||
*.pyc
|
*.pyc
|
||||||
@@ -14,3 +15,6 @@ venv/
|
|||||||
|
|
||||||
# Ignore VSCode config
|
# Ignore VSCode config
|
||||||
.vscode/
|
.vscode/
|
||||||
|
|
||||||
|
# site-packages.pth
|
||||||
|
site-packages.pth
|
||||||
|
|||||||
@@ -1,63 +1,43 @@
|
|||||||
absl-py==2.1.0
|
|
||||||
amqp==5.3.1
|
amqp==5.3.1
|
||||||
antlr4-python3-runtime==4.9.3
|
antlr4-python3-runtime==4.9.3
|
||||||
asgiref==3.8.1
|
|
||||||
asttokens==3.0.0
|
|
||||||
astunparse==1.6.3
|
|
||||||
audioread==3.0.1
|
audioread==3.0.1
|
||||||
billiard==4.2.1
|
billiard==4.2.1
|
||||||
celery==5.4.0
|
celery==5.4.0
|
||||||
certifi==2024.12.14
|
certifi==2024.12.14
|
||||||
cffi==1.17.1
|
cffi==1.17.1
|
||||||
charset-normalizer==3.4.0
|
charset-normalizer==3.4.1
|
||||||
click==8.1.8
|
click==8.1.8
|
||||||
click-didyoumean==0.3.1
|
click-didyoumean==0.3.1
|
||||||
click-plugins==1.1.1
|
click-plugins==1.1.1
|
||||||
click-repl==0.3.0
|
click-repl==0.3.0
|
||||||
cloudpickle==3.1.0
|
cloudpickle==3.1.1
|
||||||
contourpy==1.3.1
|
contourpy==1.3.1
|
||||||
cycler==0.12.1
|
cycler==0.12.1
|
||||||
decorator==5.1.1
|
decorator==5.1.1
|
||||||
demucs==4.0.1
|
demucs==4.0.1
|
||||||
Django==5.1.4
|
|
||||||
dora_search==0.1.12
|
dora_search==0.1.12
|
||||||
einops==0.8.0
|
einops==0.8.0
|
||||||
executing==2.1.0
|
filelock==3.17.0
|
||||||
filelock==3.16.1
|
fonttools==4.55.6
|
||||||
flatbuffers==24.12.23
|
|
||||||
fonttools==4.55.3
|
|
||||||
fsspec==2024.12.0
|
fsspec==2024.12.0
|
||||||
gast==0.6.0
|
|
||||||
google-pasta==0.2.0
|
|
||||||
grpcio==1.68.1
|
|
||||||
h5py==3.12.1
|
|
||||||
idna==3.10
|
idna==3.10
|
||||||
iniconfig==2.0.0
|
iniconfig==2.0.0
|
||||||
jedi==0.19.2
|
|
||||||
Jinja2==3.1.5
|
Jinja2==3.1.5
|
||||||
joblib==1.4.2
|
joblib==1.4.2
|
||||||
julius==0.2.7
|
julius==0.2.7
|
||||||
keras==3.7.0
|
|
||||||
kiwisolver==1.4.8
|
kiwisolver==1.4.8
|
||||||
kombu==5.4.2
|
kombu==5.4.2
|
||||||
lameenc==1.7.0
|
lameenc==1.8.1
|
||||||
lazy_loader==0.4
|
lazy_loader==0.4
|
||||||
libclang==18.1.1
|
|
||||||
librosa==0.10.2.post1
|
librosa==0.10.2.post1
|
||||||
llvmlite==0.43.0
|
llvmlite==0.44.0
|
||||||
Markdown==3.7
|
|
||||||
markdown-it-py==3.0.0
|
|
||||||
MarkupSafe==3.0.2
|
MarkupSafe==3.0.2
|
||||||
matplotlib==3.10.0
|
matplotlib==3.10.0
|
||||||
matplotlib-inline==0.1.7
|
|
||||||
mdurl==0.1.2
|
|
||||||
ml-dtypes==0.4.1
|
|
||||||
mpmath==1.3.0
|
mpmath==1.3.0
|
||||||
msgpack==1.1.0
|
msgpack==1.1.0
|
||||||
namex==0.0.8
|
|
||||||
networkx==3.4.2
|
networkx==3.4.2
|
||||||
numba==0.60.0
|
numba==0.61.0
|
||||||
numpy==2.0.2
|
numpy==2.1.3
|
||||||
nvidia-cublas-cu12==12.4.5.8
|
nvidia-cublas-cu12==12.4.5.8
|
||||||
nvidia-cuda-cupti-cu12==12.4.127
|
nvidia-cuda-cupti-cu12==12.4.127
|
||||||
nvidia-cuda-nvrtc-cu12==12.4.127
|
nvidia-cuda-nvrtc-cu12==12.4.127
|
||||||
@@ -72,60 +52,36 @@ nvidia-nvjitlink-cu12==12.4.127
|
|||||||
nvidia-nvtx-cu12==12.4.127
|
nvidia-nvtx-cu12==12.4.127
|
||||||
omegaconf==2.3.0
|
omegaconf==2.3.0
|
||||||
openunmix==1.3.0
|
openunmix==1.3.0
|
||||||
opt_einsum==3.4.0
|
|
||||||
optree==0.13.1
|
|
||||||
packaging==24.2
|
packaging==24.2
|
||||||
parso==0.8.4
|
pillow==11.1.0
|
||||||
pexpect==4.9.0
|
|
||||||
pillow==11.0.0
|
|
||||||
platformdirs==4.3.6
|
platformdirs==4.3.6
|
||||||
pluggy==1.5.0
|
pluggy==1.5.0
|
||||||
pooch==1.8.2
|
pooch==1.8.2
|
||||||
prompt_toolkit==3.0.48
|
prompt_toolkit==3.0.50
|
||||||
protobuf==5.29.2
|
|
||||||
ptyprocess==0.7.0
|
|
||||||
pure_eval==0.2.3
|
|
||||||
pycparser==2.22
|
pycparser==2.22
|
||||||
Pygments==2.18.0
|
pyparsing==3.2.1
|
||||||
pyparsing==3.2.0
|
|
||||||
PyQt6==6.8.0
|
|
||||||
PyQt6-Qt6==6.8.1
|
|
||||||
PyQt6_sip==13.9.1
|
|
||||||
pytest==8.3.4
|
pytest==8.3.4
|
||||||
python-dateutil==2.9.0.post0
|
python-dateutil==2.9.0.post0
|
||||||
PyYAML==6.0.2
|
PyYAML==6.0.2
|
||||||
redis==5.2.1
|
redis==5.2.1
|
||||||
requests==2.32.3
|
requests==2.32.3
|
||||||
retrying==1.3.4
|
retrying==1.3.4
|
||||||
rich==13.9.4
|
scikit-learn==1.6.1
|
||||||
scikit-learn==1.6.0
|
scipy==1.15.1
|
||||||
scipy==1.14.1
|
setuptools==75.8.0
|
||||||
setuptools==75.6.0
|
|
||||||
six==1.17.0
|
six==1.17.0
|
||||||
soundfile==0.12.1
|
soundfile==0.13.1
|
||||||
soxr==0.5.0.post1
|
soxr==0.5.0.post1
|
||||||
sqlparse==0.5.3
|
|
||||||
stack-data==0.6.3
|
|
||||||
submitit==1.5.2
|
submitit==1.5.2
|
||||||
sympy==1.13.1
|
sympy==1.13.1
|
||||||
tensorboard==2.18.0
|
|
||||||
tensorboard-data-server==0.7.2
|
|
||||||
tensorflow==2.18.0
|
|
||||||
tensorflow-hub==0.16.1
|
|
||||||
termcolor==2.5.0
|
|
||||||
tf_keras==2.18.0
|
|
||||||
threadpoolctl==3.5.0
|
threadpoolctl==3.5.0
|
||||||
torch==2.5.1
|
torch==2.5.1
|
||||||
torchaudio==2.5.1
|
torchaudio==2.5.1
|
||||||
tqdm==4.67.1
|
tqdm==4.67.1
|
||||||
traitlets==5.14.3
|
|
||||||
treetable==0.2.5
|
treetable==0.2.5
|
||||||
triton==3.1.0
|
triton==3.1.0
|
||||||
typing_extensions==4.12.2
|
typing_extensions==4.12.2
|
||||||
tzdata==2024.2
|
tzdata==2025.1
|
||||||
urllib3==2.3.0
|
urllib3==2.3.0
|
||||||
vine==5.1.0
|
vine==5.1.0
|
||||||
wcwidth==0.2.13
|
wcwidth==0.2.13
|
||||||
Werkzeug==3.1.3
|
|
||||||
wheel==0.45.1
|
|
||||||
wrapt==1.17.0
|
|
||||||
@@ -0,0 +1,51 @@
|
|||||||
|
absl-py==2.1.0
|
||||||
|
astunparse==1.6.3
|
||||||
|
certifi==2024.12.14
|
||||||
|
charset-normalizer==3.4.1
|
||||||
|
flatbuffers==25.1.24
|
||||||
|
gast==0.6.0
|
||||||
|
google-pasta==0.2.0
|
||||||
|
grpcio==1.70.0
|
||||||
|
h5py==3.12.1
|
||||||
|
idna==3.10
|
||||||
|
keras==3.8.0
|
||||||
|
libclang==18.1.1
|
||||||
|
Markdown==3.7
|
||||||
|
markdown-it-py==3.0.0
|
||||||
|
MarkupSafe==3.0.2
|
||||||
|
mdurl==0.1.2
|
||||||
|
ml-dtypes==0.4.1
|
||||||
|
namex==0.0.8
|
||||||
|
numpy==2.0.2
|
||||||
|
nvidia-cublas-cu12==12.5.3.2
|
||||||
|
nvidia-cuda-cupti-cu12==12.5.82
|
||||||
|
nvidia-cuda-nvcc-cu12==12.5.82
|
||||||
|
nvidia-cuda-nvrtc-cu12==12.5.82
|
||||||
|
nvidia-cuda-runtime-cu12==12.5.82
|
||||||
|
nvidia-cudnn-cu12==9.3.0.75
|
||||||
|
nvidia-cufft-cu12==11.2.3.61
|
||||||
|
nvidia-curand-cu12==10.3.6.82
|
||||||
|
nvidia-cusolver-cu12==11.6.3.83
|
||||||
|
nvidia-cusparse-cu12==12.5.1.3
|
||||||
|
nvidia-nccl-cu12==2.21.5
|
||||||
|
nvidia-nvjitlink-cu12==12.5.82
|
||||||
|
opt_einsum==3.4.0
|
||||||
|
optree==0.14.0
|
||||||
|
packaging==24.2
|
||||||
|
protobuf==5.29.3
|
||||||
|
Pygments==2.19.1
|
||||||
|
requests==2.32.3
|
||||||
|
rich==13.9.4
|
||||||
|
setuptools==75.8.0
|
||||||
|
six==1.17.0
|
||||||
|
tensorboard==2.18.0
|
||||||
|
tensorboard-data-server==0.7.2
|
||||||
|
tensorflow==2.18.0
|
||||||
|
tensorflow-hub==0.16.1
|
||||||
|
termcolor==2.5.0
|
||||||
|
tf_keras==2.18.0
|
||||||
|
typing_extensions==4.12.2
|
||||||
|
urllib3==2.3.0
|
||||||
|
Werkzeug==3.1.3
|
||||||
|
wheel==0.45.1
|
||||||
|
wrapt==1.17.2
|
||||||
Executable
+46
@@ -0,0 +1,46 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Check if the script is running in the root directory of the project
|
||||||
|
PROJECT_ROOT="freq-split-enhance"
|
||||||
|
CURRENT_DIR=$(basename "$PWD")
|
||||||
|
|
||||||
|
if [ "$CURRENT_DIR" != "$PROJECT_ROOT" ]; then
|
||||||
|
echo "This script must be run in the root directory of the project: '$PROJECT_ROOT'."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if the envs/ directory exists
|
||||||
|
if [ ! -d "envs" ]; then
|
||||||
|
echo "Directory 'envs/' does not exist. Please make sure it exists and contains the required environments. Please run the scripts/setup_env.sh script."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if the requirements/ directory exists, create it if not
|
||||||
|
if [ ! -d "requirements" ]; then
|
||||||
|
echo "Directory 'requirements/' does not exist. Creating it..."
|
||||||
|
mkdir requirements
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Function to freeze the dependencies of an environment
|
||||||
|
freeze_env_deps() {
|
||||||
|
local env_dir=$1
|
||||||
|
local requirements_file=$2
|
||||||
|
|
||||||
|
echo "Freezing dependencies for environment '$env_dir'..."
|
||||||
|
source "$env_dir/bin/activate" # Activate the environment
|
||||||
|
pip freeze > "$requirements_file" # Freeze the dependencies
|
||||||
|
deactivate # Deactivate the environment
|
||||||
|
echo "Dependencies for '$env_dir' saved to '$requirements_file'."
|
||||||
|
}
|
||||||
|
|
||||||
|
# Loop through all the environments inside envs/
|
||||||
|
for env_dir in envs/*; do
|
||||||
|
if [ -d "$env_dir" ]; then
|
||||||
|
env_name=$(basename "$env_dir")
|
||||||
|
requirements_file="requirements/$env_name.txt"
|
||||||
|
freeze_env_deps "$env_dir" "$requirements_file"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "Dependencies for all environments have been successfully frozen."
|
||||||
|
|
||||||
Executable
+69
@@ -0,0 +1,69 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Check if the script is running in the root directory of the project
|
||||||
|
PROJECT_ROOT="freq-split-enhance"
|
||||||
|
CURRENT_DIR=$(basename "$PWD")
|
||||||
|
|
||||||
|
if [ "$CURRENT_DIR" != "$PROJECT_ROOT" ]; then
|
||||||
|
echo "This script must be run in the root directory of the project: '$PROJECT_ROOT'."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if the envs/ directory exists
|
||||||
|
if [ ! -d "envs" ]; then
|
||||||
|
echo "Directory 'envs/' does not exist. Please make sure it exists and contains the required environments. Please run the scripts/setup_env.sh script."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# List all environments in the envs/ directory
|
||||||
|
echo "Available environments:"
|
||||||
|
env_count=0
|
||||||
|
envs_list=()
|
||||||
|
|
||||||
|
for env_dir in envs/*; do
|
||||||
|
if [ -d "$env_dir" ]; then
|
||||||
|
env_name=$(basename "$env_dir")
|
||||||
|
envs_list+=("$env_name")
|
||||||
|
echo "$((env_count + 1)). $env_name"
|
||||||
|
((env_count++))
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# Check if any environments exist
|
||||||
|
if [ "$env_count" -eq 0 ]; then
|
||||||
|
echo "No environments found in 'envs/'. Please create them first."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Ask the user to select an environment
|
||||||
|
read -p "Select an environment (1-$env_count): " env_choice
|
||||||
|
|
||||||
|
# Validate the user's choice
|
||||||
|
if [[ ! "$env_choice" =~ ^[0-9]+$ ]] || [ "$env_choice" -lt 1 ] || [ "$env_choice" -gt "$env_count" ]; then
|
||||||
|
echo "Invalid choice. Please select a number between 1 and $env_count."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Get the selected environment name
|
||||||
|
selected_env="${envs_list[$((env_choice - 1))]}"
|
||||||
|
|
||||||
|
# Ask the user for the module they want to install
|
||||||
|
read -p "Enter the module you want to install in the '$selected_env' environment: " module_name
|
||||||
|
|
||||||
|
# Function to install a module in the selected environment
|
||||||
|
install_module() {
|
||||||
|
local env_dir=$1
|
||||||
|
local module=$2
|
||||||
|
|
||||||
|
echo "Activating environment '$env_dir' and installing module '$module'..."
|
||||||
|
source "$env_dir/bin/activate" # Activate the environment
|
||||||
|
pip install "$module" # Install the module
|
||||||
|
deactivate # Deactivate the environment
|
||||||
|
echo "Module '$module' installed successfully in '$env_dir'."
|
||||||
|
}
|
||||||
|
|
||||||
|
# Install the module in the selected environment
|
||||||
|
install_module "envs/$selected_env" "$module_name"
|
||||||
|
|
||||||
|
echo "Module installation complete."
|
||||||
|
|
||||||
Executable
+36
@@ -0,0 +1,36 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Check if the script is running in the root directory of the project
|
||||||
|
PROJECT_ROOT="freq-split-enhance"
|
||||||
|
CURRENT_DIR=$(basename "$PWD")
|
||||||
|
|
||||||
|
if [ "$CURRENT_DIR" != "$PROJECT_ROOT" ]; then
|
||||||
|
echo "This script must be run in the root directory of the project: '$PROJECT_ROOT'."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Setting up virtual environments"
|
||||||
|
|
||||||
|
mkdir envs
|
||||||
|
|
||||||
|
#Create common env
|
||||||
|
echo "Creating common virtual environment env"
|
||||||
|
python -m venv envs/env
|
||||||
|
|
||||||
|
#Create env for tensorflow
|
||||||
|
echo "Creating virtual environment env_tensorflow"
|
||||||
|
python -m venv envs/env_tensorflow
|
||||||
|
|
||||||
|
source envs/env/bin/activate
|
||||||
|
echo "Installing dependencies in virtual environment env"
|
||||||
|
pip install -r requirements/env.txt
|
||||||
|
deactivate
|
||||||
|
|
||||||
|
source envs/env_tensorflow/bin/activate
|
||||||
|
pip install -r requirements/env_tensorflow.txt
|
||||||
|
deactivate
|
||||||
|
|
||||||
|
echo "Creating site-packages.pth"
|
||||||
|
touch site-packages.pth
|
||||||
|
echo "env/env/lib/python3.12/site-packages" >> site-packages.pth
|
||||||
|
echo "env/env_tensorflow/lib/python3.12/site-packages" >> site-packages.pth
|
||||||
Reference in New Issue
Block a user