data4co provides convenient dataset generators for the combinatorial optimization problem
Project description
Data4CO
A data generator tool for Combinatorial Optimization (CO) problems, enabling customizable, diverse, and scalable datasets for benchmarking optimization algorithms.
Current support
version: 0.0.1-alpha
Problem | Solver1 | Impl. | Solver2 | Impl. | Solver3 | Impl. |
---|---|---|---|---|---|---|
TSP | LKH | ✔ | Concorde | ✔ | Gurobi | 📆 |
MIS | KaMIS | ✔ | Gurobi | 📆 | -- | -- |
Problem | Type1 | Impl. | Type2 | Impl. | Type3 | Impl. | Type4 | Impl. |
---|---|---|---|---|---|---|---|---|
TSP | uniform | ✔ | gaussian | ✔ | cluster | 📆 | -- | -- |
MIS | ER | ✔ | BA | ✔ | HK | ✔ | WS | ✔ |
✔: Supported; 📆: Planned for future versions (contributions welcomed!).
How to Install
Github
Clone with the url https://github.com/heatingma/Data4CO.git , and the following packages are required, and shall be automatically installed by pip
:
Python >= 3.8
numpy>=1.24.4
networkx==2.8.8
lkh>=1.1.1
tsplib95==0.7.1
tqdm>=4.66.1
PyPI
It is very convenient to directly use the following commands
pip install data4co
How to Use
TSP
from data4co import TSPDataGenerator
tsp_data_lkh = TSPDataGenerator(
batch_size=16,
nodes_num=50,
data_type="uniform",
solver_type="lkh",
train_samples_num=128000,
val_samples_num=1280,
test_samples_num=1280,
save_path="your/path/to/save"
)
tsp_data_lkh.generate()
MIS
from data4co import MISDataGenerator
mis_data_kamis = MISDataGenerator(
nodes_num_min=700,
nodes_num_max=800,
data_type="er",
solver_type="kamis",
train_samples_num=128000,
val_samples_num=1280,
test_samples_num=1280,
save_path="your/path/to/save",
solve_limit_time=10.0
)
mis_data_kamis.generate()
mis_data_kamis.solve()
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
data4co-0.0.1a6.tar.gz
(3.2 MB
view hashes)
Built Distributions
Close
Hashes for data4co-0.0.1a6-cp310-cp310-manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | eba146f380d61ce4007314ebad1fd7ee11e846c1b9e49e740f09d01d13bcb315 |
|
MD5 | 9d5916e8187ef3a88d2c36bf37e7214e |
|
BLAKE2b-256 | b807c88ee2182f847eac718664e54223761434ccb83daf091044ec24d9580c4e |
Close
Hashes for data4co-0.0.1a6-cp39-cp39-manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2965239a389fbb447f367a98141bcd6b3aea25d541c76b7826951e4fca670bb0 |
|
MD5 | a8decb2435669cf1522239c570e8471a |
|
BLAKE2b-256 | 74666cae8fae4aa6688c8088d19e5c204c6e11892b78e071884b527bf6640980 |
Close
Hashes for data4co-0.0.1a6-cp38-cp38-manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d79ef0690df3b150f1388a255457cd1b86c5d3cf37f3398a820be0e5030fc8c4 |
|
MD5 | 6ee1bd5854d48b32b43151cf0882a206 |
|
BLAKE2b-256 | e3bb5544982e13b7490dd80f1418668e5a25dd429d24bed0eb3599cd1bf89d48 |