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

[Algorithm] Simpler IQL example #998

Merged
merged 83 commits into from
Dec 14, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
83 commits
Select commit Hold shift + click to select a range
d85e307
fix batch_size
BY571 Mar 28, 2023
bcf6d46
add offline iql example
BY571 Mar 28, 2023
eb7cee0
fix eval reward sum
BY571 Mar 28, 2023
aaf6e0d
merge main
BY571 Mar 30, 2023
77caf62
update iql online average return
BY571 Mar 30, 2023
3a24bca
Merge branch 'main' into rewrite_iql_example
BY571 Apr 20, 2023
f34efa9
update iql examples
BY571 Apr 20, 2023
ddb7f1a
update rewardscale
BY571 May 22, 2023
f7f4a0c
Merge branch 'main' into rewrite_iql_example
BY571 Jun 1, 2023
c084125
update config, script, clear utils
BY571 Jun 2, 2023
9b21360
fix memmap td
BY571 Jun 2, 2023
f3f68be
update eval
BY571 Jun 2, 2023
2af47dc
udpate logger
BY571 Jun 2, 2023
9880756
undo change
BY571 Jun 2, 2023
e476641
fix
BY571 Jun 2, 2023
22cc5df
update scripts
BY571 Jun 2, 2023
d4ca3a6
Merge branch 'rewrite_iql_example' of https://github.com/BY571/rl int…
BY571 Jun 2, 2023
2cc511f
update gym version
BY571 Jun 2, 2023
32f844f
merge main
BY571 Jun 12, 2023
26d8f4f
fix
BY571 Jun 12, 2023
155b4da
Merge branch 'main' into rewrite_iql_example
BY571 Jun 15, 2023
bf80dba
fix logging and adapt config
BY571 Jun 15, 2023
3eaa1e1
update cql and iql offline example
BY571 Jun 15, 2023
8c73156
add example script tests
BY571 Jun 15, 2023
4ce418f
Merge branch 'main' into rewrite_iql_example
BY571 Jun 16, 2023
a01f45f
merge main
BY571 Sep 15, 2023
5e8dc39
update namings andadd time
BY571 Sep 15, 2023
ae82555
fixes
BY571 Sep 15, 2023
bbc85da
update offline
BY571 Sep 15, 2023
6f461de
update cql
BY571 Sep 18, 2023
2ab87b8
fixes
BY571 Sep 18, 2023
7b1af77
update tests and config
BY571 Sep 21, 2023
874fcc4
update
BY571 Sep 21, 2023
4dae15e
update
BY571 Sep 21, 2023
caa39b7
update iql offline config
BY571 Sep 21, 2023
438ad1b
update set gym backend
BY571 Sep 21, 2023
d05fd91
Merge branch 'main' into rewrite_iql_example
BY571 Sep 26, 2023
686d307
update cql bc loss
BY571 Sep 26, 2023
5b63e0a
config fix
BY571 Oct 3, 2023
6ea2176
Merge branch 'main' into rewrite_iql_example
BY571 Oct 3, 2023
4cd605f
observation transform fix
BY571 Oct 3, 2023
ab0ca80
Merge branch 'main' into rewrite_iql_example
BY571 Oct 4, 2023
0fd374c
delete file
BY571 Oct 4, 2023
38d4220
Delete .circleci/config.yml
vmoens Oct 5, 2023
0ad0323
amend
vmoens Oct 5, 2023
ace65ac
amend
vmoens Oct 5, 2023
6601235
Merge remote-tracking branch 'origin/main' into rewrite_iql_example
vmoens Oct 5, 2023
444d05c
update cql separate loss
BY571 Nov 8, 2023
4d7909f
fix
BY571 Nov 8, 2023
0cbe069
Merge branch 'rewrite_iql_example' of https://github.com/BY571/rl int…
BY571 Nov 8, 2023
a8e4e64
update iql loss separation
BY571 Nov 8, 2023
0d70875
merge main and fixes
BY571 Nov 8, 2023
5d97fb4
fix backend
BY571 Nov 8, 2023
93c2b1c
fixes
BY571 Nov 8, 2023
6704d37
fix logger none
BY571 Nov 8, 2023
aeae390
Merge branch 'main' into rewrite_iql_example
BY571 Nov 9, 2023
90fb686
fix cql tests and loss
BY571 Nov 10, 2023
fe14afd
delay_qvalue fix
BY571 Nov 10, 2023
8ebad7a
fix priority setting
BY571 Nov 10, 2023
6736e56
fix naming discrete continuous for helper functions
BY571 Nov 10, 2023
85fc878
small fixes
BY571 Nov 10, 2023
7f27b0f
fix example run tests
BY571 Nov 10, 2023
237fe76
fix num_workers cfg
BY571 Nov 10, 2023
d806994
collector device fix
BY571 Nov 10, 2023
bc209ed
fix
BY571 Nov 10, 2023
c774a3d
fixes
BY571 Nov 10, 2023
b40bf10
device fixes tests
BY571 Nov 10, 2023
433be98
logger fixes tests
BY571 Nov 10, 2023
7fdaf04
td clone fix
BY571 Nov 26, 2023
11967e0
add cql bc loss comment
BY571 Nov 26, 2023
254f8d3
clamp cql lagrange fix
BY571 Nov 26, 2023
5089035
max clamp fix
BY571 Nov 26, 2023
03b865f
fixes
BY571 Nov 26, 2023
6d0c1f0
update metadataupdates
BY571 Nov 30, 2023
76eb7d5
Merge branch 'main' into rewrite_iql_example
BY571 Nov 30, 2023
e80fdcb
merge main
BY571 Dec 7, 2023
2651c3b
fix cql objective actor parameter to module
BY571 Dec 7, 2023
cc83496
fix cql objective actor parameter to module
BY571 Dec 7, 2023
d1be2c6
Merge remote-tracking branch 'origin/main' into rewrite_iql_example
vmoens Dec 14, 2023
ec38f7b
amend
vmoens Dec 14, 2023
826d094
amend
vmoens Dec 14, 2023
fdea50e
amend
vmoens Dec 14, 2023
a85baad
fix cql batch size
vmoens Dec 14, 2023
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
Prev Previous commit
Next Next commit
merge main
  • Loading branch information
BY571 committed Mar 30, 2023
commit aaf6e0d156b7f2649c769bcba450e13be66586dc
63 changes: 63 additions & 0 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -586,6 +586,61 @@ jobs:
- store_test_results:
path: test-results

unittest_linux_sklearn_gpu:
<<: *binary_common
machine:
image: ubuntu-2004-cuda-11.4:202110-01
resource_class: gpu.nvidia.medium
environment:
image_name: "nvidia/cudagl:11.4.0-base"
TAR_OPTIONS: --no-same-owner
PYTHON_VERSION: << parameters.python_version >>
CU_VERSION: << parameters.cu_version >>

steps:
- checkout
- designate_upload_channel
- run:
name: Generate cache key
# This will refresh cache on Sundays, nightly build should generate new cache.
command: echo "$(date +"%Y-%U")" > .circleci-weekly
- restore_cache:
keys:
- env-v3-linux-{{ arch }}-py<< parameters.python_version >>-{{ checksum ".circleci/unittest/linux_libs/scripts_sklearn/environment.yml" }}-{{ checksum ".circleci-weekly" }}
- run:
name: Setup
command: docker run -e PYTHON_VERSION -t --gpus all -v $PWD:$PWD -w $PWD "${image_name}" .circleci/unittest/linux_libs/scripts_sklearn/setup_env.sh
- save_cache:

key: env-v3-linux-{{ arch }}-py<< parameters.python_version >>-{{ checksum ".circleci/unittest/linux_libs/scripts_sklearn/environment.yml" }}-{{ checksum ".circleci-weekly" }}

paths:
- conda
- env
- run:
# Here we create an envlist file that contains some env variables that we want the docker container to be aware of.
# Normally, the CIRCLECI variable is set and available on all CI workflows: https://circleci.com/docs/2.0/env-vars/#built-in-environment-variables.
# They're available in all the other workflows (OSX and Windows).
# But here, we're running the unittest_linux_gpu workflows in a docker container, where those variables aren't accessible.
# So instead we dump the variables we need in env.list and we pass that file when invoking "docker run".
name: export CIRCLECI env var
command: echo "CIRCLECI=true" >> ./env.list
- run:
name: Install torchrl
command: docker run -e PYTHON_VERSION -t --gpus all -v $PWD:$PWD -w $PWD "${image_name}" .circleci/unittest/linux_libs/scripts_sklearn/install.sh
- run:
name: Run tests
command: docker run --env-file ./env.list -t --gpus all -v $PWD:$PWD -w $PWD "${image_name}" .circleci/unittest/linux_libs/scripts_sklearn/run_test.sh
- run:
name: Codecov upload
command: |
bash <(curl -s https://codecov.io/bash) -Z -F sklearn-gpu
- run:
name: Post Process
command: docker run -t --gpus all -v $PWD:$PWD -w $PWD "${image_name}" .circleci/unittest/linux_libs/scripts_sklearn/post_process.sh
- store_test_results:
path: test-results


unittest_linux_jumanji_gpu:
<<: *binary_common
Expand Down Expand Up @@ -1344,6 +1399,14 @@ workflows:
cu_version: cu117
name: unittest_linux_habitat_gpu_py3.8
python_version: '3.8'
# - unittest_linux_d4rl_gpu:
# cu_version: cu117
# name: unittest_linux_d4rl_gpu_py3.8
# python_version: '3.8'
- unittest_linux_sklearn_gpu:
cu_version: cu117
name: unittest_linux_sklearn_gpu_py3.8
python_version: '3.8'
- unittest_linux_d4rl_gpu:
cu_version: cu117
name: unittest_linux_d4rl_gpu_py3.8
Expand Down
1 change: 1 addition & 0 deletions .circleci/unittest/linux_examples/scripts/run_test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -231,6 +231,7 @@ python .circleci/unittest/helpers/coverage_run_parallel.py examples/iql/iql_onli
mode=offline \
collector_devices=cuda:0

python .circleci/unittest/helpers/coverage_run_parallel.py examples/bandits/dqn.py --n_steps=100

coverage combine
coverage xml -i
20 changes: 20 additions & 0 deletions .circleci/unittest/linux_libs/scripts_sklearn/environment.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
channels:
- pytorch
- defaults
dependencies:
- pip
- pip:
- hypothesis
- future
- cloudpickle
- pytest
- pytest-cov
- pytest-mock
- pytest-instafail
- pytest-rerunfailures
- expecttest
- pyyaml
- scipy
- hydra-core
- scikit-learn
- pandas
51 changes: 51 additions & 0 deletions .circleci/unittest/linux_libs/scripts_sklearn/install.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
#!/usr/bin/env bash

unset PYTORCH_VERSION
# For unittest, nightly PyTorch is used as the following section,
# so no need to set PYTORCH_VERSION.
# In fact, keeping PYTORCH_VERSION forces us to hardcode PyTorch version in config.
apt-get update && apt-get install -y git wget gcc g++
#apt-get update && apt-get install -y git wget freeglut3 freeglut3-dev

set -e

eval "$(./conda/bin/conda shell.bash hook)"
conda activate ./env

if [ "${CU_VERSION:-}" == cpu ] ; then
version="cpu"
else
if [[ ${#CU_VERSION} -eq 4 ]]; then
CUDA_VERSION="${CU_VERSION:2:1}.${CU_VERSION:3:1}"
elif [[ ${#CU_VERSION} -eq 5 ]]; then
CUDA_VERSION="${CU_VERSION:2:2}.${CU_VERSION:4:1}"
fi
echo "Using CUDA $CUDA_VERSION as determined by CU_VERSION ($CU_VERSION)"
version="$(python -c "print('.'.join(\"${CUDA_VERSION}\".split('.')[:2]))")"
fi


# submodules
git submodule sync && git submodule update --init --recursive

printf "Installing PyTorch with %s\n" "${CU_VERSION}"
if [ "${CU_VERSION:-}" == cpu ] ; then
# conda install -y pytorch torchvision cpuonly -c pytorch-nightly
# use pip to install pytorch as conda can frequently pick older release
# conda install -y pytorch cpuonly -c pytorch-nightly
pip3 install --pre torch --extra-index-url https://download.pytorch.org/whl/nightly/cpu --force-reinstall
else
pip3 install --pre torch --extra-index-url https://download.pytorch.org/whl/nightly/cu116 --force-reinstall
fi

# install tensordict
pip install git+https://github.com/pytorch-labs/tensordict.git

# smoke test
python -c "import functorch;import tensordict"

printf "* Installing torchrl\n"
pip3 install -e .

# smoke test
python -c "import torchrl"
6 changes: 6 additions & 0 deletions .circleci/unittest/linux_libs/scripts_sklearn/post_process.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/usr/bin/env bash

set -e

eval "$(./conda/bin/conda shell.bash hook)"
conda activate ./env
Loading