2023-04-05 04:17:26 -04:00
|
|
|
import os
|
|
|
|
import argparse
|
|
|
|
import llama_cpp
|
|
|
|
|
|
|
|
|
|
|
|
def main(args):
|
2024-04-28 02:48:47 +02:00
|
|
|
fname_inp = args.fname_inp.encode("utf-8")
|
|
|
|
fname_out = args.fname_out.encode("utf-8")
|
2023-04-05 04:17:26 -04:00
|
|
|
if not os.path.exists(fname_inp):
|
|
|
|
raise RuntimeError(f"Input file does not exist ({fname_inp})")
|
|
|
|
if os.path.exists(fname_out):
|
|
|
|
raise RuntimeError(f"Output file already exists ({fname_out})")
|
2024-04-28 02:48:47 +02:00
|
|
|
ftype = args.type
|
|
|
|
args = llama_cpp.llama_model_quantize_default_params()
|
|
|
|
args.ftype = ftype
|
|
|
|
return_code = llama_cpp.llama_model_quantize(fname_inp, fname_out, args)
|
2023-04-05 04:17:26 -04:00
|
|
|
if return_code != 0:
|
|
|
|
raise RuntimeError("Failed to quantize model")
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
parser.add_argument("fname_inp", type=str, help="Path to input model")
|
|
|
|
parser.add_argument("fname_out", type=str, help="Path to output model")
|
2024-04-28 02:48:47 +02:00
|
|
|
parser.add_argument("type", type=int, help="Type of quantization (2: q4_0, 3: q4_1), see llama_cpp.py for enum")
|
2023-04-05 04:17:26 -04:00
|
|
|
args = parser.parse_args()
|
|
|
|
main(args)
|
2024-04-28 02:48:47 +02:00
|
|
|
|