hdl.ast: remove quadratic time complexity in Statement.cast().
Using `sum(lst, [])` to flatten a list of lists has quadratic time complexity. Use `chain.from_iterable()` instead. While not strictly necessary to improve performance, convert to `map()`. A test case writing out verilog for a 512k entry FIFO is 120x faster with this applied.
This commit is contained in:
		
							parent
							
								
									9834b7e95f
								
							
						
					
					
						commit
						9f78ac0691
					
				|  | @ -4,6 +4,7 @@ import functools | |||
| from collections import OrderedDict | ||||
| from collections.abc import Iterable, MutableMapping, MutableSet, MutableSequence | ||||
| from enum import Enum | ||||
| from itertools import chain | ||||
| 
 | ||||
| from .. import tracer | ||||
| from .._utils import * | ||||
|  | @ -1404,7 +1405,7 @@ class Statement: | |||
|     @staticmethod | ||||
|     def cast(obj): | ||||
|         if isinstance(obj, Iterable): | ||||
|             return _StatementList(sum((Statement.cast(e) for e in obj), [])) | ||||
|             return _StatementList(list(chain.from_iterable(map(Statement.cast, obj)))) | ||||
|         else: | ||||
|             if isinstance(obj, Statement): | ||||
|                 return _StatementList([obj]) | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Anton Blanchard
						Anton Blanchard