generated from upkie/new_agent
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Makefile
109 lines (89 loc) · 4.37 KB
/
Makefile
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
# Makefile for the PPO balancer
#
# SPDX-License-Identifier: Apache-2.0
PROJECT_NAME = ppo_balancer
# You can adjust the number of training environments for best performance on
# your machine, either by editing this file or by passing it to the `make`
# command, e.g. `make <your_target> NB_TRAINING_ENVS=<new_value>`.
NB_TRAINING_ENVS = 6
# Programs
BAZEL = $(CURDIR)/tools/bazelisk
BROWSER = firefox
CONDA_ENV_FILE = conda_env.tar.gz
PYTHON = python3
RASPUNZEL = $(CURDIR)/tools/raspunzel
CURDATE = $(shell date -Iseconds)
CURDIR_NAME = $(shell basename $(CURDIR))
TRAINING_DATE = $(shell date +%Y-%m-%d)
TRAINING_PATH = ${UPKIE_TRAINING_PATH}
# Only used to avoid uploading the training directory to the robot
TRAINING_DIRNAME = $(shell basename ${UPKIE_TRAINING_PATH})
# Help snippet adapted from:
# http://marmelab.com/blog/2016/02/29/auto-documented-makefile.html
.PHONY: help
help:
@echo "Host targets:\n"
@grep -P '^[a-zA-Z0-9_-]+:.*? ## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf " \033[36m%-24s\033[0m %s\n", $$1, $$2}'
@echo "\nRobot targets:\n"
@grep -P '^[a-zA-Z0-9_-]+:.*?### .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?### "}; {printf " \033[36m%-24s\033[0m %s\n", $$1, $$2}'
.DEFAULT_GOAL := help
.PHONY: check_upkie_name
check_upkie_name:
@ if [ -z "${UPKIE_NAME}" ]; then \
echo "ERROR: Environment variable UPKIE_NAME is not set.\n"; \
echo "This variable should contain the robot's hostname or IP address for SSH. "; \
echo "You can define it inline for a one-time use:\n"; \
echo " make some_target UPKIE_NAME=your_robot_hostname\n"; \
echo "Or add the following line to your shell configuration:\n"; \
echo " export UPKIE_NAME=your_robot_hostname\n"; \
exit 1; \
fi
.PHONY: clean_broken_links
clean_broken_links:
find -L $(CURDIR) -type l ! -exec test -e {} \; -delete
.PHONY: build
build: clean_broken_links
$(BAZEL) build --config=pi64 //ppo_balancer:run
.PHONY: clean
clean: ## clean intermediate build files
$(BAZEL) clean --expunge
rm -f $(CONDA_ENV_FILE)
run_policy: ### run saved policy on the real robot
$(RASPUNZEL) run -v -s //ppo_balancer:run
.PHONY: upload
upload: check_upkie_name ## upload agent to the robot
ssh ${UPKIE_NAME} sudo date -s "$(CURDATE)"
ssh ${UPKIE_NAME} mkdir -p $(CURDIR_NAME)
ssh ${UPKIE_NAME} sudo find $(CURDIR_NAME) -type d -name __pycache__ -user root -exec chmod go+wx {} "\;"
rsync -Lrtu --delete-after --exclude bazel-bin/ --exclude bazel-out/ --exclude bazel-testlogs/ --exclude bazel-$(CURDIR_NAME) --exclude bazel-$(CURDIR_NAME)/ --exclude cache/ --exclude .pixi --exclude env/ --exclude activate.sh --exclude $(TRAINING_DIRNAME)/ --progress $(CURDIR)/ ${UPKIE_NAME}:$(CURDIR_NAME)/
tensorboard: ## Start tensorboard on today's trainings
rm -f $(TRAINING_PATH)/today
ln -sf $(TRAINING_PATH)/$(TRAINING_DATE) $(TRAINING_PATH)/today
$(BROWSER) http://localhost:6006 &
tensorboard --logdir $(TRAINING_PATH)/$(TRAINING_DATE)
test_policy: ## test locally saved policy
$(PYTHON) ppo_balancer/run.py
train: ## train a new policy
$(BAZEL) run //ppo_balancer:train -- --nb-envs $(NB_TRAINING_ENVS)
train_and_show: ## train a new policy with simulations shown (slower)
$(BAZEL) run //ppo_balancer:train -- --nb-envs $(NB_TRAINING_ENVS) --show
# Packing and unpacking conda environment for an offline Upkie
# ============================================================
.PHONY: check_mamba_setup
check_mamba_setup:
@ if [ -z "${MAMBA_EXE}" ] || [ -z "${MAMBA_ROOT_PREFIX}" ]; then \
echo "ERROR: Either MAMBA_EXE or MAMBA_ROOT_PREFIX is not set."; \
echo "Is Micromamba installed?"; \
echo "See https://mamba.readthedocs.io/en/latest/installation/micromamba-installation.html"; \
exit 1; \
fi
.PHONY: pack_conda_env
pack_conda_env: check_mamba_setup ## prepare conda environment to install it offline on your Upkie
${MAMBA_EXE} env create -f environment.yaml -n raspios_$(PROJECT_NAME) --platform linux-aarch64 -y
tar -zcf $(CONDA_ENV_FILE) -C ${MAMBA_ROOT_PREFIX}/envs/raspios_$(PROJECT_NAME) .
# ${MAMBA_EXE} env remove -n raspios_$(PROJECT_NAME) -y
.PHONY: check_mamba_setup unpack_conda_env
unpack_conda_env: ### unpack conda environment to remote conda path
-${MAMBA_EXE} env list | grep $(PROJECT_NAME) > /dev/null && micromamba env remove -n $(PROJECT_NAME) -y
mkdir -p ${MAMBA_ROOT_PREFIX}/envs/$(PROJECT_NAME)
tar -zxf $(CONDA_ENV_FILE) -C ${MAMBA_ROOT_PREFIX}/envs/$(PROJECT_NAME)