Commit 92b0ee5
committed
Add per-node origin cap (nOriginsMax) to bound accumulation
Shared fanin cones can accumulate origins from all CO drivers,
causing O(n²) dedup cost in Gia_ObjAddOrigin. Add nOriginsMax
field to Gia_Man_t that short-circuits overflow-mode AddOrigin
when the node has reached the limit. Cap is set via &origins_id -M.
Pathological case (10K outputs, shared 50-deep cone):
No cap: 5.70s, 1.01M total origins, max 10000/node
-M 256: 0.79s, 45K total origins, max 256/node (7.2x faster)
Normal designs (i10.aig, max 165/node): identical results.
Co-developed-by: Claude Code v2.1.89 (claude-opus-4-6)1 parent 4496674 commit 92b0ee5
3 files changed
Lines changed: 57 additions & 7 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
220 | 220 | | |
221 | 221 | | |
222 | 222 | | |
| 223 | + | |
223 | 224 | | |
224 | 225 | | |
225 | 226 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
213 | 213 | | |
214 | 214 | | |
215 | 215 | | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
216 | 219 | | |
217 | 220 | | |
218 | 221 | | |
| |||
331 | 334 | | |
332 | 335 | | |
333 | 336 | | |
| 337 | + | |
334 | 338 | | |
335 | 339 | | |
336 | 340 | | |
| |||
364 | 368 | | |
365 | 369 | | |
366 | 370 | | |
| 371 | + | |
367 | 372 | | |
368 | 373 | | |
369 | 374 | | |
| |||
399 | 404 | | |
400 | 405 | | |
401 | 406 | | |
| 407 | + | |
402 | 408 | | |
403 | 409 | | |
404 | 410 | | |
| |||
456 | 462 | | |
457 | 463 | | |
458 | 464 | | |
| 465 | + | |
459 | 466 | | |
460 | 467 | | |
461 | 468 | | |
| |||
1108 | 1115 | | |
1109 | 1116 | | |
1110 | 1117 | | |
| 1118 | + | |
1111 | 1119 | | |
1112 | 1120 | | |
1113 | 1121 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
35536 | 35536 | | |
35537 | 35537 | | |
35538 | 35538 | | |
35539 | | - | |
| 35539 | + | |
35540 | 35540 | | |
35541 | | - | |
| 35541 | + | |
35542 | 35542 | | |
35543 | 35543 | | |
35544 | 35544 | | |
| 35545 | + | |
| 35546 | + | |
| 35547 | + | |
| 35548 | + | |
| 35549 | + | |
| 35550 | + | |
| 35551 | + | |
| 35552 | + | |
| 35553 | + | |
| 35554 | + | |
| 35555 | + | |
| 35556 | + | |
| 35557 | + | |
| 35558 | + | |
| 35559 | + | |
35545 | 35560 | | |
35546 | 35561 | | |
35547 | 35562 | | |
| |||
35553 | 35568 | | |
35554 | 35569 | | |
35555 | 35570 | | |
| 35571 | + | |
| 35572 | + | |
| 35573 | + | |
| 35574 | + | |
| 35575 | + | |
| 35576 | + | |
35556 | 35577 | | |
35557 | 35578 | | |
35558 | 35579 | | |
| |||
35594 | 35615 | | |
35595 | 35616 | | |
35596 | 35617 | | |
35597 | | - | |
| 35618 | + | |
35598 | 35619 | | |
| 35620 | + | |
35599 | 35621 | | |
35600 | 35622 | | |
35601 | 35623 | | |
| |||
35617 | 35639 | | |
35618 | 35640 | | |
35619 | 35641 | | |
35620 | | - | |
| 35642 | + | |
35621 | 35643 | | |
35622 | | - | |
| 35644 | + | |
35623 | 35645 | | |
35624 | 35646 | | |
35625 | 35647 | | |
| 35648 | + | |
| 35649 | + | |
| 35650 | + | |
| 35651 | + | |
| 35652 | + | |
| 35653 | + | |
| 35654 | + | |
| 35655 | + | |
| 35656 | + | |
| 35657 | + | |
| 35658 | + | |
| 35659 | + | |
| 35660 | + | |
| 35661 | + | |
35626 | 35662 | | |
35627 | 35663 | | |
35628 | 35664 | | |
| |||
35643 | 35679 | | |
35644 | 35680 | | |
35645 | 35681 | | |
| 35682 | + | |
35646 | 35683 | | |
35647 | 35684 | | |
35648 | 35685 | | |
35649 | | - | |
| 35686 | + | |
| 35687 | + | |
| 35688 | + | |
| 35689 | + | |
35650 | 35690 | | |
35651 | 35691 | | |
35652 | 35692 | | |
35653 | 35693 | | |
35654 | | - | |
| 35694 | + | |
35655 | 35695 | | |
35656 | 35696 | | |
| 35697 | + | |
35657 | 35698 | | |
35658 | 35699 | | |
35659 | 35700 | | |
| |||
0 commit comments