Packages

o

org.bitcoins.core.protocol.dlc.compute

DLCAdaptorPointComputer

object DLCAdaptorPointComputer

Responsible for optimized computation of DLC adaptor point batches.

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. DLCAdaptorPointComputer
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Type Members

  1. case class AdditionTrieNode(preComputeTable: Vector[Vector[ECPublicKey]], depth: Int = 0, children: Vector[AdditionTrieNode] = Vector.empty, pointOpt: Option[SecpPoint] = None) extends Product with Serializable

    This trie is used for computing adaptor points for a single oracle corresponding to digit prefixes while memoizing partial sums.

    This trie is used for computing adaptor points for a single oracle corresponding to digit prefixes while memoizing partial sums.

    For example the point corresponding to 0110 and 01111010 both begin with the 011 sub-sum.

    This trie stores all already computed sub-sums and new points are computed by extending this Trie.

    Note that this method should not be used if you have access to LibSecp256k1CryptoRuntime because calling CryptoUtil.combinePubKeys will outperform memoization in that case.

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##: Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  5. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native()
  6. def computeAdaptorPoints(contractInfo: SingleContractInfo): Vector[ECPublicKey]

    Efficiently computes all adaptor points, in order, for a given ContractInfo.

    Efficiently computes all adaptor points, in order, for a given ContractInfo.

    See also

    https://medium.com/crypto-garage/optimizing-numeric-outcome-dlc-creation-6d6091ac0e47

  7. def computePoint(pubKey: SchnorrPublicKey, nonce: ECPublicKey, outcome: ByteVector): ECPublicKey

    Computes: nonce + outcomeHash*pubKey where outcomeHash is as specified in the DLC spec.

    Computes: nonce + outcomeHash*pubKey where outcomeHash is as specified in the DLC spec.

    See also

    https://github.com/discreetlogcontracts/dlcspecs/blob/master/Oracle.md#signing-algorithm

  8. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  9. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  10. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable])
  11. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  12. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  13. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  15. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  16. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  17. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  18. def toString(): String
    Definition Classes
    AnyRef → Any
  19. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  20. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  21. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()
  22. object AdditionTrieNode extends Serializable

Inherited from AnyRef

Inherited from Any

Ungrouped