Commit a0b6480
feat: Implement integer programming solver for Coloring problem (#20)
* feat: Implement integer programming solver for Coloring problem
Add ILP reduction for the Graph K-Coloring problem with:
- Binary variables x_{v,c} for each (vertex, color) pair
- Constraints ensuring each vertex has exactly one color
- Constraints ensuring adjacent vertices have different colors
- Comprehensive test suite covering various graph types
Closes #19
🤖 Generated with [Claude Code](https://claude.com/claude-code)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* docs: Add Coloring -> ILP to reduction graph and documentation
- Register Coloring -> ILP in inventory for automatic discovery
- Add ILP as a problem type in reduction graph
- Add theorem and proof for Coloring -> ILP reduction in reductions.typ
- Update reduction graph diagram and registered reductions table
- Regenerate reduction_graph.json with ILP node
🤖 Generated with [Claude Code](https://claude.com/claude-code)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
* fix: Resolve clippy needless_range_loop warning
Refactor extract_solution to use functional style with map/find
instead of indexing into a mutable vector.
🤖 Generated with [Claude Code](https://claude.com/claude-code)
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>1 parent c758eae commit a0b6480
5 files changed
Lines changed: 461 additions & 0 deletions
File tree
- docs
- paper
- src/reductions
- src/rules
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
82 | 82 | | |
83 | 83 | | |
84 | 84 | | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
85 | 90 | | |
86 | 91 | | |
87 | 92 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
170 | 170 | | |
171 | 171 | | |
172 | 172 | | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
173 | 177 | | |
174 | 178 | | |
175 | 179 | | |
| |||
331 | 335 | | |
332 | 336 | | |
333 | 337 | | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
334 | 356 | | |
335 | 357 | | |
336 | 358 | | |
| |||
400 | 422 | | |
401 | 423 | | |
402 | 424 | | |
| 425 | + | |
403 | 426 | | |
404 | 427 | | |
405 | 428 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
61 | 61 | | |
62 | 62 | | |
63 | 63 | | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
64 | 67 | | |
65 | 68 | | |
66 | 69 | | |
| |||
129 | 132 | | |
130 | 133 | | |
131 | 134 | | |
| 135 | + | |
132 | 136 | | |
133 | 137 | | |
134 | 138 | | |
| |||
0 commit comments