-
Notifications
You must be signed in to change notification settings - Fork 520
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
Adding script for processing many intermediate checkpoints at once for offline evals #731
base: main
Are you sure you want to change the base?
Changes from 77 commits
ef7a31c
62d9a1d
dba011b
84a4f1b
9a7b03b
d4687e9
24ec144
6187889
fbfda0e
a862a0b
8d79a01
b4ed78d
2f2a764
b9601c4
8cc86ee
50e7090
8aa450f
f357320
02899a3
9ac3739
ef0b403
c0ff186
15092ae
c489f53
2ed6a50
dd3dc18
9bc11d7
e08895f
0b82c2b
482a487
5c015ca
268d74d
1326da7
ccbeef2
d83f2ed
a42de22
e07796b
c6e773d
798ded3
45a9374
26a1e26
30a9cb9
083ff3e
9c6dc75
54a0d62
25d5a7d
dd9ae8a
402f7b7
f5806da
7718e9f
d8436da
49dff54
c7717a1
b8445ce
855d666
ed5abb7
cbcbc86
d49db7b
cd6a75a
f8e9c96
de82922
d3e16d7
73fc47b
ef8ffbd
fac649d
7597534
94fa6da
5e46840
3c808a8
da90ae2
447de12
3920f2e
acaccdd
a4a40e1
3d2bd32
d529f5a
904ae26
4a32be0
2dc26a9
378aafe
69d12f3
579d612
3b9563d
4a882a3
6acbfcc
6e67a9c
21193cb
1b4da65
7b6e37f
264ce05
2154ea8
d4e1f42
f39a522
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,6 @@ | ||
# beaker yaml | ||
guided-trout-2f805b9.yaml | ||
|
||
# build artifacts | ||
|
||
.eggs/ | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -284,6 +284,12 @@ def main(): | |
help="Keep olmo-specific artifacts in the checkpoint.", | ||
) | ||
|
||
parser.add_argument( | ||
"--cleanup-local-dir", | ||
action="store_true", | ||
help="Remove local download of the directory." | ||
) | ||
|
||
args = parser.parse_args() | ||
|
||
args.destination_dir = args.destination_dir or args.checkpoint_dir | ||
|
@@ -308,6 +314,9 @@ def main(): | |
upload_local_checkpoint(local_checkpoint_dir, args.destination_dir) | ||
|
||
print(f"Converted checkpoint saved to {args.destination_dir}") | ||
if args.cleanup_local_dir: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is there ever a reason not to do this? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I removed the if statement & the flag. |
||
print(f"Removing temporary local dir: {local_checkpoint_dir}") | ||
shutil.rmtree(local_checkpoint_dir) | ||
|
||
|
||
if __name__ == "__main__": | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
#!/bin/bash | ||
pip install torch |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Don't commit temp output. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. sorry. removed |
||
o=======[] | ||
__ _ _ _ |_ [] | ||
/ _` | __ _ _ _ | |_ _ _ | || | [] | ||
\__, | / _` | | ' \ | _| | '_| \_, | _/ ]_ | ||
|___/ \__,_| |_||_| _\__| _|_|_ _|__/ |_____| | ||
_|"""""|_|"""""|_|"""""|_|"""""|_|"""""|_| """"| | ||
`---------------------------------------------' | ||
|
||
Experiment submitted, see progress at https://beaker.org/ex/01J7446KB7EXZ35D8NST0JTNTY |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
torch | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We don't use requirements.txt in OLMo. We use pyproject.toml. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Removed --- it was created to troubleshoot. |
||
datasets | ||
rich | ||
botocore | ||
cached-path | ||
transformers | ||
beaker-gantry |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,95 @@ | ||
#!/usr/bin/env bash | ||
|
||
# Converts s3 checkpoints into WEKA | ||
# To be run at the top of the root of OLMo repository. | ||
# Script requires the use of GANTRY and AWS access to WEKA | ||
# | ||
# Usage: scripts/convert_checkpoints.sh <s3 checkpoint to process> [-s] | ||
# -s if converted checkpoint is found in s3, then save to weka | ||
# -c sanity check; don't actually do conversion. just go through the motions and print stuff | ||
# | ||
# calls: convert_checkpoints_batch.py | ||
# usage: convert_checkpoints_batch.py [-h] | ||
# (--checkpoint-path CHECKPOINT_PATH | --checkpoint-path-file CHECKPOINT_PATH_FILE) | ||
# [--weka-load-dir WEKA_LOAD_DIR] | ||
# [--weka-prefix WEKA_PREFIX] | ||
# [--sanity-check] [--save-to-weka] | ||
# | ||
# Example use: | ||
# Run: | ||
# sh scripts/convert_checkpoints.sh s3://ai2-llm/checkpoints/cheap_decisions/dolma-v1-6-and-sources-baseline-3x-code-1B-N-1T-D-mitchish1-001/step9* | ||
# This will convert all models in the directory and save them to: | ||
# weka://oe-eval-default/ai2-llm/checkpoints/cheap_decisions/dolma-v1-6-and-sources-baseline-3x-code-1B-N-1T-D-mitchish1-001-hf/step9* | ||
# | ||
# It will first, though, check that the weka directory doesn't exist AND that s3 doesn't have a corresponding directory (so as not to replicate what conversions already made) | ||
# | ||
# ASSUMPTIONS | ||
# - INPUT must be on s3. Multiple wildcards allowed | ||
# - OUTPUT to weka is saved to the path as found on s3 with "-hf" suffix appended to the path | ||
# - Assumes tokenizer allenai/gpt-neox-olmo-dolma-v1_5.json | ||
# | ||
# OUTPUT logs | ||
# - saves log.jsonl. For every checkpoint found given input: | ||
# - "unprocessed_path" := checkpoint path to convert | ||
# - "converted_path" := checkpoint converted path | ||
# - "conversion_status" := [new | existing (already in weka) | existing-downloaded (from s3) ] | ||
# - "date" := datestamp | ||
# - "error" := error if any conversions didn't pan out for any reason | ||
# - saves model_checkpoints.jsonl: this is input file is formatted for oe-eval-internal experiments | ||
# - example log files for the following run: | ||
# > sh scripts/convert_checkpoints.sh s3://ai2-llm/checkpoints/OLMo-ladder/baseline-300M-1xC/step91*6-unsharded | ||
# log.jsonl: | ||
# {"unprocessed_path": "s3://ai2-llm/checkpoints/OLMo-ladder/baseline-300M-1xC/step9176-unsharded", "converted_path": "weka://oe-eval-default/ianm/ai2-llm/checkpoints/OLMo-ladder/baseline-300M-1xC/step9176-unsharded-hf", "conversion": "existing", "date_time": "Oct-04-2024_2012", "error": ""} | ||
# {"unprocessed_path": "s3://ai2-llm/checkpoints/OLMo-ladder/baseline-300M-1xC/step9166-unsharded", "converted_path": "weka://oe-eval-default/ianm/ai2-llm/checkpoints/OLMo-ladder/baseline-300M-1xC/step9166-unsharded-hf", "conversion": "existing", "date_time": "Oct-04-2024_2012", "error": ""} | ||
# {"unprocessed_path": "s3://ai2-llm/checkpoints/OLMo-ladder/baseline-300M-1xC/step9186-unsharded", "converted_path": "weka://oe-eval-default/ianm/ai2-llm/checkpoints/OLMo-ladder/baseline-300M-1xC/step9186-unsharded-hf", "conversion": "existing", "date_time": "Oct-04-2024_2012", "error": ""} | ||
# model_checkpoints.jsonl: | ||
# {"model_name": "baseline-300M-1xC", "checkpoints_location": "weka://oe-eval-default/ianm/ai2-llm/checkpoints/OLMo-ladder/baseline-300M-1xC", "revisions": ["step9176-unsharded-hf", "step9166-unsharded-hf", "step9186-unsharded-hf"]} | ||
# | ||
# SH run SPECIFICATION DEFAULTS: | ||
# - Budget for oe-eval (see below) | ||
# - Loading for weka weka://oe-eval-default/ (see below) | ||
# - Gantry experiments saved to beaker://ai2/cheap-decisions | ||
# - Weka prefix is used for model_checkpoints.jsonl | ||
# | ||
# TODOs | ||
# - Make tokenizer updatable | ||
|
||
CHECKPOINT_PATH=$1 | ||
SAVE_TO_WEKA="" | ||
SANITY_CHECK="" | ||
shift | ||
|
||
usage() { | ||
echo "Usage: $0 <s3 checkpoint to process> [-s]" | ||
echo " -s --save-to-weka" | ||
echo " -c --sanity-check" | ||
exit 1; | ||
} | ||
|
||
while getopts "sc" opt; | ||
do | ||
case $opt in | ||
s) SAVE_TO_WEKA="--save-to-weka" ;; | ||
c) SANITY_CHECK="--sanity-check" ;; # mostly useful for local test runs - it will stop from doing any copying or conversions. | ||
*) usage ;; | ||
esac | ||
done | ||
|
||
#echo "python scripts/convert_checkpoints_batch.py --checkpoint-path $CHECKPOINT_PATH --weka-load-dir '/data/input' --weka-prefix 'weka://oe-eval-default' $SAVE_TO_WEKA $SANITY_CHECK" | ||
|
||
gantry run \ | ||
--description "Converting $CHECKPOINT_PATH" \ | ||
--allow-dirty \ | ||
--workspace ai2/cheap-decisions \ | ||
--priority normal \ | ||
--gpus 0 \ | ||
--preemptible \ | ||
--cluster ai2/jupiter-cirrascale-2 \ | ||
--budget ai2/oe-eval \ | ||
--env-secret AWS_ACCESS_KEY_ID=JENA_AWS_ACCESS_KEY_ID \ | ||
--env-secret AWS_SECRET_ACCESS_KEY=JENA_AWS_SECRET_ACCESS_KEY \ | ||
--shared-memory 10GiB \ | ||
--weka=oe-eval-default:/data/input \ | ||
--yes \ | ||
-- /bin/bash -c "python scripts/convert_checkpoints_batch.py --checkpoint-path $CHECKPOINT_PATH --weka-load-dir '/data/input' --weka-prefix 'weka://oe-eval-default' $SAVE_TO_WEKA $SANITY_CHECK" | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
removed