mirror of
https://github.com/open-mmlab/mmclassification.git
synced 2025-06-03 21:53:55 +08:00
* [Feat] Migrate blip caption to mmpretrain. (#50) * Migrate blip caption to mmpretrain * minor fix * support train * [Feature] Support OFA caption task. (#51) * [Feature] Support OFA caption task. * Remove duplicated files. * [Feature] Support OFA vqa task. (#58) * [Feature] Support OFA vqa task. * Fix lint. * [Feat] Add BLIP retrieval to mmpretrain. (#55) * init * minor fix for train * fix according to comments * refactor * Update Blip retrieval. (#62) * [Feature] Support OFA visual grounding task. (#59) * [Feature] Support OFA visual grounding task. * minor add TODO --------- Co-authored-by: yingfhu <yingfhu@gmail.com> * [Feat] Add flamingos coco caption and vqa. (#60) * first init * init flamingo coco * add vqa * minor fix * remove unnecessary modules * Update config * Use `ApplyToList`. --------- Co-authored-by: mzr1996 <mzr1996@163.com> * [Feature]: BLIP2 coco retrieval (#53) * [Feature]: Add blip2 retriever * [Feature]: Add blip2 all modules * [Feature]: Refine model * [Feature]: x1 * [Feature]: Runnable coco ret * [Feature]: Runnable version * [Feature]: Fix lint * [Fix]: Fix lint * [Feature]: Use 364 img size * [Feature]: Refactor blip2 * [Fix]: Fix lint * refactor files * minor fix * minor fix --------- Co-authored-by: yingfhu <yingfhu@gmail.com> * Remove * fix blip caption inputs (#68) * [Feat] Add BLIP NLVR support. (#67) * first init * init flamingo coco * add vqa * add nlvr * refactor nlvr * minor fix * minor fix * Update dataset --------- Co-authored-by: mzr1996 <mzr1996@163.com> * [Feature]: BLIP2 Caption (#70) * [Feature]: Add language model * [Feature]: blip2 caption forward * [Feature]: Reproduce the results * [Feature]: Refactor caption * refine config --------- Co-authored-by: yingfhu <yingfhu@gmail.com> * [Feat] Migrate BLIP VQA to mmpretrain (#69) * reformat * change * change * change * change * change * change * change * change * change * change * change * change * change * change * change * change * change * change * change * refactor code --------- Co-authored-by: yingfhu <yingfhu@gmail.com> * Update RefCOCO dataset * [Fix] fix lint * [Feature] Implement inference APIs for multi-modal tasks. (#65) * [Feature] Implement inference APIs for multi-modal tasks. * [Project] Add gradio demo. * [Improve] Update requirements * Update flamingo * Update blip * Add NLVR inferencer * Update flamingo * Update hugging face model register * Update ofa vqa * Update BLIP-vqa (#71) * Update blip-vqa docstring (#72) * Refine flamingo docstring (#73) * [Feature]: BLIP2 VQA (#61) * [Feature]: VQA forward * [Feature]: Reproduce accuracy * [Fix]: Fix lint * [Fix]: Add blank line * minor fix --------- Co-authored-by: yingfhu <yingfhu@gmail.com> * [Feature]: BLIP2 docstring (#74) * [Feature]: Add caption docstring * [Feature]: Add docstring to blip2 vqa * [Feature]: Add docstring to retrieval * Update BLIP-2 metafile and README (#75) * [Feature]: Add readme and docstring * Update blip2 results --------- Co-authored-by: mzr1996 <mzr1996@163.com> * [Feature] BLIP Visual Grounding on MMPretrain Branch (#66) * blip grounding merge with mmpretrain * remove commit * blip grounding test and inference api * refcoco dataset * refcoco dataset refine config * rebasing * gitignore * rebasing * minor edit * minor edit * Update blip-vqa docstring (#72) * rebasing * Revert "minor edit" This reverts commit 639cec757c215e654625ed0979319e60f0be9044. * blip grounding final * precommit * refine config * refine config * Update blip visual grounding --------- Co-authored-by: Yiqin Wang 王逸钦 <wyq1217@outlook.com> Co-authored-by: mzr1996 <mzr1996@163.com> * Update visual grounding metric * Update OFA docstring, README and metafiles. (#76) * [Docs] Update installation docs and gradio demo docs. (#77) * Update OFA name * Update Visual Grounding Visualizer * Integrate accelerate support * Fix imports. * Fix timm backbone * Update imports * Update README * Update circle ci * Update flamingo config * Add gradio demo README * [Feature]: Add scienceqa (#1571) * [Feature]: Add scienceqa * [Feature]: Change param name * Update docs * Update video --------- Co-authored-by: Hubert <42952108+yingfhu@users.noreply.github.com> Co-authored-by: yingfhu <yingfhu@gmail.com> Co-authored-by: Yuan Liu <30762564+YuanLiuuuuuu@users.noreply.github.com> Co-authored-by: Yiqin Wang 王逸钦 <wyq1217@outlook.com> Co-authored-by: Rongjie Li <limo97@163.com>
199 lines
7.4 KiB
Python
199 lines
7.4 KiB
Python
import os
|
|
import os.path as osp
|
|
import shutil
|
|
import sys
|
|
import warnings
|
|
from setuptools import find_packages, setup
|
|
|
|
|
|
def readme():
|
|
with open('README.md', encoding='utf-8') as f:
|
|
content = f.read()
|
|
return content
|
|
|
|
|
|
def get_version():
|
|
version_file = 'mmpretrain/version.py'
|
|
with open(version_file, 'r', encoding='utf-8') as f:
|
|
exec(compile(f.read(), version_file, 'exec'))
|
|
return locals()['__version__']
|
|
|
|
|
|
def parse_requirements(fname='requirements.txt', with_version=True):
|
|
"""Parse the package dependencies listed in a requirements file but strips
|
|
specific versioning information.
|
|
|
|
Args:
|
|
fname (str): path to requirements file
|
|
with_version (bool, default=False): if True include version specs
|
|
|
|
Returns:
|
|
List[str]: list of requirements items
|
|
|
|
CommandLine:
|
|
python -c "import setup; print(setup.parse_requirements())"
|
|
"""
|
|
import re
|
|
import sys
|
|
from os.path import exists
|
|
require_fpath = fname
|
|
|
|
def parse_line(line):
|
|
"""Parse information from a line in a requirements text file."""
|
|
if line.startswith('-r '):
|
|
# Allow specifying requirements in other files
|
|
target = line.split(' ')[1]
|
|
for info in parse_require_file(target):
|
|
yield info
|
|
else:
|
|
info = {'line': line}
|
|
if line.startswith('-e '):
|
|
info['package'] = line.split('#egg=')[1]
|
|
else:
|
|
# Remove versioning from the package
|
|
pat = '(' + '|'.join(['>=', '==', '>']) + ')'
|
|
parts = re.split(pat, line, maxsplit=1)
|
|
parts = [p.strip() for p in parts]
|
|
|
|
info['package'] = parts[0]
|
|
if len(parts) > 1:
|
|
op, rest = parts[1:]
|
|
if ';' in rest:
|
|
# Handle platform specific dependencies
|
|
# http://setuptools.readthedocs.io/en/latest/setuptools.html#declaring-platform-specific-dependencies
|
|
version, platform_deps = map(str.strip,
|
|
rest.split(';'))
|
|
info['platform_deps'] = platform_deps
|
|
else:
|
|
version = rest # NOQA
|
|
if '--' in version:
|
|
# the `extras_require` doesn't accept options.
|
|
version = version.split('--')[0].strip()
|
|
info['version'] = (op, version)
|
|
yield info
|
|
|
|
def parse_require_file(fpath):
|
|
with open(fpath, 'r') as f:
|
|
for line in f.readlines():
|
|
line = line.strip()
|
|
if line and not line.startswith('#'):
|
|
for info in parse_line(line):
|
|
yield info
|
|
|
|
def gen_packages_items():
|
|
if exists(require_fpath):
|
|
for info in parse_require_file(require_fpath):
|
|
parts = [info['package']]
|
|
if with_version and 'version' in info:
|
|
parts.extend(info['version'])
|
|
if not sys.version.startswith('3.4'):
|
|
# apparently package_deps are broken in 3.4
|
|
platform_deps = info.get('platform_deps')
|
|
if platform_deps is not None:
|
|
parts.append(';' + platform_deps)
|
|
item = ''.join(parts)
|
|
yield item
|
|
|
|
packages = list(gen_packages_items())
|
|
return packages
|
|
|
|
|
|
def add_mim_extension():
|
|
"""Add extra files that are required to support MIM into the package.
|
|
|
|
These files will be added by creating a symlink to the originals if the
|
|
package is installed in `editable` mode (e.g. pip install -e .), or by
|
|
copying from the originals otherwise.
|
|
"""
|
|
|
|
# parse installment mode
|
|
if 'develop' in sys.argv:
|
|
# installed by `pip install -e .`
|
|
mode = 'symlink'
|
|
elif 'sdist' in sys.argv or 'bdist_wheel' in sys.argv:
|
|
# installed by `pip install .`
|
|
# or create source distribution by `python setup.py sdist`
|
|
mode = 'copy'
|
|
else:
|
|
return
|
|
|
|
filenames = ['tools', 'configs', 'model-index.yml']
|
|
repo_path = osp.dirname(__file__)
|
|
mim_path = osp.join(repo_path, 'mmpretrain', '.mim')
|
|
os.makedirs(mim_path, exist_ok=True)
|
|
|
|
for filename in filenames:
|
|
if osp.exists(filename):
|
|
src_path = osp.join(repo_path, filename)
|
|
tar_path = osp.join(mim_path, filename)
|
|
|
|
if osp.isfile(tar_path) or osp.islink(tar_path):
|
|
os.remove(tar_path)
|
|
elif osp.isdir(tar_path):
|
|
shutil.rmtree(tar_path)
|
|
|
|
if mode == 'symlink':
|
|
src_relpath = osp.relpath(src_path, osp.dirname(tar_path))
|
|
try:
|
|
os.symlink(src_relpath, tar_path)
|
|
except OSError:
|
|
# Creating a symbolic link on windows may raise an
|
|
# `OSError: [WinError 1314]` due to privilege. If
|
|
# the error happens, the src file will be copied
|
|
mode = 'copy'
|
|
warnings.warn(
|
|
f'Failed to create a symbolic link for {src_relpath}, '
|
|
f'and it will be copied to {tar_path}')
|
|
else:
|
|
continue
|
|
|
|
if mode == 'copy':
|
|
if osp.isfile(src_path):
|
|
shutil.copyfile(src_path, tar_path)
|
|
elif osp.isdir(src_path):
|
|
shutil.copytree(src_path, tar_path)
|
|
else:
|
|
warnings.warn(f'Cannot copy file {src_path}.')
|
|
else:
|
|
raise ValueError(f'Invalid mode {mode}')
|
|
|
|
|
|
if __name__ == '__main__':
|
|
add_mim_extension()
|
|
setup(
|
|
name='mmpretrain',
|
|
version=get_version(),
|
|
description='OpenMMLab Model Pretraining Toolbox and Benchmark',
|
|
long_description=readme(),
|
|
long_description_content_type='text/markdown',
|
|
keywords='computer vision, image classification, '
|
|
'unsupervised learning, self-supervised learning',
|
|
packages=find_packages(exclude=('configs', 'tools', 'demo', 'tests')),
|
|
include_package_data=True,
|
|
python_requires='>=3.7',
|
|
classifiers=[
|
|
'Development Status :: 4 - Beta',
|
|
'License :: OSI Approved :: Apache Software License',
|
|
'Operating System :: OS Independent',
|
|
'Programming Language :: Python :: 3',
|
|
'Programming Language :: Python :: 3.7',
|
|
'Programming Language :: Python :: 3.8',
|
|
'Programming Language :: Python :: 3.9',
|
|
'Programming Language :: Python :: 3.10',
|
|
'Programming Language :: Python :: 3.11',
|
|
'Topic :: Scientific/Engineering :: Artificial Intelligence',
|
|
],
|
|
url='https://github.com/open-mmlab/mmpretrain',
|
|
author='MMPretrain Contributors',
|
|
author_email='openmmlab@gmail.com',
|
|
license='Apache License 2.0',
|
|
install_requires=parse_requirements('requirements/runtime.txt'),
|
|
extras_require={
|
|
'all': parse_requirements('requirements.txt'),
|
|
'tests': parse_requirements('requirements/tests.txt'),
|
|
'optional': parse_requirements('requirements/optional.txt'),
|
|
'mim': parse_requirements('requirements/mminstall.txt'),
|
|
'multimodal': parse_requirements('requirements/multimodal.txt'),
|
|
},
|
|
zip_safe=False)
|