setup.py 3.04 KB
Newer Older
zhouxiang's avatar
zhouxiang committed
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
import glob
import os.path
from setuptools import setup, Extension
from setuptools import find_packages

import sys
import argparse
parser = argparse.ArgumentParser(description='build pyfastllm wheel')
parser.add_argument('--cuda', dest='cuda', action='store_true', default=False,
                    help='build with cuda support')
args, unknown = parser.parse_known_args()
sys.argv = [sys.argv[0]] + unknown

__VERSION__ = "'0.1.3'"

BASE_DIR = os.path.dirname(os.path.dirname(__file__))

ext_modules = []
try:
    from pybind11.setup_helpers import Pybind11Extension
    source_files = glob.glob(os.path.join(BASE_DIR, "src/**/*.cpp"), recursive=True)
    for file in source_files:
        if file.endswith("cudadevice.cpp"): 
            source_files.remove(file)

    extra_compile_args = ["-w", "-DPY_API"]
    # If any libraries are used, e.g. libabc.so
    include_dirs = [os.path.join(BASE_DIR, "include/"), os.path.join(BASE_DIR, "include/devices/cpu/"), os.path.join(BASE_DIR, "include/models"), os.path.join(BASE_DIR, "include/utils")]
    library_dirs = []
    
    # (optional) if the library is not in the dir like `/usr/lib/`
    # either to add its dir to `runtime_library_dirs` or to the env variable "LD_LIBRARY_PATH"
    # MUST be absolute path
    runtime_library_dirs = []
    libraries = []

    if args.cuda:
        assert False, "Not Implement Yet!"
        extra_compile_args.append("-DUSE_CUDA -Wl,-rpath,$ORIGIN/")

        source_files.append(os.path.join(BASE_DIR, "src/devices/cuda/cudadevice.cpp"))
        include_dirs.append(os.path.join(BASE_DIR, "include/devices/cuda/"))

        library_dirs.append("/usr/local/cuda/lib64/")
        library_dirs.append(os.path.join(BASE_DIR, "pyfastllm/"))

        libraries.append("fastllm_cuda")

    ext_modules = [
        Pybind11Extension(
            "pyfastllm", 
            source_files,
            define_macros=[('VERSION_INFO', __VERSION__)],
            include_dirs=include_dirs,
            library_dirs=library_dirs,
            runtime_library_dirs=runtime_library_dirs,
            libraries=libraries,
            extra_compile_args=extra_compile_args,
            cxx_std=17,
            language='c++'
        ),
    ]
except Exception as e:
    print(f"some errors happened: ")
    print(e)
    sys.exit(1)

cmdclass = {}

setup(
    name='fastllm',  
    version=eval(__VERSION__),
    description='python api for fastllm',
    author='wildkid1024',
    author_email='wildkid1024@outlook.com',
    maintainer='',
    maintainer_email='',
    url='',
    long_description='',
    ext_modules=ext_modules,
    packages = find_packages(), 
    cmdclass=cmdclass,
    setup_requires=["pybind11"],
    install_requires=[""],
    python_requires='>=3.6',
    # data_files = [('', ['libfastllm_cuda.so'])],
    include_package_data=False,
    entry_points={
        'console_scripts':[
            'fastllm-convert = fastllm.convert:main'
        ]
    },
    zip_safe=False,
    classifiers=[
        'AI::ChatGPT'
        'AI::InfereEngine',
        'LLM::ChatGLM',
        'LLM::Moss',
        'LLM::LLama'
    ]
)