-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathquantize.py
33 lines (30 loc) · 2.17 KB
/
quantize.py
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
import argparse
from any_precision.quantization import any_precision_quantize
if __name__ == "__main__":
parser = argparse.ArgumentParser(description="Quantize a model to any precision")
parser.add_argument("model", type=str, help="The model to quantize")
parser.add_argument("--seed_precision", type=int, help="The precision to quantize the seed to")
parser.add_argument("--parent_precision", type=int, help="The precision to quantize the parent to")
parser.add_argument("--mode", type=str, default="pack", help="The mode to run in")
parser.add_argument("--yaml_path", type=str, help="The path to the architecture config yaml file")
parser.add_argument("--cache_dir", type=str, help="The directory to cache results in")
parser.add_argument("--dataset", type=str, help="The dataset to use")
parser.add_argument("--seq_len", type=int, help="The sequence length to use")
parser.add_argument("--num_examples", type=int, help="The number of examples to use")
parser.add_argument("--cpu_count", type=int, help="The number of CPUs to use for parallelization")
parser.add_argument('--overwrite_gradients', action="store_true",
help="Whether to overwrite the gradients stored to disk")
parser.add_argument("--overwrite_quantize", action="store_true",
help="Whether to overwrite the parent model stored to disk")
parser.add_argument("--overwrite_pack", action="store_true",
help="Whether to overwrite the packed model stored to disk")
parser.add_argument("--random_state", type=int,
help="The random state to use for reproducibility\n"
"[WARNING] May not be reproducible across different machines")
parser.add_argument("--group_count", type=int,
help="Experimental: Group count per row - the default is 1")
parser.add_argument("--dns", action="store_true",
help="REALLY Experimental: Whether to run Dense & Sparse quantization")
args = parser.parse_args()
# only pass options that are not None
any_precision_quantize(**{k: v for k, v in args.__dict__.items() if v is not None})