[build-system]
requires = ["hatchling"]
build-backend = "hatchling.build"

[project]
name = "repo"
dynamic = ["classifiers"]
version = "0.4.0"
readme = "README.md"
description = "repo: Desynced Low Communication Adaptive Optimizers for Training Foundation Models."
license = "Apache-2.0"
authors = [
    { name = "Anonymous", email = "anonymous@anon" },
    { name = "Anonymous", email = "anonymous@anon" },
]
requires-python = "<3.13,>=3.10"
dependencies = [
    "hydra-core==1.3.2",
    "types-protobuf<5.0.0.0,>=4.24.0.1",
    "types-pyyaml<7.0.0.0,>=6.0.12.12",
    "types-decorator<6.0.0.0,>=5.1.8.4",
    "types-setuptools<69.0.0.0,>=68.2.0.0",
    "multiprocess<1.0.0,>=0.70.15",
    "nvsmi<1.0.0,>=0.4.2",
    "cloudpickle<4.0.0,>=3.0.0",
    "tqdm<5.0.0,>=4.66.1",
    "psutil<6.0.0,>=5.9.5",
    "pandas<3.0.0,>=2.1.1",
    "librosa<1.0.0,>=0.10.1",
    "nvidia-ml-py==12.560.30",
    "ipykernel<7.0.0,>=6.25.2",
    "matplotlib<4.0.0,>=3.8.0",
    "seaborn<1.0.0,>=0.13.0",
    "jupyter-server<3.0.0,>=2.7.3",
    "ipywidgets<9.0.0,>=8.1.1",
    "ipython<9.0.0,>=8.17.2",
    "torch @ https://download.pytorch.org/whl/cu124/torch-2.6.0%2Bcu124-cp312-cp312-linux_x86_64.whl#sha256=a393b506844035c0dac2f30ea8478c343b8e95a429f06f3b3cadfc7f53adb597",
    "torchaudio @ https://download.pytorch.org/whl/cu124/torchaudio-2.6.0%2Bcu124-cp312-cp312-linux_x86_64.whl#sha256=3e5ffa69606171c74f3e2b969785ead50b782ca657e746aaee1ee7cc88dcfc08",
    "torchvision @ https://download.pytorch.org/whl/cu124/torchvision-0.21.0%2Bcu124-cp312-cp312-linux_x86_64.whl#sha256=efb53ea0af7bf09b7b53e2a18b9be6d245f7d46a90b51d5cf97f37e9b929a991",
    "accelerate<0.26,>=0.25",
    "fsspec==2023.6.0",
    "omegaconf<3,>=2.2.3",
    "slack-sdk<4",
    "boto3<2,>=1.21.45",
    "huggingface-hub<1.0,>=0.17.0",
    "beautifulsoup4<5,>=4.12.2",
    "tenacity<9,>=8.2.3",
    "lm-eval @ git+https://github.com/EleutherAI/lm-evaluation-harness.git@v0.4.2",
    "wheel<1.0.0,>=0.42.0",
    "pip==24.1",
    "py3nvml<1.0.0,>=0.2.7",
    "memray<2.0.0,>=1.11.0",
    "objgraph<4.0.0,>=3.6.0",
    "minio<8.0.0,>=7.2.4",
    "watchdog==3.0.0",
    "ninja<2.0.0.0,>=1.11.1.1",
    "poetry<3.0.0,>=2.0.0",
    "opencensus<1.0.0,>=0.11.4",
]

[tool.hatch.metadata]
allow-direct-references = true # allow direct references to git repos in dependencies

[tool.isort]
line_length = 88
indent = "    "
multi_line_output = 3
include_trailing_comma = true
force_grid_wrap = 0
use_parentheses = true

[tool.black]
line-length = 88
preview = true
target-version = ["py312"]

[tool.pytest.ini_options]
minversion = "6.2"
addopts = "-qq"

[tool.mypy]
ignore_missing_imports = true
show_error_codes = true
strict = false
plugins = "numpy.typing.mypy_plugin"

[tool.pylint."MESSAGES CONTROL"]
disable = "bad-continuation,duplicate-code,too-few-public-methods,useless-import-alias,import-error,no-member,no-name-in-module"
good-names = "f,i,j,k,_,x,y,X,Y"
signature-mutators="hydra.main.main"

[[tool.mypy.overrides]]
module = [
    "importlib.metadata.*",
    "importlib_metadata.*",
]
follow_imports = "skip"
follow_imports_for_stubs = true
disallow_untyped_calls = false

[[tool.mypy.overrides]]
module = "torch.*"
follow_imports = "skip"
follow_imports_for_stubs = true

[[tool.mypy.overrides]]
module = "ray.*"
follow_imports = "skip"
follow_imports_for_stubs = true

[tool.pyright]
exclude = [
    "env-**",
    "venv*",
    ".venv",
    ".git",
    ".hg",
    ".mypy_cache",
    ".nox",
    ".pants.d",
    ".pytype",
    ".ruff_cache",
    ".svn",
    ".tox",
    ".venv",
    "__pypackages__",
    "_build",
    "buck-out",
    "build",
    "dist",
    "node_modules",
    "venv",
    "proto",
    "outputs",
    "wandb",
    "multirun",
]
stubPath = ""
reportMissingTypeStubs = "none"
reportUnusedClass = "warning"
reportUnusedFunction = "warning"
reportUnusedImport = "error"
reportUnusedVariable = "error"
reportDuplicateImport = "error"
reportWildcardImportFromLibrary = "error"
reportUntypedFunctionDecorator = "error"
reportUndefinedVariable = "error"
strictParameterNoneValue = true
reportPropertyTypeMismatch = "error"
reportUntypedNamedTuple = "error"
reportUnnecessaryCast = "error"
reportInvalidTypeVarUse = "error"
reportOverlappingOverload = "error"
reportUninitializedInstanceVariable = "error"
reportInvalidStringEscapeSequence = "error"
reportMissingParameterType = "error"
reportCallInDefaultInitializer = "error"
reportUnnecessaryComparison = "error"
reportSelfClsParameterName = "error"
reportImplicitStringConcatenation = "none"
reportInvalidStubStatement = "error"
reportIncompleteStub = "error"
reportUnsupportedDunderAll = "error"
reportUnusedCoroutine = "error"
reportMissingImports = "error"

[tool.docformatter]
wrap-summaries = 88
wrap-descriptions = 88

[tool.yamlfix]
allow_duplicate_keys = false
line_length = 88
none_representation = "null"
whitelines = 1
section_whitelines = 1
exclude = [
    ".bzr",
    ".direnv",
    ".eggs",
    ".git",
    ".hg",
    ".mypy_cache",
    ".nox",
    ".pants.d",
    ".pytype",
    ".ruff_cache",
    ".svn",
    ".tox",
    ".venv",
    "__pypackages__",
    "_build",
    "buck-out",
    "build",
    "dist",
    "node_modules",
    "venv",
    "proto",
    "outputs",
    "wandb",
    "multirun",
]


[tool.ruff]
target-version = "py312"
line-length = 88
preview = true
lint.select = ["ALL"]
lint.fixable = ["ALL"]
lint.ignore = ["TD003", "FIX002", "S101", "CPY001"]
exclude = [
    ".bzr",
    ".direnv",
    ".eggs",
    ".git",
    ".hg",
    ".mypy_cache",
    ".nox",
    ".pants.d",
    ".pytype",
    ".ruff_cache",
    ".svn",
    ".tox",
    ".venv",
    "__pypackages__",
    "_build",
    "buck-out",
    "build",
    "dist",
    "node_modules",
    "venv",
    "proto",
]

[tool.ruff.format]
preview = true

[tool.vulture]
ignore_decorators = ["@typed_field_validator"]
ignore_names = [
    "client_ids", "cls", "collaborative", "suppress_errors", "proportion", "repeat",
    "choose", "download_retry", "download_timeout", "validate_hash", "keep_zip",
    "_rng_state", "location", "old_engine", "_callbacks", "dataloader_len", "predict_timestamp",
    "global_seed", "pretrained", "count", "last_values", "connect_timeout",
    "read_timeout", "project", "tags", "entity", "resume", "id", "allow_val_change",
    "is_test", "COSMO", "INFINIMATH", "MPT_CAUSAL_LM_3B", "MPT_CAUSAL_LM_350M",
    "SMOLLM_135M", "folder_split", "PYTHON_EDU_BUCKET_NAME", "shuffle", "cache_limit",
    "post_processor", "full_state_update", "MPTForCausalLM", "node_manager_temp_dir",
    "round_parameters_sh", "DROPOUT_FUNCTIONS", "context", "exc_type", "exc_value",
    "traceback", "worker_metrics", "worker_parameters_sh", "worker_num_samples_sh",
    "worker_eval_loss_sh", "to_str", "_generate_next_value_",
    "get_sequence_length_from_dataset", "from_str", "CustomMMLUEvaluationTask",
    "eval_forward", "get_tokenizer_config_from_streams", "get_num_samples_from_streams",
    "set_trainable_params_dict", "MPTForTokenClassification", "SMOLLM_SHARED", "SMOLLM_1B",
    "SMOLLM_13B","compute_logits","load_weights","set_optim_with_state_dict", "ListDictValueType",
    "OptimizerStateType", "reconcile_model_state_with_scheduler"
]
paths = ["repo/"]
sort_by_size = true

[dependency-groups]
dev = [
    "isort<6.0.0,>=5.13.2",
    "black[jupyter]<25.0.0,>=24.10.0",
    "docformatter<2.0.0,>=1.7.5",
    "mypy>=1.11.0",
    "pylint>=3.3.1",
    "flake8==7.1.1",
    "pytest-watch==4.2.0",
    "ruff>=0.9.6",
    "yamlfix>=1.16.0",
    "pre-commit>=3.8.0",
    "pytest<9,>=7.2.1",
    "pytest-codeblocks<0.18,>=0.16.1",
    "pytest-cov<7,>=4",
    "pyright>=1.1.390",
    "vulture>=2.3",
    "toml<0.11,>=0.10.2",
    "packaging<25,>=21",
    "hf-transfer==0.1.9",
]
