|  View source on GitHub | 
Represents linear combination of things.
cirq.LinearDict(
    terms: (Mapping[TVector, cirq.TParamValComplex] | None) = None,
    validator: (Callable[[TVector], bool] | None) = None
) -> None
LinearDict implements the basic linear algebraic operations of vector addition and scalar multiplication for linear combinations of abstract vectors. Keys represent the vectors, values represent their coefficients. The only requirement on the keys is that they be hashable (i.e. are immutable and implement hash and eq with equal objects hashing to equal values).
A consequence of treating keys as opaque is that all relationships between the keys other than equality are ignored. In particular, keys are allowed to be linearly dependent.
Methods
clean
clean(
    *, atol: float = 1e-09
) -> Self
Remove terms with coefficients of absolute value atol or less.
clear
clear()
D.clear() -> None. Remove all items from D.
copy
copy() -> Self
fromkeys
@classmethodfromkeys( vectors, coefficient=0 )
get
get(
    vector, default=0
)
D.get(k[,d]) -> D[k] if k in D, else d. d defaults to None.
items
items() -> ItemsView[TVector, cirq.TParamValComplex]
D.items() -> a set-like object providing a view on D's items
keys
keys() -> KeysView[TVector]
D.keys() -> a set-like object providing a view on D's keys
pop
pop(
    key, default=<object object>
)
D.pop(k[,d]) -> v, remove specified key and return the corresponding value. If key is not found, d is returned if given, otherwise KeyError is raised.
popitem
popitem()
D.popitem() -> (k, v), remove and return some (key, value) pair as a 2-tuple; but raise KeyError if D is empty.
setdefault
setdefault(
    key, default=None
)
D.setdefault(k[,d]) -> D.get(k,d), also set D[k]=d if k not in D
update
update(
    *args, **kwargs
)
D.update([E, ]**F) -> None. Update D from mapping/iterable E and F. If E present and has a .keys() method, does: for k in E: D[k] = E[k] If E present and lacks .keys() method, does: for (k, v) in E: D[k] = v In either case, this is followed by: for k, v in F.items(): D[k] = v
values
values() -> ValuesView[cirq.TParamValComplex]
D.values() -> an object providing a view on D's values
__add__
__add__(
    other: Self
) -> Self
__bool__
__bool__() -> bool
__contains__
__contains__(
    vector: Any
) -> bool
__eq__
__eq__(
    other: Any
) -> bool
Checks whether two linear combinations are exactly equal.
Presence or absence of terms with coefficients exactly equal to zero does not affect outcome.
Not appropriate for most practical purposes due to sensitivity to numerical error in floating point coefficients. Use cirq.approx_eq() instead.
__getitem__
__getitem__(
    vector: TVector
) -> cirq.TParamValComplex
__iter__
__iter__() -> Iterator[TVector]
__len__
__len__() -> int
__mul__
__mul__(
    a: cirq.TParamValComplex
) -> Self
__ne__
__ne__(
    other: Any
) -> bool
Checks whether two linear combinations are not exactly equal.
See eq().
__neg__
__neg__() -> Self
__rmul__
__rmul__(
    a: cirq.TParamValComplex
) -> Self
__sub__
__sub__(
    other: Self
) -> Self
__truediv__
__truediv__(
    a: cirq.TParamValComplex
) -> Self