The present disclosure generally relates to network construction technologies and particularly relates to topology constructions that satisfy the partition tolerance in the consortium blockchain consensus.
Blockchain refers to a pattern of constructing the chained-block data structure that is unforgeable, non-tamperable and traceable through transparent and trusted rules in a Peer-to-Peer network environment to implement and manage transaction processing. In some senses, a blockchain is a chained data structure in which data blocks are sequentially connected in a chronological order, and is an distributed ledger that cannot be tempered or falsified by cryptography; in a broader sense, the blockchain is a new, distributed infrastructure and computing method that uses the chained-block data structure to validate and store data, uses distributed consensus algorithms to generate and update data, uses cryptography to ensure the security of data transmission and access, and utilizes smart contracts consisting of automated script code to program and manipulate data.
In some implementations, a topology construction method for satisfying partition tolerance under consortium blockchain consensus, wherein the topology construction method includes the following steps: S1. Combining the consortium blockchain consensus mechanism with the network topology structure to make the consortium blockchain consensus satisfy the partition tolerance in probability; S2. Abstracting the partition tolerance of the system into a class of convergent Markov process and obtaining the steady-state probability of the system; S3. Estimating the probability and the minimum repair time of failing to meet consistency or availability in the event of a partition failure with a given number of failure channels, and the partition tolerance probability and the average minimum repair time of the system are obtained; and S4. Analyzing the resource overhead and the partition tolerance under different network topologies according to the obtained partition tolerance probability and the average minimum repair time, and constructing a network topology structure with suitable scale and high partition tolerance for the consortium blockchain consensus of different needs.
In some implementations, the Markov process in the step S2 converges to a steady-state distribution independent of the initial distribution, and in the single network topology structure, computing the steady-state probability of the system includes the following steps: S21. Multiplying the state transition matrix P iteratively by itself; and S22. Determining whether the 2-norm of the difference between two consecutive products is less than a set convergence precision; wherein if less than, determining that the power value of P at this time is the steady-state probability matrix P* and if not less than, returning to the step S21.
In some implementations, the MTBF and MTTR of each analysis element in the step S3 are independent processes without memory, and each mean value is constant; and in the single network topology structure, computing the partition tolerance probability of the system includes the following steps: S311. Sampling N times for each possible state of the steady-state system; S312. Estimating the probability of failing to meet consistency or availability in the event of a partition failure in each state; and S313. Calculating the partition tolerance probability of the system according to a full probability formula, wherein the full probability formula is: p=1−Σi=1lP{steady-state i}P{failing to meet consistency or availability in the event of a partition failure |steady-state i}, 1 indicates the total number of channels, and i indicates that only i channels are in a failure state in the steady state system.
In some implementations, in the single network topology structure, computing the average minimum repair time of the system includes the following steps: S321. Calculating the minimum repair time for each sample of failing to meet consistency or availability in the event of a partition failure; and S322. Multiplying the weight of the sample in the whole system partition tolerance problem, and obtaining the average minimum repair time of the system.
In some implementations, in the hierarchical network topology, according to the process of consensus, the partition tolerance of a lower-level domain is not only affected by its network topology but is also related to the partition tolerance of the higher-level domains; wherein the partition tolerance probability of the system is p=1−Σm=1n Σ(i1,i2,i3, . . . ,im) pi1pi1i2pi1i2i3 . . . pi1i2i3 . . . im−1(1−pi1i2i3 . . . im); wherein the average minimum repair time of the system is
where pi1i2i3 . . . represents the partition tolerance probability of each domain, and t i1i2i3 . . . represents the average minimum repair time of each domain.
In some implementations, a topology construction system for satisfying the partition tolerance in the consortium blockchain consensus, wherein the topology construction system includes: a combination module configured to combine a consortium blockchain consensus mechanism and a network topology structure to make the consortium blockchain consensus probabilistically satisfy partition tolerance; a convergence module configured to abstract the partition tolerance of the system into a class of convergent Markov process and obtain the steady-state probability of the system; a sampling estimation module configured to estimate the probability and the minimum repair time of failing to meet consistency or availability in the event of a partition failure with a given number of failure channels, and to obtain the partition tolerance probability and the average minimum repair time of the system; and a network construction module configured to analyze the resource overhead and the partition tolerance under different network topologies according to the partition tolerance probability and the average minimum repair time, and to construct the network topology with suitable size and higher partition tolerance for the consortium blockchain consensus of different needs.
In some implementations, the Markov process in the convergence module converges to a steady-state distribution independent of the initial distribution, and wherein in the single network topology, computing the steady-state probability of the system includes: a loop multiplication unit configured to multiply the state transition matrix P iteratively by itself; and a determining unit configured to determine whether the 2-norm of the difference between two consecutive products is smaller than a set convergence precision; wherein if it is less than, the power value of P at this time is determined to be the steady-state probability matrix P*, and if it is not less than, returning to the loop multiplication unit.
In some implementations, the MTBF and MTTR of each analysis element in the sampling estimation module are independent processes without memory, and each mean value is constant; wherein in the single network topology structure, computing the partition tolerance probability of the system includes: a sampling unit configured to sample N times for each possible state of the steady-state system; an estimation unit configured to estimate a probability of failing to meet consistency or availability in the event of a partition failure in each state; and a calculation unit configured to calculate the partition tolerance probability of the system according to a full probability formula, wherein the full probability formula is: p=1−Σi=1lP{steady-state i}P{failing to meet consistency or availability in the event of a partition failure |steady-state i}, 1 indicates the total number of channels, and i indicates that only i channels are in a failure state in the steady-state system.
In some implementations, in the single network topology, computing the average minimum repair time of the system includes: a calculating the minimum repair time unit configured to calculate the minimum repair time for each sample that fails to meet consistency or availability in the event of a partition failure; and a calculating the average minimum repair time unit configured to multiply with a weight of the sample in the total system partition tolerance problem, and to obtain the average minimum repair time of the system.
In some implementations, in the hierarchical network topology structure, according to the process of consensus, the partition tolerance of a lower-level domain is not only affected by its network topology structure but is also related to the partition tolerance of the higher-level domains; wherein the partition tolerance probability of the system is p=1−Σm=1nΣ(i1,i2,i3, . . . ,im) pi1pi1i2pi1i2i3 . . . pi1i2i3 . . . im−1(1−pi1i2i3 . . .im); wherein the average minimum repair time of the system is
where pi1i2i3 . . . represents the partition tolerance probability of each domain, and ti1i2i3 . . . represents the average minimum repair time of each domain.
The beneficial effects of the present disclosure are: combining the network topology with the consortium blockchain consensus mechanism, so that the consortium blockchain consensus satisfies the partition tolerance in probability, and thus may achieve the coexistence of the three factors of CAP, and has high practical significance; using the mean time between failures and the mean time to repair that are constant over a period of time as parameters improves the prediction accuracy of the Markov model for the probability distribution trend of the system state; estimating the probability and the minimum repair time of failing to satisfy consistency or availability in the event of a partition failure with a given number of failure channels, so as to fully adapt to the self-partition tolerance and network topology characteristics of the consensus mechanism.
The implementations disclosed herein are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings. Like reference numerals refer to corresponding parts throughout the drawings.
The blockchain is essentially a decentralized distributed ledger, and these distributed ideas have been proposed and matured long before the blockchain emerged. In 2000, Eric Brewer made a conjecture at a seminar that consistency(C), availability(A), and partition tolerance(P) could not be fully satisfied in a distributed system at the same time. In 2002, Lynch et al. proved this conjecture and referred to it as the CAP theorem. For the first time, the CAP theorem refines the three factors of consistency, availability, and partition tolerance into important features of distributed system design. Specifically, (1) consistency means that any operation in the system should appear to be “atomic” or serial, all operations appear to be globally ordered; (2) availability means that any normal node after requested should receive response in a limited amount of time; (3) partition tolerance means that when the network is partitioned at a particular time, the system can still meet the consistency and availability.
Due to the complex network environment of the blockchain, mainstream blockchain consensus algorithms such as PoW satisfy high availability and partition tolerance by weakening strict consistency for long-term eventual consistency, but this will result in limited TPS performance of the system. Therefore, some high-performance blockchain systems such as EOS choose to sacrifice partial partition tolerance by controlling the number of nodes participating in bookkeeping in exchange for TPS performance improvement. Both of these methods only choose two factors as the primary reinforcement point among consistency, availability and partition tolerance, and significantly weaken the third factor. There is still much room for the CAP limit.
Bitcoin uses an Internet-based peer-to-peer distributed network architecture with network routing capabilities on each node. When a new node needs to access the Bitcoin network, it should perform the following steps:
1. Using the DNS seed or ‘seednode’ command to find a valid node in the Bitcoin network.
2. Sending a ‘version’ message containing the essential authentication content to the discovered valid bitcoin node for the initial handshake communication process to establish a connection.
3. Sending its IP address to the connected node. After receiving, the connected node forwards the IP address to its respective connected nodes, so that more nodes in the network receive the new node.
4. Asking the connected node for a list of known node IP addresses to find more connectable nodes.
5. Periodically sending messages to the connected nodes to maintain the connection. If there is no communication with a node for more than 90 minutes, it is determined to have been disconnected and starts to find a new node. Since Bitcoin communication is based on the TCP protocol, each node has a limited number of TCP connections, so an excessive number of IP addresses are ignored.
After the startup is complete, the node remembers the nodes that were successfully connected recently, and when it restarts, it can quickly re-establish the connection with the previous nodes. If the previous nodes are unable to connect, re-execute from step (1).
In the process of communication between bitcoin nodes, it is not required to maintain the topology of the network, that is, it is not necessary to abstract the network logically, and the flooding strategy is used for data transmission.
The flooding strategy is simple and easy to implement, and the behaviors such as node joining, leaving, and failure have a less negative impact on the whole system, so the network reliability is high. However, because the mesh structures are connected, flooding may cause the nodes to repeatedly receive the same data multiple times, resulting in redundant reception of node information, and a large amount of useless repeated data transmission also consumes network resources.
The Proof of Authority (PoA) consensus algorithm based on the consortium blockchain was proposed by Ethereum co-founder and former chief technology officer Gavin Wood in 2017 and is currently used in the Ethereum test network Kovan. PoA's consensus process is: first, a set of initially authorized signers are specified in the creative block. After the mining is started, the signer starts to sign the generated block and broadcast it. If other authorized signers object to the block's generation, a “kick out” vote is held on the signer of the block, and if the number of votes exceeds 50% of the total number of signers, the bookkeeping right of the corresponding signer is canceled.
In order to reduce the loss caused by the malicious signers, the same signer can only sign one of the (SIGNER—COUNT/2)+1 blocks. To reduce the probability of forks, the system has a signer in the IN-TURN state at each height, and other signers are in the OUT-OF-TURN state. The signer in the IN-TURN state can immediately broadcast its block. The signer in the OUT-OF-TURN state who generates a block will randomly delay for a while before broadcasting.
The PoA consensus relies on a practical and trustworthy authentication mechanism. Considering that the identity of the signers is open to the whole network, once more than half of the signers are attacked, the system cannot guarantee the correctness of the blocks. On the other hand, compared to the conventional PBFT consensus algorithm, the PoA consensus algorithm achieves high availability and partition tolerance by weakening the consistency requirement as non-consistency (Aura client) or eventual consistency (Clique client).
As shown in
The existing blockchain systems only strengthen two factors among consistency, availability, and partition tolerance at the consensus level, accompanied by a significant weakening of the third factor, which is still far from the CAP limit.
Also, at the data communication level, the current mainstream blockchain systems do not consider how to maintain the network topology, which brings potential network communication risks and resource waste.
In view of the above problems, the present disclosure—a topology construction method and system that satisfies the partition tolerance in the consortium blockchain consensus, combines the network topology with the consortium blockchain consensus mechanism, so that the consortium blockchain consensus satisfies the partition tolerance in terms of probability, and further may achieve the coexistence of three factors of CAP. The present disclosure also proposes a partition tolerance calculation method, which abstracts the partition tolerance problem of the system into a class of convergent Markov process, and uses simulation software such as MATLAB to sample and calculate the probability and average minimum repair time for the network failing to meet consistency or availability in the event of a partition failure. According to the above calculation method, the present disclosure specifically analyzes resource overhead and partition tolerance in different network topologies and constructs network topology with proper scale and high partition tolerance for the consortium blockchain consensus of different needs.
The technical solution of the present disclosure combines the network topology with the consortium blockchain consensus mechanism on the basis of not affecting the consistency and availability of the consensus algorithm, so that the consortium blockchain consensus may satisfy the partition tolerance in terms of probability, and thus may achieve the coexistence of three factors of CAP which has a highly practical meaning.
A partition tolerance calculation method is proposed to abstract the partition tolerance problem of the system into a class of convergent Markov process. Moreover, by using the mean time between failures and the mean time to repair that remains constant over some time as parameters, the prediction accuracy of the Markov model for the probability distribution trend of the system state is improved.
Different consensus mechanisms have different partition tolerance. The situation of partition failures may also be different under different network topologies, so their failure probability has different characteristics. By using the simulation software such as MATLAB to estimate the probability and the minimum repair time of failing to satisfy consistency or availability in the event of a partition failure with a given number of failure channels, the self-partition tolerance and network topology structure characteristics of the consensus mechanism are fully adapted.
This paper further deduces the partition tolerance in the hierarchical network topology structure, which applies not only to the general single-chain architecture, but also to the multi-chain and cross-chain architecture, from the computational method in the single network topology, and has broad application prospects.
This paper analyzes the resource overhead and partition tolerance in different network topologies and constructs single or hierarchical network topology structure with appropriate scale and high partition tolerance for the consortium blockchain consensus of different needs. Different levels of domains may use the same or different network topologies and parameters. The network topologies of different domains at the same level may also be different.
Generally, the evaluation of communication networks is based on the following basic assumptions:
1. All elements involved in the analysis have only two states: work and failure.
2. Failures and repairs between each analysis elements are independent of each other.
3. The MTBF (Mean Time Between Failures) and MTTR (Mean Time To Repair) of each analysis element are independent processes with no memory and constant mean value.
4. MTBF is much larger than MTTR.
Based on the above assumptions, since each element is in multiple processes of work-failure-repair, the Markov process can be used for mathematical description. The parameters are defined as follows:
v: Total number of network nodes.
l: Total number of network channels.
k: The minimum required some consensus nodes in the consortium blockchain consensus mechanism that satisfy consistency and availability, that is, if and only if the number of consensus nodes in a partition is more than k, this consortium blockchain consensus mechanism satisfies consistency and availability.
λ: The probability of failure of the channel per unit time, that is, λ=1/MTBF.
μ: The probability that a channel in the failure state is repaired in the unit time of the system, that is, μ=1/MTTR.
For a network topology structure containing v nodes and l channel (such as multi-dimensional hypercube structure or multi-point fully connected structure), make a Markov state transition diagram, as shown in
The state transition matrix of the Markov model is a matrix P of size (l+1)×(l+1), where the element pji represents the probability of transitioning from the i-th system state to the j-th system state. Let m denote the number of the same failure channels in state i and state j, then the value range of m is [max{i+j−l,0}, min{i,j}].
The state transition matrix P of the above Markov model satisfies three characteristics:
1. Since all elements of P are greater than or equal to 0, and the sum of the elements of a column represents the sum of the probabilities of all possible next jumps given an initial state, that is, the column sum of P is 1, then P satisfies randomness.
2. Since the failures and repairs between the channels are independent of each other, each system state may come from any other state, that is, the Markov state transition diagram is fully connected, so P satisfies the irreducibility.
3. As shown in
Therefore, the above Markov process will eventually converge to a steady-state distribution independent of the initial distribution. Algorithm 1 describes the iterative calculation process for the steady-state probability of the system. The state transition matrix P is multiplied iteratively by itself. If the 2-norm of the difference between successive products is less than the given convergence precision, then the power of P at this time is considered to be the steady-state probability matrix P*.
Since the MTBF and MTTR of each analysis element are independent processes with no memory and the constant mean value, it is possible to estimate the probability of failing to satisfy consistency or availability in the event of a partition failure with a given number of failure channels. Algorithm 2 describes the partition tolerance probability calculation process for a system in the single network topology structure. For the various states that the system in steady-state may be, it is sampled N times and estimated the probability of the partition failure occurred without satisfying consistency or availability. And then, the partition tolerance probability of the system is calculated according to the full probability formula.
The minimum repair time is defined as the minimum time required for the system to repair part of the channel in the event of a failure so that the system meets consistency and availability. Algorithm 3 describes the average minimum repair time calculation process for a system in the single network topology structure. Based on Algorithm 2, for each partition failure instance that does not meet the consistency or availability, calculate its minimum repair time, multiply by the weight of the instance in the whole system partition tolerance problem, and obtain the average minimum repair time of the system.
In a hierarchical network topology structure, after the lower-level domain node generates a block within the domain, the block is passed to the upper-level domain to continue the higher-level consensus. For an n-level network topology structure, each domain is numbered according to the tree structure of (i1i2i3 . . . ), as shown in
The partition tolerance of the lower-level domain is not only affected by its network topology structure but also related to the partition tolerance of the higher-level domain. Let pi1i2i3 . . . denote the partition tolerance probability of each domain. Then the partition tolerance probability of the system is
p=1−Σm=1(i1,i2,i3, . . . ,im)nΣpi1pi1i2pi1i2i3 . . . pi1i2i3 . . . im−1(1−pi1i2i3 . . . im). (2)
For the same reason, let ti1i2i3 . . . denote the average minimum repair time of each domain. Then the average minimum repair time of the system is
Taking the digital optical cable system as an example, the following is the calculation of the partition tolerance probability and the average minimum repair time when the Proof of Vote (PoV) in the consortium blockchain adopts the 2- to 5-dimensional hypercube network topology and the 4- to 10-point fully connected network topology. An example of the 5-d hypercube is shown in
According to national standards, the digital optical cable communication system with automatic switching function of the primary and backup systems should meet the full year indicators shown in Table 1. Therefore, take the parameter pair (λ,μ)∈{(4.5662×10−4, 4.1667 ×10−2), (2.7397×10−4, 6.9444×10−2), (3.8358×10−5, 4.9603×10−1), (2.5571×10−5, 7.4405×10−1)}.
The resource overhead of the multi-dimensional hypercube and multi-point fully connected network topologies are shown in Table 2.
In the PoV consensus,
The calculation results of the partition tolerance probability and the average minimum repair time are shown in
Continue to consider the four hierarchical network topologies as shown in
Assume that the link lengths of the top, second, and third domains in
(1) Lower boundary situation
p=1−[(1−p1)+p1*(1−p11)*4+p1*p11*(1−p111)*4*4]≈1−4×10−4/h, that is, a partition failure will occur approximately every 3 months.
t=[t1*(1−p1)+t11*p1*(1−p11)*4+t111*p1*p11*(1−p111)*4*4]/(1−p)≈21 h, that is, the average minimum repair time after a partition failure is approximately 21 hours.
(2) Completely symmetric 3-level topology
p=1−[(1−p1)+p1*(1−p11)*8+p1*p11*(1−p111)*8*8]≈1−5×10−8/h, that is, a partition failure will occur approximately every 2,283 years.
t=[t1*(1−p1)+t11*p1*(1−p11)*8+t111*p1*p11*(1−p111)*8*8]/(1−p)≈23 h, that is, the average minimum repair time after a partition failure is approximately 23 hours.
(3) Semi-symmetric 2-level topology
p=1−[(1−p1)+p1*(1−p11)*16]≈1−1×10−8, that is, a partition failure will occur every 11,416 years.
t=[t1*(1−p1)+t11*p1*(1−p11)*16]/(1−p)≈14 h, that is, the average minimum repair time after a partition failure is approximately 14 hours.
(4) Asymmetrical 2-level topology
p=1−[(1−p1)+p1*(1−p11)*4+p1*(1−p12)*8+p1*(1−p13)*4]≈1−6×10−9, that is, a partition failure will occur approximately every 19,026 years.
t=[t1*(1−p1)+t11*p1*(1−p11)*4+t12*p1*(1−p12)*8+t13*p1*(1−p13) *4]/(1−p)≈14 h, that is, the average minimum repair time after a partition failure is approximately 14 hours.
Another object of the present disclosure is to provide a topology construction system that satisfies the partition tolerance in the consortium blockchain consensus, and the topology construction system includes:
a combination module configured to combine the consortium blockchain consensus mechanism with the network topology to make the consortium blockchain consensus satisfy the partition tolerance in terms of probability;
a convergence module configured to abstract the partition tolerance of the system into a class of convergent Markov process and to obtain the steady-state probability of the system;
a sampling estimation module configured to estimate the probability and the minimum repair time of failing to meet consistency or availability in the event of a partition failure with a given number of failure channels, and to obtain the partition tolerance probability and the average minimum repair time of the system; and
a network construction module configured to analyze the resource overhead and the partition tolerance under different network topologies according to the obtained partition tolerance probability and the average minimum repair time and to construct the network topology with suitable size and higher partition tolerance for the consortium blockchain consensus of different needs.
In some implementations, the Markov process in the convergence module converges to a steady-state distribution independent of the initial distribution, and in the single network topology, computing the steady-state probability of the system includes:
a loop multiplication unit configured to multiply a state transition matrix P iteratively by itself; and
a determining unit configured to determine whether a 2-norm of the difference between two consecutive products is smaller than a set convergence precision; wherein if it is less than, the power value of P at this time is determined to be the steady-state probability matrix P*, and if it is not less than, returning to the loop multiplication unit.
In some implementations, the MTBF and MTTR of each analysis element in the sampling estimation module are independent processes with no memory and constant mean value; and in the single network topology structure, computing the partition tolerance probability of the system includes:
a sampling unit configured to sample N times for each possible state of the steady-state system;
an estimation unit configured to estimate a probability and an average minimum repair time of failing to meet consistency or availability in the event of a partition failure; and
a calculation unit configured to calculate the partition tolerance probability of the system according to a full probability formula, wherein the full probability formula is: p=1−Σi=1lP{steady-state i}P{failing to meet consistency or availability in the event of a partition failure|steady-state i}, 1 indicates the total number of channels, and i indicates that only i channels are in a failure state in the steady-state system.
In some implementations, in the single network topology structure, computing the average minimum repair time of the system includes:
a calculating the minimum repair time unit configured to calculate the minimum repair time for each sample that fails to meet consistency or availability in the event of a partition failure; and
a calculating the average minimum repair time unit configured to multiply with a weight of the sample in the whole system partition tolerance problem, and to obtain the average minimum repair time of the system.
In some implementations, in the hierarchical network topology structure, according to the process of consensus, the partition tolerance of a lower-level domain is not only affected by its network topology structure but is also related to the partition tolerance of a higher-level domain; wherein the partition tolerance probability of the system is p=1−Σm=1nΣ(i1,i2,i3, . . . ,im) pi1pi1i2pi1i2i3 . . . Pi1i2i3 . . . im−1(1−pi1i2i3 . . . im); wherein the average minimum repair time of the system is
where pi1i2i3 . . . represents the partition tolerance probability of each domain, and ti1i2i3 . . . represents the average minimum repair time of each domain.
The method 1200, in some implementations, includes: combining (1202) a consortium blockchain consensus mechanism with a network topology to make the consortium blockchain consensus meet the partition tolerance in probability; abstracting (1204) the partition tolerance of the system into a class of convergent Markov process and obtain the steady-state probability of the system; estimate (1206) a probability and a minimum repair time of failing to meet consistency or available in the event of a partition failure with a given number of failure channel, and a partition tolerance probability and an average minimum repair time of the system are obtained; and analyzing (1208) a resource overhead and a partition tolerance under different network topologies according to the obtained partition tolerance probability and the average minimum repair time, and construct a network topology structure with suitable scale and high partition tolerance for the consortium blockchain consensus of different needs
Plural instances may be provided for components, operations or structures described herein as a single instance. Finally, boundaries between various components, operations, and data stores are somewhat arbitrary, and particular operations are illustrated in the context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within the scope of the implementation(s). In general, structures and functionality presented as separate components in the example configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the implementation(s).
It will also be understood that, although the terms “first,” “second,” etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another.
The terminology used herein is for the purpose of describing particular implementations only and is not intended to be limiting of the claims. As used in the description of the implementations and the appended claims, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will also be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
As used herein, the term “if” may be construed to mean “when” or “upon” or “in response to determining” or “in accordance with a determination” or “in response to detecting,” that a stated condition precedent is true, depending on the context. Similarly, the phrase “if it is determined (that a stated condition precedent is true)” or “if (a stated condition precedent is true)” or “when (a stated condition precedent is true)” may be construed to mean “upon determining” or “in response to determining” or “in accordance with a determination” or “upon detecting” or “in response to detecting” that the stated condition precedent is true, depending on the context.
The foregoing description included example systems, methods, techniques, instruction sequences, and computing machine program products that embody illustrative implementations. For purposes of explanation, numerous specific details were set forth in order to provide an understanding of various implementations of the inventive subject matter. It will be evident, however, to those skilled in the art that implementations of the inventive subject matter may be practiced without these specific details. In general, well-known instruction instances, protocols, structures, and techniques have not been shown in detail.
The foregoing description, for purpose of explanation, has been described with reference to specific implementations. However, the illustrative discussions above are not intended to be exhaustive or to limit the implementations to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The implementations were chosen and described in order to best explain the principles and their practical applications, to thereby enable others skilled in the art to best utilize the implementations and various implementations with various modifications as are suited to the particular use contemplated.
This application is a continuation of PCT Patent Application PCT/CN/2018/090453, filed Jun. 8, 2018. This application is also a continuation-in-part of U.S. patent application Ser. No. 15/997,710, filed Jun. 5, 2018, now allowed, which is a continuation of PCT/CN2017/084431 filed May 16, 2017. All above-identified patent applications are hereby incorporated by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2017/084431 | May 2017 | US |
Child | 15997710 | US | |
Parent | PCT/CN2018/090453 | Jun 2018 | US |
Child | PCT/CN2017/084431 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15997710 | Jun 2018 | US |
Child | 16361067 | US |