Releases: dwavesystems/dwave-hybrid
Releases · dwavesystems/dwave-hybrid
0.4.0
New Features
EnergyWeightedResampler
for input set re-sampling at a given
temperatureAggregatedSamples
block that aggregates or spreads input samplesConst
block that sets output state variables to constant valuesWait
block for synchronization of racing components- Population annealing workflow examples and importable workflows
(PopulationAnnealing
/HybridizedPopulationAnnealing
) - Input extrapolation and output aggregation options in
FixedTemperatureSampler
auto_embedding_params
argument in QPU auto-embedding samplersLoop
now terminates onEndOfStream
(alternative toUnwind
)
Fixes
- All QPU samplers now explicitly ask for a QPU solver
- Faster and more general
SplatComposer
/hstack_samplesets
(act on
all samples) - Support for unstructured QPU samplers in QPU auto-embedding samplers
- Isolated RNG in PT/PA components
Changes
- Renamed
qpu_params
argument tosampling_params
in all QPU samplers - New default for
rolling_history
inEnergyImpactDecomposer
: now
decomposing the complete problem - Removed default variables (
samples
andproblem
) fromState
Identity
block is now non-blocking. In racing contexts you should
now useBlockingIdentity
(orWait
) instead.
0.3.1
New Features
- Added
Branches
andDup
components that generalizeParallel
- Added predicate-based termination criterion in
Loop
, enabling run-to-energy mode - Even lazier auto-embedding QPU sampler
- Added parallel tempering workflow examples
- Importable workflows for
Kerberos
,ParallelTempering
/HybridizedParallelTempering
andSimplifiedQbsolv
Fixes
- Looser traits enforcing (run-time only, skip construction-time checks)
RandomConstraintDecomposer
edge casesRoofDualityComposite
energy calculation
0.3.0
New Features
- Tabu/SimulatedAnnealing samplers now use input state samples to initialize
- Racing context propagated to children via runopts
- Added
stoppable
class decorator to simplify implementing thread-safe stop behaviour - Added
RoofDualifyDecomposer
- Exposed all SA parameters in SimulatedAnnealing sampler
- Exposed non-interruptible Tabu timeout in Kerberos
Fixes
- Longer default runtime in Tabu
- Better handling of larger problems by Kerberos
Changes
endomorphic
option removed fromRacingBranches
andParallelBranches
in favor of explicitIdentity
blocksweeps
renamed tonum_sweeps
in SA samplers
0.2.1
Changes since 0.2.0:
New components
MergeSamples
that vertically stacks SampleSets from multiple StatesSliceSamples
that slices the set of samples (and trivially truncates)
Performance improvements
- Multi-threaded support in Tabu and Simulated Annealing samplers
General
- Added
States.first
property
Fixes
- Compatibility with
dimod==0.8.8
(breaking change ofSampleSet.samples()
behaviour)
0.2.0
Changes since 0.1.4:
New components
- Reverse annealing sampler:
ReverseAnnealingAutoEmbeddingSampler
- Best-state tracking block:
TrackMin
GreedyPathMerge
sample composer that finds the best sample on a greedy path between two samplesIdentity
runnable
Looping
Loop
refactored and generalized. Loops now come in two flavours:LoopUntilNoImprovement
andLoopWhileNoImprovement
.- Loops are now infinite by default, but all accept
max_iter
, andmax_time
(a new terminating condition). - Infinite loops are now interruptible/stoppable
SimpleIterator
deprecated.
Decomposition
- Structural decomposition added to
EnergyImpactDecomposer
. Two new modes of traversal are Breadth-First-Search and Priority-First-Search, both energy impact seeded. Unwind
ing context implicitly propagated to child runnables- Synchronous
Unwind
General
- Added deferred runtime parameters defined during
Runnable
construction - Added
State.from_(sub)problem
factories - Added
SampleSet.hstack
andSampleSet.vstack
utility functions - Added Dialectic Search example workflow
Fixes
- Blocks don't start after stop
- Performance counter access fails before the first run
0.1.4
Changes since 0.1.3:
EnergyImpactDecomposer
rewritten as a rolling, streaming, decomposer- consistent use of
size
in all decomposers - new blocks:
Unwind
andReduce
- runnables are picklable
- new module
hybrid.concurrency
(with new process executor) - profiling refactor: accumulating timers and integer counters
- misc bugfixes