Trace reconstruction was originally motivated by problems in sequence alignment, phylogeny, and computational biology. The goal of trace reconstruction is to reconstruct an unknown binary string x given random portions or “traces” of x where each trace is generated by deleting each coordinate of x independently with probability p<1. Put another way, the setting for the problem is as follows: There is an unknown string xϵ{0, 1}n, and the goal is to reconstruct the string. Towards this goal, traces of x are made available, which are obtained by sending x through a deletion channel. This deletion channel independently deletes bits of x with a given deletion probability d. Accordingly, each trace corresponds to a subsequence of x.
In this scenario, the traditional optimization problem is to minimize the number of traces required for reconstructing x with high probability. Since its introduction, the problem of trace reconstruction has been studied from several different perspectives.
Two of the main perspectives correspond to “worst-case trace reconstruction”, where the reconstruction algorithm must work simultaneously for all strings in {0, 1}n, and “average-case trace reconstruction,” where the reconstruction algorithm is only required to work with high probability, taken over the choice of string and the randomness of the reconstruction algorithm for a uniformly random string. The number of traces required for average-case trace reconstruction is, as expected, much smaller than that required for worst-case trace reconstruction. The problem in question has also been studied from a combinatorial coding perspective.
Previous work on average-case trace reconstruction can be interpreted from a coding theoretic perspective: They state that there exist very large codebooks which can be reconstructed efficiently from relatively few traces. However, no efficient encoders are known for such codes, and it may be possible to further reduce the number of traces required for reconstruction by relaxing the size of the code.
This point of view naturally leads to the problem of coded trace reconstruction: The goal is to design high rate, efficiently encodable codes whose codewords can be efficiently reconstructed with high probability from very few traces with constant deletion probability. Here, “high rate” refers to a rate approaching 1 as the block length increases. In such a case, the number of traces must grow with the block length of the code. Coded trace reconstruction is also closely related to and motivated by the read process in portable DNA-based data storage systems.
A practical motivation for coded trace reconstruction comes from portable DNA-based data storage systems using DNA nanopores. In DNA-based storage, a block of user-defined data is first encoded over the nucleotide alphabet {A, C, G, T}, and then transformed into moderately long strands of DNA through a DNA synthesis process. For ease of synthesis, the DNA strands are usually encoded to have balanced GC-content, so that the fraction of {A, T} and {G, C} bases is roughly the same. To recover the block of data, the associated strand of DNA is sequenced with nanopores, resulting in multiple corrupted reads of its encoding. Although the errors encountered during nanopore sequencing include both deletions/insertions as well as substitution errors, careful read preprocessing alignment allows the processed reads to be viewed as traces of the data block's encoding. As a result, recovering the data block in question can be cast in the setting of trace reconstruction. Due to practical time constraints (e.g., sequencing time), it is of great interest to minimize the number of reads required to reconstruct the data block.
The trace reconstruction procedures associated to the codes used by practical portable DNA-based storage systems are largely based on heuristics. Conventional trace reconstruction algorithms operate on carefully designed coded strings, but make use of multiple sequence alignment algorithms which are difficult to analyze rigorously. For example, an example conventional trace reconstruction algorithm does not make use of specific read-error correction codes and is a variation of the Bitwise Majority Alignment (BMA) algorithm. However, the BMA algorithm is only known to be robust when the errors correspond to independent and identically distributed (i.i.d.) deletions and the fraction of errors is at most O(1/log n), where n denotes the blocklength of the code. Moreover, the conventional codes have been designed only for a fixed blocklength. As a result, such codes have poor robustness or performance guarantees for trace reconstruction even under i.i.d. deletions with constant deletion probability.
Accordingly, there exists a need for a coded trace reconstruction method that offers improved robustness and performance for trace reconstruction in portable DNA-based data storage systems.
The present disclosure describes methods that can provide coded trace reconstruction for efficient, high-rate codes against a constant rate of deletions, among other possibilities. Namely, the disclosure describes the design and analysis of high-rate efficiently encodable codes that can be efficiently decoded with high probability from few traces (also called reads) that are corrupted by edit errors.
In a first aspect, method is provided. The method includes receiving a message having a message length n bits. The method also includes partitioning the message into a plurality of blocks with a maximum block length of O(log2 n). The method additionally includes encoding each block to provide a plurality of encoded blocks and inserting unique markers between the encoded blocks so as to form an encoded message. The markers each have a minimum marker length O(log n). The method also includes causing a DNA sequencer to synthesize a nucleotide sequence based on the encoded message.
In a second aspect, a method is provided. The method includes receiving, at a DNA readout system, a nucleotide sequence. The method additionally includes reading the nucleotide sequence based on an alphabet consisting of {adenine (A), cytosine (C), guanine (G), and thymine (T)}. The method further includes determining positions of unique markers between a plurality of encoded blocks in the nucleotide sequence and decoding each encoded block of the plurality of encoded blocks according to an inner code, forming a plurality of decoded blocks. The method yet further includes appending the decoded blocks to one another to provide a decoded message with message length n bits.
In a third aspect, A DNA-based sequencing system is provided. The DNA-based sequencing system includes a DNA sequencer and a controller configured to carry out operations. The operations include receiving a message having a message length n bits. The operations additionally include partitioning the message into a plurality of blocks with a maximum block length of O(log2 n). The operations also include encoding each block to provide a plurality of encoded blocks and inserting unique markers between the encoded blocks so as to form an encoded message. The markers each have a minimum marker length O(log n). The operations additionally include causing the DNA sequencer to synthesize a nucleotide sequence based on the encoded message.
In a fourth aspect, a DNA-based readout system is provided. The DNA-based readout system includes a DNA reader and a controller configured to carry out operations. The operations include receiving, at a DNA reader, a nucleotide sequence and reading the nucleotide sequence based on an alphabet consisting of {adenine (A), cytosine (C), guanine (G), and thymine (T)}. The operations additionally include determining positions of unique markers between a plurality of encoded blocks in the nucleotide sequence and decoding each encoded block of the plurality of encoded blocks according to an inner code, so as to form a plurality of decoded blocks. The operations yet further include appending the decoded blocks to one another to provide a decoded message with message length n bits.
Other aspects, embodiments, and implementations will become apparent to those of ordinary skill in the art by reading the following detailed description, with reference where appropriate to the accompanying drawings.
Example methods, devices, and systems are described herein. It should be understood that the words “example” and “exemplary” are used herein to mean “serving as an example, instance, or illustration.” Any embodiment or feature described herein as being an “example” or “exemplary” is not necessarily to be construed as preferred or advantageous over other embodiments or features. Other embodiments can be utilized, and other changes can be made, without departing from the scope of the subject matter presented herein.
Thus, the example embodiments described herein are not meant to be limiting. Aspects of the present disclosure, as generally described herein, and illustrated in the figures, can be arranged, substituted, combined, separated, and designed in a wide variety of different configurations, all of which are contemplated herein.
Further, unless context suggests otherwise, the features illustrated in each of the figures may be used in combination with one another. Thus, the figures should be generally viewed as component aspects of one or more overall embodiments, with the understanding that not all illustrated features are necessary for each embodiment.
As described herein, a channel model may be utilized to represent a nanopore system as follows. For a given input string xϵ{0, 1}n, a deletion probability d, and an integer t(n), the channel returns t(n) traces of x. Each trace of x is obtained by sending x through a deletion channel with deletion probability d. In such a scenario, the deletion channel deletes each bit of x independently with probability d, and outputs a subsequence of x containing all bits of x that were not deleted in order. The t(n) traces are independent and identically distributed (i.i.d.) as outputs of the deletion channel for input x.
Given a code C⊆{0, 1}n, C can be efficiently reconstructed from t(n) traces if there exists a polynomial p(n) and a polynomial-time algorithm that recovers every cϵC from t(n) traces of c with probability at least 1−1/p(n) over the probability distribution of the traces.
Coded trace reconstruction is described herein within the context of determining efficient, high-rate codes against a constant rate of trace deletions. More specifically, the performance of marker-based constructions is analyzed with worst-case trace reconstruction algorithms. These constructions have the advantage that they can be easily adapted to work with a large range of inner codes.
At a high level, the construction operates by splitting an n-bit message into short blocks of length O(log2 n), encoding each block with an inner code satisfying a certain constraint, and adding markers of length O(log n) between the blocks. The structure of the markers and the property of the inner code imply that, with high probability, we can split the traces into many shorter sub-traces associated with substrings of length O(log2 n), and then apply the worst-case trace reconstruction algorithm on the sub-traces. The main result in this context is Theorem 1.
Theorem 1. For every constant deletion probability d<1, there exists an efficiently encodable code C⊆{0, 1}n+r with redundancy r=O(n/log n) that can be efficiently reconstructed from exp(O(log2/3 n)) traces.
The above construction is relevant as it shows that marker-based construction can be utilized with any inner code satisfying a simple constraint and iterate the marker-based construction by further dividing each block of length log2 n into blocks of length (log log n)2 and adding markers of length O(log log n) between them. In this setting, it is almost guaranteed that reconstruction of a small fraction of blocks will fail. Nevertheless, this problem can be easily resolved by adding error-correction redundancy to the string to be encoded.
This leads to the following result, which can be extended beyond two marker levels.
Theorem 2. For every constant deletion probability d<1, there exists an efficiently encodable code C⊆{0, 1}n+r with redundancy r=O(n/log log n) that can be efficiently reconstructed from exp(O(log log n)2/3) traces.
In some embodiments, the marker-based constructions can be implemented with a large range of inner codes to construct high-rate marker-based codes over the {A, C, G, T} alphabet with two important properties: The codes have balanced GC-content and provably require few traces to be efficiently reconstructed. Such embodiments may be similar to the marker-based constructions above, but with different markers and an inner code over a larger alphabet and with stronger constraints. In this context, the following results can be obtained.
Theorem 3. For every constant deletion probability d<1, there exists an efficiently encodable code C⊆{A, C, G, T}n+r with redundancy r=O(n/log n) and balanced GC-content that can be efficiently reconstructed from exp(O(log2/3 n)) traces.
Theorem 4. For every constant deletion probability d<1, there exists an efficiently encodable code C⊆{A, C, G, T}n+r with redundancy r=O(n/log log n) and balanced GC-content that can be efficiently reconstructed from exp(O(log log n)2/3) traces.
The result of Theorem 1 may be further improved by considering a more careful design of the highrate inner code to be used in the marker-based constructions, provided that the deletion probability is a small enough constant. This allows for using a modified version of an algorithm for average-case trace reconstruction, which leads to a substantial reduction in the number of traces required for reconstruction and barely any rate changes. As a first step towards achieving this goal, a low-redundancy code is described that can be efficiently reconstructed from polynomially many traces. The proposed coding scheme relies on the fact that n-bit messages into strings that are almost subsequence-unique via explicit constructions of almost k-wise independent spaces can be efficiently encoded.
The average-case trace reconstruction algorithm operates on subsequence-unique strings, and an adaptation of the algorithm can provide the following result.
Theorem 5. If the deletion probability is a small enough constant, there exists an efficiently encodable code C⊆{0, 1}n+r with redundancy r=O(log n) that can be efficiently reconstructed from poly(n) traces.
An important step is to adapt this code for use as an inner code in the marker-based construction. Some care is needed, since the global structure of the strings changes significantly due to the presence of the markers. In particular, the bootstrapping method in the trace reconstruction algorithm no longer works. In such scenarios, the following result can be found.
Theorem 6. If the deletion probability is a small enough constant, there exists an efficiently encodable code C⊆{0, 1}n+r with redundancy r=O(n/log n) that can be efficiently reconstructed from poly(log n) traces.
For simplicity, the present description mostly focuses on constructions of binary codes, although it provides some guidelines and simple coding procedures for quaternary codes. It will be understood that coded trace reconstruction is inherently more difficult for smaller alphabets.
The present disclosure provides ways to reduce the read time-delay and increases the reliability of nanopore readouts for DNA-based data storage. This is achieved, at least in part, by carefully encoding information to allow for reconstruction in the presence of very few reads with high deletion probabilities.
2.1 Notation
We denote the length of a string x by |x|, and its Hamming weight by w(x)=|{i:xi≠0}|. Given two strings x and y over the same alphabet, we denote their concatenation by x∥y. For a string x, we define x[a, b)=(xa, xa+1, . . . , xb-1) and x[a, b]=(xa, xa+1, . . . , xb). If |x|=n, we define x[a, ⋅]=(xa, xa+1, . . . , xn).
We say that y is a subsequence of x if there exist indices i1<i2< . . . <i|y| such xij=yj. Moreover, y is said to be a substring of x if y=x[a, a+|y|) for some 1≤a≤|x|−|y|+1. Given two strings x, yϵ{0, 1}n, we write x+y for the bitwise XOR of x and y. A run of length f in a string x is a substring of x comprising f identical symbols. Sets are denoted by bold letters such as S and T. Random variables are denoted by uppercase letters such as X, Y, and Z. The uniform distribution over {0, 1}t is denoted by Ut, and the binomial distribution on n trials with success probability p is denoted by Bin(n, p). The binary entropy function is denoted by h and all logarithms log are taken with respect to the base 2.
2.2 Almost k-Wise Independent Spaces
We start by defining almost k-wise independence and present a related result that we will find useful in our future derivations.
Definition 7 (ϵ-almost k-wise independent random variable). A random variable X ϵ{0, 1}m is said to be ϵ-almost k-wise independent if for all sets of k distinct indices i1, i2, . . . , ik we have |Pr[Xi|i=x1, . . . , Xik=xk]−2−k|≤ϵ for all (x1, . . . , xk)ϵ{0, 1}k.
The following result gives an efficient construction of an ϵ-almost k-wise independent space which can be generated from few uniformly random bits.
Lemma 8. For every m, k, and ϵ, there exists an efficiently computable function g: {0, 1}t→{0, 1}m with
such that g(Ut) is an ϵ-almost k-wise independent random variable over {0, 1}m, where Ut denotes the uniform distribution over {0, 1}t.
2.3 Nearly-Optimal Systematic Codes for Edit Errors
We require systematic codes that are robust against edit errors (deletions and insertions). Nearly-optimal systematic codes for adversarial edit errors have been recently constructed using optimal protocols for deterministic document exchange. The following result is relevant to our analysis.
Lemma 9. For every m and t<m there exists an efficiently encodable and decodable systematic code Cedit ⊆{0, 1}m+r with encoder Encedit:{0, 1}m→{0, 1}m+r and redundancy
that can efficiently correct up to t edit errors. In particular, if t=Θ(m), then the redundancy is r=O(m).
2.4 Trace Reconstruction
Next, we discuss several results pertaining to the worst-case and average-case trace reconstruction problem that will be useful for our constructions.
2.4.1 Worst-Case Trace Reconstruction
For worst-case reconstruction, a result used in Section 3 is summarized below.
Lemma 10. For every n and constant deletion probability d, there exists an algorithm that reconstructs an arbitrary string xϵ{0, 1}n with probability at least 1−exp(−2n) from exp(O(n1/3)) traces in time exp(O(n1/3))
2.4.2 Trace Reconstruction of Subsequence-Unique Strings
One of the key tools for our constructions in Section 4 is a modified version of the efficient trace reconstruction algorithm for what we refer to as subsequence-unique strings. This algorithm may also be used for average-case trace reconstruction. We start by defining subsequence-unique strings.
Definition 11 (w-sub sequence-unique string). A string xϵ{0, 1}n is said to be w-sub sequence-unique if for every a and b such that either a<b or b+1.1w<a+w we have that the substring x[a, a+w) is not a subsequence of x[b, b+1.1w).
Note that these strings have been under the name “sub string-unique” in other work. We proposed the name change to avoid confusion with a different definition under the same name, described herein. The following result about subsequence-unique strings was established previously.
Lemma 12. For w=100 log n and a small enough constant deletion probability d, there exists an algorithm that reconstructs every w-sub sequence-unique string xϵ{0, 1}n with probability 1−1/poly(n) from poly(n) traces in time poly(n).
Since a uniformly random string is w-subsequence-unique with high probability, Lemma 12 applies to average-case trace reconstruction. As we make explicit use of the algorithm behind Lemma 12, for the sake of clarity, we provide next a more in-depth discussion of the method. However, before we proceed to the actual description of the algorithm, we briefly introduce some definitions and basic related results.
Given integers i and j and a deletion probability d, we denote the probability that the i-th bit of a string appears as the j-th bit of its trace by PQ, j). Then, we have
The following lemma states some useful properties of P(i, j).
Lemma 13. If j≤(1−3d)i, then P(i,j)≥2Σi′>i P(i′,j). Furthermore, if (1−4d)i<j<(1−3d)i, we have P(i,j)≥exp(−6di).
Intuitively, the second part of Lemma 13 means that we have a good idea of the position of x; in the trace if i is small. The following result makes use of this. It states that we can recover the first O(log n) bits of an arbitrary string with poly(n) traces, which is required to bootstrap the trace reconstruction algorithm.
Lemma 14. Fix a string xϵ{0, 1}n, and suppose that we know x1, . . . , xh-1. Then, there is an algorithm that recovers xh from exp(O(hd log(1/d))) traces of x with probability 1−o(1), provided that d<1/3.
In the second part of the algorithm, we must look for matchings of certain strings within the traces. To this end, we introduce the following definition.
Definition 15. Fix a string xϵ{0, 1}n, and let T denote its trace. Then, we say that there is a matching of x[a, b) in T if there exists some u such that T [u−(b−a), u)=x[a, b).
Matchings of w-subsequence-unique strings have useful properties, as formalized in the following lemma.
Lemma 16. If x is w-subsequence-unique and there is a matching of x[a, a+w) in T, say at T[u−w, u), then the probability that Tu-1 does not come from x[a+w, a+1.1w) is at most nd0.001w.
We are now in a position to describe an algorithm introduced previously. We begin by setting w=100 log n, v=w/d, and j=(v−0.1w)(1−3d). Then, to recover a w-subsequence-unique string x, we proceed with two steps: First, we use the algorithm from Lemma 14 to recover the first v bits of x with poly(n) traces. Now, suppose we have recovered x1, . . . , xi-1 for i−1≥v. Our next goal is to recover xi with poly(n) traces.
Note that if i is relatively large, we cannot use the algorithm from Lemma 14 to recover x; anymore, as it would require more than poly(n) traces. To achieve our goal, we instead focus on finding matchings of the substring x[i−v−w, i−v) within the trace. Let T denote a trace of x, and suppose there is a matching of x[i−v−w, i−v) in Tat positions T [u−w, u). Then, we set V=T [u, ⋅], i.e., we let V be the suffix of the trace following the matching. The key property is that Pr[Vj=1] satisfies a threshold property depending on the value of xi. More precisely, there exist two positive values B1>B0 sufficiently far apart such that Pr[Vj=1]≤B0 if xi=0 and Pr[Vj=1]≥B1 if xi=1. Moreover, all terms in these inequalities can be estimated with a small error from poly(n) traces of x. As a result, we can reliably estimate x; by checking whether Pr[Vj=1]≤B0 or Pr[Vj=1]≥B1.
We prove next the threshold property for Pr[Vj=1]. Let R denote the position in x of the bit appearing in position u−1 in the trace T of the matching for x[i−v−w, i−v). In other words, R denotes the position in x of the last bit appearing in the matching in T. We may write
where the second equality follows from Lemma 16 with 0≤ϵ(x)≤nd0.001w. Using the first part of Lemma 13, we conclude that P(−r,j)≤½P(i−r,
By the second part of Lemma 13, since i−r≤v and v=w/d, we have P(i−r,j)≥2−9w. Combining this with Lemma 16 ford small enough means that the gap between the right hand side of (1) and (2) is at least 2−(9w+1). To finalize the argument, we note that (i) we can efficiently approximate Pr[Vj=1] to within an error of, say, 2−100w with high probability from poly(n) traces of x, and (ii) we can efficiently approximate Pr[R=/|R<i] to within the same error given that we know x1, . . . , xi-1, provided d is small enough. Since Pr[R<i]≥1−nd−0.001w by Lemma 16, we can further efficiently approximate Pr[R=r] to within an error of, say, 2−50w with high probability. From these observations, it follows that we can estimate xi correctly with high probability from poly(n) traces, where the degree of the polynomial is independent of i, as desired.
This section describes simple constructions of high-rate codes that can be efficiently reconstructed from a few traces. The idea behind the approach is the following: Each codeword contains markers, consisting of sufficiently long runs of 0's and 1's. Between two consecutive markers, we add a short block containing a codeword from an inner code satisfying a mild constraint.
Intuitively, the runs in the markers will still be long in the trace, and so we hope to be able to correctly identify the positions of all markers in a trace with high probability. After this is done, the trace can be split into many shorter, independent sub-traces corresponding to a block (and possibly some bits from the two markers delimiting it). Then, a worst-case trace reconstruction algorithm can be applied to the sub-traces. The savings in the number of traces required for reconstruction stem from the fact that subtraces are short, and that each trace can be utilized simultaneously (and independently) by all blocks. This idea for reconstruction almost works as is, except that the process of identifying the markers in a trace may be affected by long runs of 0's originating from a block between two markers. However, this can be easily solved by requiring that all runs of 0's in each block are short enough. Many codes, including codes with low redundancy, satisfy the desired property, and hence make for good candidates for the inner code.
We describe and analyze a code based on the idea discussed above in Section 3.1. Then, we consider a follow-up construction in Section 3.2 which requires fewer traces, at the expense of a decrease in the rate. At a high-level, this second code is obtained by introducing two levels of markers and adding some simple error-correction redundancy to the message prior to other encodings. Finally, in Section 3.3, we extend these ideas to the {A, C, G, T} alphabet in order to obtain high-rate codes with desireable properties for use in DNA-based storage. Namely, these codes have balanced GC-content and can be reconstructed from few traces. Such codes are designed by exploiting the fact that the marker-based constructions can be instantiated with a large range of inner codes, and we can make the inner code satisfy stronger constraints than before.
3.1 A Simple Construction
Here, we provide a precise description of the encoder Enc for our code C and prove Theorem 1. For simplicity, we consider d=½ throughout. Let =50 log n, and define two strings M0= and M1=. Then, a marker M is a string of length 2 of the form M=M0∥M1=|. We also require an efficiently encodable and decodable inner code C′⊆{0, 1}m+r with encoder Enc′: {0, 1}m→{0, 1}m+r where m=log2 n and r is the redundancy, satisfying the following property.
Property 17. For all cϵC and substrings s of c with |s|=√{square root over ( )}m, it holds that w(s)≥|s|/3.
In other words, every codeword of C′ has many 1's in all short enough sub strings. Such efficient codes exist with redundancy r=O(log m)=O(log log n). We provide a simple construction in Section 3.1.1.
Suppose we wish to encode an n-bit message xϵ{0, 1}n. The encoder Enc on input x proceeds through the following steps:
1. Split x into n/log2 n blocks, each of length log2 n such that:
x=x
(1)
∥x
(2)
∥ . . . ∥x
n/log
n;
2. Encode each block x(i) under the inner code C′ to obtain:
(i)
=Enc′(x(i))ϵ{0,1}log
3. Set the encoding of x, denoted by Enc(x), to be:
Enc(x)=∥
We remark that the first run and the last run are superfluous, and are added only to make the analysis simpler. Computing Enc(x) from x and decoding x from Enc(x) can both be done efficiently if the inner code C′ is efficiently encodable and decodable.
We now compute the redundancy of C. It is straightforward to see that
As mentioned before, we have r=O(log log n). Therefore, C can be made to have redundancy
In the remainder of this section, we prove Theorem 1 using C via a sequence of lemmas. For convenience, we restate the theorem below.
Theorem 18 (Theorem 1, restated). There is an efficient algorithm that recovers every cϵC from exp(O(log2/3 n)) traces in time poly(n) with probability 1−1/poly(n).
To prove Theorem 1, we proceed in steps: First, we show that the markers M still contain long enough runs after they are sent through the deletion channel. Then, we show that no long runs of 0's originate from the sub-traces associated with each block. This implies that we can correctly identify the position of the “01” string of each marker in the trace. Finally, we show that we can apply the worst-case trace reconstruction algorithm from Lemma 10 to recover each block with high probability and with the desired number of traces.
We start by proving that the markers M still contain long runs after they are sent through the deletion channel.
Lemma 19. Let 0L01L1 be the output of the deletion channel on input M. Then,
Pr[L0>10 log n,L1>0]≥1−n−3.
Proof. The result follows by a standard application of the Chernoff bound. More precisely, we have E[L0]=25 log n, and hence
To conclude the proof, we note that Pr[L1=0]==n−50, and that the two events in question are independent. GP-41,ART
We now show that no long runs of 0's originate from the sub-traces associated with each block.
Lemma 20. Let cϵC′. Then, a trace of c does not contain a run of 0's of length at least 10 log n with probability at least 1−n3.
Proof. Since cϵC′, a run of 0's of length at least 10 log n in the trace of c requires that at least 10×(log n/3)−1 consecutive 1's are deleted in c. The probability that this happens for a fixed sequence of 10×(log n/3)−1 consecutive 1's is at most n−33. Since there are at most O(log2 n) such sequences in c, by the union bound, it follows that the desired probability is at most n−3.
The next lemma follows immediately by combining Lemmas 19 and 20 with the union bound over the n/log2 n blocks.
Lemma 21. Consider the following event E: We correctly identify the separation between the traces of and from every marker in the trace of Enc(x) by looking for all 1's that appear immediately after a run of at least 10 log n 0's.
Then, E happens with probability at least 1−n−2 over the randomness of the trace.
We are now ready to prove Theorem 1. Let E denote the event described in Lemma 21. Then, Lemma 21 implies that, conditioned on E happening, we can split a trace T of Enc(x) into n/log 2 n strings T(1), . . . , Tn/log 2
1) The strings T (i) are independent;
2) Each string T (i) is distributed like a trace of |x(i)∥ conditioned on the high probability event E.
In fact, each string T (i) can be identified by looking for the (i−1)-th and i-th runs of 0 of length at least 10 log n in the trace T, and picking every bit in T immediately after the (i−1)-th run up to and including the i-th run.
Observe that |x(i)∥ has length O(log2 n). Suppose that we have t=exp(O(log n)2/3) independent traces T1, . . . , Tt of Enc(x). Let Eau denote the event that E holds for all Ti simultaneously. Combining Lemma 21 with a union bound yields
Pr[Eall]≥1−t/n2>1−1/n (4)
Fix some trace reconstruction algorithm A, and let EindFail(i) denote the event that A fails to recover a fixed string y(i)=∥x(i)∥ from t independent traces of y(i). Assuming that Eall holds, the strings T1(i), . . . , Tt(i) are distributed as t independent traces of y(i), each also satisfying the conditions that the first run is not completely deleted, the last run has length at least 10 log n in the trace, and there is no run of 0's of length at least 10 log n in the trace of x(i). We denote the event that these conditions hold for all of the t of independent traces y(i) by Esplit(i). Finally, we let Efail denote the event that we fail to recover Enc(x) from the t i.i.d. traces T1, . . . , Tt. Then, we have
The first equality follows from the discussion in the previous paragraph, the second inequality follows from (4), and the third inequality follows by the union bound. Instantiating A with the worst-case trace reconstruction algorithm from Lemma 10, we conclude from (6) that
Pr[Efail]≤n·exp(−2 log2 n)+1/n<2/n,
As a result, we can successfully recover x from exp(O(log n)2/3) traces of Enc(x) with probability at least 1−2/n. To conclude the proof, we note that we can repeat the process O(log n) times and take the majority vote to boost the success probability to 1−1/p(n) for any fixed polynomial p of our choice. The total number of traces required is still exp(O(log2/3 n)). Since recovering each x(i) from the associated traces takes time exp(O(log2/3 n)) and the inner code C′ has an efficient decoder, the whole procedure is efficient.
3.1.1 Instantiating the Inner Code
What remains to be done is to instantiate the inner code C′ with the appropriate parameters and properties.
To this end, we present a simple construction of an efficiently encodable and decodable inner code C′ with encoder Enc′:{0, 1}m→{0, 1}m+r and redundancy r=O(log m). We can then obtain the desired code by setting m=log2 n. The starting point is the following result.
Lemma 22. Let g:{0, 1}t→{0, 1}m be the function whose existence is guaranteed by Lemma 8 with k=3w and ϵ=2−10w for w=100 log m (hence t=O(log m)). Fix some xϵ{0, 1}m and consider the random variable Y=x+g(Ut). Then, with probability at least 1−2/m, we have that Y satisfies the following property:
Property 23. w(Y [a, a+w))≥0.4w simultaneously for all 1≤a≤m−w+1.
Proof. Fix some a. Then, we have
The first inequality follows because Y is ϵ-almost k-wise independent, and the second inequality follows from a standard bound on the volume of the Hamming ball and the fact that 23wϵ<2−w. Since there are at most m choices for a, by the union bound we conclude that Y fails to satisfy the desired property with probability at most m·2/m2=2/m, as desired.
Given xϵ{0, 1}m, we evaluate Enc′(x) as follows: We iterate over all zϵ{0, 1}t until we find z such that y=x+g(z) satisfies w(s[a, a+w))≥0.4w. Such a string z is known to exist by Lemma 22 and can be found in time poly(m) since t=O(log m). Then, we set Enc′(x)=z∥x+g(z).
Observe that the redundancy of C′ is exactly|z|=t=O(log m), and that we have encoders and decoders for C′ running in time poly(m) since t=O(log m). To see that C′ satisfies the property required in this section, fix some substring s of Enc′(x) such that |s|=√{square root over ( )}m. Then, w(s)≥0.4w·|s|/w−t≥0.39|s| provided that m is large enough.
Finally, we remark that the code used in this marker-based construction is just an example of a viable inner code C′. Any structured family of codes satisfying Property 17 may be used instead, and one may envision adding more constraints to C′, depending on the application constraints at hand. We exploit this fact in Sections 3.2 and 3.3. For example, in Section 3.3 we will require that C′ is a code over {A, C, G, T} satisfying an analogue of Property 17 while also having balanced GC-content.
3.2 Adding a Second Level of Markers
In our next construction, we exploit the fact that the marker-based construction from Section 3.1 can be instantianted with a large range of inner codes to prove Theorem 2. To do so, we show that we can iterate the marker-based construction so that we can split a trace into even smaller sub-traces with high probability.
This leads to a code requiring fewer traces, but with a penalty in the redundancy. We restate Theorem 2 for convenience.
Theorem 24 (Theorem 2, restated). There exists an efficiently encodable code C0⊆{0,1}n
As before, for simplicity we set d=½ throughout the section. We will use the same construction blueprint as in Section 3.1, except for the following differences:
1) We assume the n-bit message x belongs to a binary code CHam ⊆{0, 1}n with encoder EncHam:{0,1}n
Such efficiently encodable and decodable codes are known to exist with redundancy
The reasons for using this encoding will be made clear later;
2) The inner code C′ differs from the one used in Section 3.1.1.
If C denotes the code obtained via the reasoning of Section 3.1 and Enc corresponds to its encoder, then the encoder Enc0:{0,1}n
Enc
0
=Enc∘Enc
Ham.
We proceed to describe the encoder Enc′ for the inner code C′ of C. Given yϵ{0, 1}m, where m=log2 n, we split y into m/log2 m blocks of length log2 m,
y=y
(1)
∥y
(2)
∥ . . . ∥y
(m/log
m).
Then, we take C′⊆{0, 1}m′+r′ with encoder Enc″:{0, 1}m′→{0, 1}m′+r′ as the efficiently encodable and decodable code constructed in Section 3.1.1 with message length m′=log2 m and redundancy r′=O(log m′)=O(log log m). For each i, we define
Enc′(y)=M′∥
Observe that we can efficiently decode y from Enc′(y) provided that C″ is efficiently decodable.
We first compute the redundancy of the inner code C′ and the resulting code C obtained as in Section 3.1. We have
Thus, C′ has redundancy r=O(m/log m). Plugging r into (3) and recalling that m=log2 n, we conclude that C has redundancy
As a result, since
the code C0 has redundancy r0=O(n0/log log n0), as desired.
We now show that C′ satisfies Property 17. First, we observe that C″ satisfies Property 23 with m′ in place of m. Then, since each M′ has weight 0.5|M′|, we conclude that every substring s of Enc′(y) such that |s|=√{square root over ( )}m satisfies
w(s)≥0.4w·|s|/w−≥0.39|s|,
provided m is large enough, since =O(log m). As a result, Lemma 21 holds for this choice of inner code, and we can hence focus solely on the trace reconstruction problem for strings of the form
|Enc′(y)∥=∥M′∥
where =O(log n)=O(√{square root over ( )}m), and provided the number of traces used is significantly smaller than n. We now give a trace reconstruction algorithm for strings of the form (7) that requires exp(O(log2/3 m))=exp(O(log log n0)⅔) traces and time, and succeeds with probability at least 1−1/poly(m)=1−1/poly(log n0).
We have the following two lemmas whose proofs are analogous to those of Lemmas 19 and 20 and hence omitted.
Lemma 25. Let 0L
Pr[L0>10 log m,L1>0]≥1−m−3.
Lemma 26. Let cϵC″. Then, a trace of c does not contain a run of 0's of length at least 10 log m with probability at least 1−m3.
Combining Lemmas 25 and 26 with the union bound leads to the following analogue of Lemma 21.
Lemma 27. Consider the following event E′: We correctly identify the separation between the traces of and from every marker in the trace of Enc′(x) by looking for all 1's that appear immediately after a run of at least 10 log m 0's.
Then, E′ happens with probability at least 1−m−2 over the randomness of the trace.
As in Section 3.1, Lemma 27 implies that, conditioned on E′ happening for a trace T of ∥Enc′(y)∥, we can split T into independent sub-traces T(i) each distributed like a trace of ∥Enc″(y(i))∥ conditioned on the high probability event E′.
Let A denote the worst-case trace reconstruction algorithm from Lemma 10 for strings of length O(m′)=O(log2 m), with failure probability at most exp(−Ω(log2 m)). A reasoning similar to that preceding (6) with Lemma 27 in place of Lemma 21, and the code C′ designed in this section in place of C shows that, using algorithm A, we fail to recover Enc′(y) from exp(O(log2/3 m)) i.i.d. traces of ∥Enc′(y)∥ with probability at most
m·exp(−Ω(log2 m))+1/m<2/m. (8)
Let A′ denote the algorithm that recovers Enc′(y) from exp(O(log2/3 m)) i.i.d. traces of ∥Enc′(y)∥ with failure probability at most 2/m as described above. We hope to instantiate (6) directly with A′ to obtain the desired upper bound on the reconstruction failure probability for C. However, this approach does not produce a satisfactory result as the failure probability of A′ is 2/m=1/poly(log n), which is too large to be used in the union bound.
Recall from Section 3.1 that, given xϵ{0, 1}n, the codeword Enc(x) of C is obtained by splitting x into n/log2 n blocks x(i) and encoding each block with the encoder Enc′ associated with C′. From the discussion in the previous paragraph, a fraction of blocks x(i) will be reconstructed with errors. Below we argue that this fraction is of size at most 10/log2 n0 with probability at least 1−2/n0. The reasoning is similar in spirit to that used to derive (5), and it suffices to complete the proof of Theorem 2. In fact, suppose we recovered {tilde over (x)}, which is a guess of x with at most a (10/log2 n0)-fraction of incorrect blocks. In particular, the relative Hamming distance between x and x is at most 10/log2 n0. Since the relative distance of CHam is at least 30/log2 n0 and we assumed that xϵCHam, it follows that DecHam({tilde over (x)})=DecHam(x)=x0.
Therefore, we conclude that we can recover the underlying message x0 with probability at least 1−2/n0 from exp(O(log2/3 m))=exp(O(log log n0)2/3) i.i.d. traces of Enc0(x). This proves Theorem 2.
As the last step, we show that the fraction of bad blocks is small enough with high probability. Suppose that we have access to t=exp(O(log2/3 m)) i.i.d. traces T1, . . . , Tt of Enc(x), where Enc is the encoder associated with C. Let E denote the event from Lemma 21, and let Eall denote the event that E holds for all Ti simultaneously. As before, assuming that Eall holds, the strings (Ti(i), . . . , Tt(i))1≤i≤n/log
The first equality follows from the discussion in the previous paragraph, and the second inequality follows from Lemma 21 and the fact that n>n0. Recalling (8), which asserts that the failure probability for A′ is at most 2/m, shows that
Pr[IindFail(i)]≤2/m=2/log2 n<2/log2 n0
holds for every i. Since the IindFail(i) are independent for all i, a standard application of the Chernoff bound yields the following lemma.
Lemma 28. We have
We remark that the Chernoff bound yields a stronger upper bound than the one featured in Lemma 28. However, for simplicity we use a weaker upper bound that still suffices for our needs. Combining (9) with Lemma 28 allows us to conclude that Pr[Efail]<2/n0, as desired.
3.3 A Code for DNA-Based Data Storage Decodable from a Few Traces
We describe next how to adapt the ideas from Sections 3.1 and 3.2 in order to construct codes over the alphabet {A, C, G, T} that have balanced GC-content and provably require few traces for reconstruction. As already pointed out, strings with balanced GC-content are significantly easier to synthesize than their non-balanced counterparts. Therefore, constructions accommodating this constraint are well-suited for use in DNA-based data storage.
The constructions follow those outlined in Sections 3.1 and 3.2. The only modifications are the choice of markers and the definition of the inner code. We focus on discussing these changes and their properties within the setting of Section 3.1. The full argument and the extension for the two-level marker-based construction of Section 3.2 follow in a straightforward manner.
We first describe the modified markers. The marker Mused throughout the section is of the form M=∥, where =25 log n and n is the message length. Observe that this marker has the same length as the original marker in Section 3.1. Moreover, M has balanced GC-content.
In order to proceed as in Section 3.1 we need to design an efficiently encodable and decodable inner code C′⊆{A, C, T, G}m′ with balanced GC-content which satisfies a property analogous to Property 17.
Suppose that C′ has encoder Enc′:{0, 1}m→{A, C, T, G}m′
and that m′=m/2+r, where m=log2 n as in Section 3.1 and r denotes the redundancy to be determined. Given the composition of M, the property we wish C′ to satisfy is the following: Property 29. For all cϵC′ and substrings s of c with |s|=√{square root over ( )}m, it holds that at least |s|/3 symbols of s are Tor G.
Similarly to Lemma 20, it can be shown that if C′ satisfies Property 29, then with high probability a trace of cϵC will not contain long runs consisting only of symbols A and C. As a result, with high probability we can easily split a trace into many sub-traces associated with different blocks as in Section 3.1. This is accomplished by looking for all long substrings of the trace consisting only of A's and C's in the trace. The reason is that, with high probability, each such substring consists of the trace of an substring from a marker M possibly with some extra symbols prepended. In that case we can correctly identify the separation between the traces of (AC) and in all markers by looking for the first T or G after every sufficiently long substring of A's and C's.
We proceed to describe the encoder Enc′ of the inner code C′ that has redundancy r=O(log m).
We combine the code from Section 3.1.1. along with a requirement of an efficiently encodable and decodable binary balanced code C1 with encoder Enc1:{0,1}m/2→{0,1}m/2+r
The code C′ is defined via an encoding Enc′:{0, 1}m→{A, C, G, T}m/2+r of the form
Enc′(x)=Ψ(Enc1(x(1)),Enc2(x(2))),
where x=x(1)∥x(2)ϵ{0, 1}m/2×{0, 1}m/2. It is clear that decoding x from Enc′(x) can be performed efficiently. We hence have the following lemma.
Lemma 30. The inner code C′ has balanced GC-content and satisfies Property 29.
Proof Suppose that c=Ψ(c1, c2), where c1ϵC1 and C2ϵC2. To see that c has balanced GC-content, note that the number of C's and G's in c equals the weight of c1. We have w(c1)=|c1|/2 since C1 is a balanced code, and hence c has balanced GC-content. To verify that C satisfies Property 29, note that the number of T's and G's within a sub string c[i,j] equals w(c2[i, j]). Since C2 satisfies Property 17, the proof follows.
Given Lemma 30, we can now proceed along the steps described in Section 3.1 by splitting a trace of C into many short sub-traces associated with different blocks, and then applying a worst-case trace reconstruction algorithm on each block. We remark that although the algorithm from Lemma 10 works for worst-case trace reconstruction over binary strings, it can be easily adapted for quaternary strings. In fact, if t traces suffice for a worst-case trace reconstruction algorithm to reconstruct a string in {0, 1}n with high probability, then a simple modification of this procedure recovers any quaternary string in {A, C, G, T}n with 2t traces. This is achieved by mapping the symbols in the first t traces over {A, C, G, T} to traces over {0, 1} according to, say, A→0, C→0, G→1, T→1, and the symbols in the last t traces according to A→0, C→1, G→0, T→1.
We can now run the binary worst-case algorithm on both sets of t traces, and recover the original string over {A, C, G, T} from the two outputs.
Taking into account the previous discussion, applying the reasoning from Section 3.1 to the marker M and inner code C′ defined in this section leads to Theorem 3, which we restate for completeness.
Theorem 31 (Theorem 3, restated). For every deletion probability d<1, there exists an efficiently encodable code C⊆{A, C, G, T}n+r with redundancy r=O(n/log n) and balanced GC-content that can be efficiently reconstructed from exp(O(log n)2/3) traces.
Following the reasoning from Section 3.2 with the modified markers and C″ instantiated with the inner code C′ we designed in this section proves Theorem 4, which we also restate for completeness.
Theorem 32 (Theorem 4, restated). For every constant deletion probability d<1, there exists an efficiently encodable code C⊆{A, C, G, T}n+r with redundancy r=O(n/log log n) and balanced GC-content that can be efficiently reconstructed from exp(O(log log n)2/3) traces.
Finally, two comments are in place regarding the choice of markers. First, the marker sequence M=| may lead to hairpin formations when single stranded DNA is used. Hairpins are doublestranded folds, but may be easily controlled through addition of urea or through temperature increase. Second, repeats such as marker repeats are undesirable as they may lead to issues during DNA synthesis. To mitigate this issue, one can alternate marker sequences. For example, two valid marker options are | and |, and any other marker where the sets of symbols used in each side are disjoint and C and G do not appear in the same side is appropriate for use in the construction.
Note that alternating markers in turn requires alternating the inner codes used between markers. This can be accommodated in a straightforward manner. Suppose that the block x(i) precedes an | marker. Then, we encode x(i) as usual with Enc′ as defined in this section. However, if x(i) precedes an | marker, then we encode x(i) by first computing Enc′(x(i)), and then swapping all G's and C's in the encoding. Observe that in both cases the encoding has balanced GC-content. Moreover, since C′ satisfies Property 29, with high probability the trace of each block's encoding will not have long substrings containing only A's and C's (resp. A's and G's) before an | marker (resp. | marker).
As before, this means that, with high probability, we can correctly split the full trace into the relevant subtraces by alternately looking for long substrings composed of A's and C's only, and of A's and A's and G's only. In fact, the end of such long substrings corresponds to the beginning of the traces of the and substrings of the marker, respectively.
In Section 3, we gave a construction of marker-based codes that require a few traces for reconstruction. A simple property of the inner code ensured that we can correctly identify all markers with high probability, effectively dividing the global trace into many independent, shorter traces. After this, we applied the worst-case trace reconstruction algorithm from Lemma 10 on each short trace in order to obtain the desired codes.
It seems plausible, however, that one could design the inner code more carefully so that many fewer traces are needed to recover the short codewords contained between the markers. This is the main problem we address in this section. We design a code that, when used as the inner code in the construction from Section 3, leads to an almost exponential reduction of the number of traces required for reconstruction with only a slight decrease in the code rate, provided that the deletion probability is a sufficiently small constant. The trace reconstruction algorithm we use is a variation of the algorithm for average-case trace reconstruction described elsewhere.
Our starting point is a low redundancy code with the property that it can be reconstructed from poly(n) traces. We discuss this construction in Section 4.1. Then, in Section 4.2 we show how to adapt this code so that it can be successfully used as an inner code in the marker-based construction introduced in Section 3.
4.1 Low Redundancy Codes Reconstructable from Polynomially Many Traces
In what follows, we prove Theorem 5. We restate the result for convenience.
Theorem 33 (Theorem 5, restated). For small enough deletion probability d, there exists an efficiently encodable code C⊆{0, 1}n+r with encoder Enc:{0, 1}n→{0, 1}n+r and redundancy r=0(log n) that can be efficiently reconstructed from poly(n) traces with probability at least 1−exp(−n).
The code we construct to prove Theorem 5 will be the starting point for the proof of Theorem 6 in Section 4.2. Roughly speaking, our code encodes n-bit messages into codewords that are almost w-subsequence-unique for w=0(log n), in the sense that all but the first O(log n) bits of the codeword comprise a w-subsequence-unique string. This is possible because an ϵ-almost k-wise independent random variable over {0, 1}n with the appropriate parameters is w-subsequence-unique with high probability. We make this statement rigorous in the following lemma. We note that the technique in the lemma below has already been used to obtain strings satisfying related properties, such as substring-uniqueness, with high probability.
Lemma 34. Let g:{0, 1}t→{0, 1}m be the function guaranteed by Lemma 8 with k=3w and ϵ=2−10w for w=100 log m (hence t=O(log m)). Fix some xϵ{0, 1}m and define the random variable Y=x+g(Ut). Then, with probability at least 1−1/poly(m) it holds that Y is w-subsequence-unique.
Proof First, note that Y is ϵ-almost k-wise independent. This proof follows along the same lines as the proof that a random string is w-subsequence-unique with high probability with a few simple modifications.
Without loss of generality, fix a and b such that a<b, and fix distinct indices i1, . . . , iwϵ[b, . . . , b+1.1w). For convenience, let S={i1, . . . , iw}, S′=[b, b+1.1w)−S, and u=min(a+w, b). Then,
We now show that Y [a, u) and YS′ completely determine YS under the constraint YS=Y [a, a+w). This can be seen by induction. First, we must have Yi1=Ya, and Ya is determined by Y [a, u) since a<u.
Now, suppose that Yi1, . . . , Yij are determined by Y [a, u) and YS′. It must be the case that Yi
As a result, we conclude that there exists a string
Pr[YS=Y[a,a+w),Y[a,u)=y,YS′=y′]=Pr[YS=
Since Y is ϵ-almost 3w-wise independent and fewer than 3w coordinates are fixed, we have
Pr[YS=
for all y and y′. Combining (10), (11), and (12), we conclude that
Pr[YS=Y[a,a+w)]≤2u-v,20.1w(2−1.1w−(a-u)+23wϵ)≤2−w+24.1wϵ≤2−w+1,
since u−a≤w and ϵ=2−10w. Since there are
choices for S for each pair (a, b) and fewer than m2 possible pairs (a, b), the probability that Y is not w-subsequence-unique is at most
as desired.
Lemma 34 naturally leads to a simple, efficient candidate construction of the encoder Enc: Given xϵ{0, 1}n, we first iterate over all zϵ{0, 1}t until we find z such that x+g(z) is w-subsequence-unique. Most strings z satisfy this, according to Lemma 34. Moreover, since t=O(log n), we can iterate over all such z in time poly(n), and verify whether x+g(z) is w-subsequence-unique for each z in poly(n) time. To recover x from x+g(z) we need to provide z to the receiver. Therefore, the encoder Enc for C maps a message xϵ{0, 1}n to the codeword
Enc(x)=z∥x+g(z)ϵ{0,1}n+t, (13)
where z is the first string (in lexicographic order) such that x+g(z) is w-subsequence-unique. Observe that the redundancy of C is exactly t=O(log n).
4.1.1 the Trace Reconstruction Algorithm
In this section, we describe an efficient trace reconstruction algorithm for C that works whenever the deletion probability is a small enough constant, thus proving Theorem 5. This algorithm works very similarly to the one described in Section 2.4.2. As before, we shall set w=100 log n, v=w/d=O(log n) and j=(v−0.1w)(1−3d)=O(log n). Given a codeword c=Enc(x)=+g(z), we proceed as follows:
First, we apply the algorithm from Lemma 14 to recover z and the first 2v+w=O(log n) bits of y=x+g(z) with poly(n) traces (repeating the process O(n) times if necessary) and success probability 1−exp(−Ω(n)). Now, suppose that we know y1, . . . , yi-1 for i−1≥2v+w. We show how to find)), with probability 1−exp(−Ω(n)) from poly(n) traces, which concludes the proof of Theorem 5.
Let T denote a trace of c. As in Section 2.4.2, we will look for a matching of y[i−v−w, i−v) within T. However, we shall discard matchings that occur too early in T. More precisely, suppose that y[i−v−w, i−v) is matched with T [u−w, u). We call such a matching good if u−w>|z|. If T does not contain a good matching of y[i−v−w, i−v), we discard it. Otherwise, if the first good matching occurs at T [u−w, u), we let V=T [u, ⋅] and discard the remaining bits of T. Our observations so far are summarized in the following lemmas.
Lemma 35. For d small enough, the probability that a good matching occurs in T is at least 2−(w+1).
Proof. First, observe that the probability that no bit in y[i−v−w, i−v) is deleted is exactly (1−d)w≥2−w.
Given this, suppose that y[i−v−w, i−v) shows up in positions T [U−w, U). Then, the probability that the given matching is good equals Pr[U>|z|+w], and |z|+w≤Cw for a fixed constant C>0, since |z|=O(log n). Note that we may assume i−v−w≥v=w/d since we have already learned the first 2v+w bits of y. We may also choose d< 1/10 small enough such that v>Cw. Then, we have
Pr[U≤|z|+w]≤Pr[Bin(2Cw,1−d)≤Cw]<½,
where the last inequality follows from an application of the Chernoff bound. Concluding, the trace T contains a good matching with probability at least ½ ·2−w=2−(w+1).
Lemma 36. The probability that the last bit of a good matching in T does not come from y[i−v, i−v+0.1w) is at most nd−w/100≤2−100w if d is small enough.
Proof. The probability that the event in question happens is at most the probability that more than 0.1w bits are deleted from some substring y[b, b+1.1w). To see this, first note that the bits in a good matching must come from y. If at most 0.1w bits are deleted from every substring y[b, b+1.1w), then the w bits of the good matching in T for y[i−v−w, i−v) must be a subsequence of y[b, b+1.1w) for some b, which means y[i−v−w, i−v) appears as a subsequence of y[b, b+1.1w). Since y is w-subsequence-unique, for this to happen we must have b≤i−v−w and b+1.1w≥i−v. Now suppose that the last bit of the good matching in T does not come from y[i−v, i−v+0.1w). Then, it must be the case that y[i−v−w, i−v) is a subsequence of y[b, i−v−1). Since i−v−1<i−v, this violates the w-subsequence-uniqueness property of y.
For a fixed b, the probability that more than 0.1w bits are deleted from y[b, b+1.1w) is at most d−w/100 for d small enough. The result then follows by a union bound, since there are fewer than n choices for b.
Let Egood denote the event that a good matching occurs in T. From Lemma 35 and the fact that we can efficiently check whether Egood occurred for T, it follows that we can efficiently estimate
Pr[Vj=1|Egood]
to within an error of, say, 2−100w from poly(n) traces, with probability at least 1−exp(−Ω(n)). Then, we proceed similarly to Section 2.4.2. Let R be the random variable denoting the coordinate in y of the last bit appearing in the good matching within T We may then write
for 0≤ϵi(c)≤2−100w, by Lemma 36. The second equality follows because, once R=r is fixed, V does not depend on whether Egood occurs or not, but only depends on the traces of z and y[1, r]. Therefore, as in (1) and (2) we have
Similarly to what was done in Section 2.4.2, since i−r≤v and v=w/d, the second part of Lemma 13 implies that P(1−r, j)>2−9w. Combining this result with Lemma 36 shows that the gap between the right hand sides of (14) and (15) is at least 2−(9w+1). Each term Pr[R=r|Egood can be approximated to within an error of 2−90w with probability at least 1−exp(−Ω(n)) in time poly(n). This is accomplished by first using z and the values y1, . . . , yi-1 that we have already recovered to estimate Pr[R=r|Egood, R<i] to within a small enough error and with high probability. Then, the fact that Pr[R<i|Egood]≥1−2−100w and Lemma 36 imply that
|Pr[R=r|Egood]−Pr[R=r|Egood,R<i]|≤2·2−100w,
which in turn implies a good enough approximation for Pr[R=r|Egood].
Since we know y1, . . . , yi-1, the discussion above suggests that we can approximate the right hand side of (14) and (15) to within an error of
2−100w+n2·2−90w≤2−80w
with high probability. As already mentioned, we can estimate Pr[Vj=1|Egood] to within error 2−100w from poly(n) traces in time poly(n) with probability at least 1−exp(−Ω(n)). Consequently, with probability 1−exp(−Ω(n)) we can recover yi correctly from poly(n) traces, where the degree of this polynomial is independent of i. The success probability can be made at least 1−exp(−Cn) for any fixed constant C of our choice by repeating the process O(n) times and taking the majority vote. Overall, we must recover fewer than n positions of y, and each position requires poly(n) traces, where the degree of this polynomial is independent of the position of the bit. As a result, the total number of traces required is poly(n) and the overall success probability is 1−1/poly(n). This proves Theorem 5.
4.2 Using the Code within a Marker-Based Construction
Next, we combine the constructions from Sections 3 and 4.1 with some additional modifications in order to prove Theorem 6, which we restate here.
Theorem 37 (Theorem 6, restated). For small enough deletion probability, there exists an efficiently encodable code C with encoder Enc:{0, 1}n→{0, 1}n+r and redundancy r=O(n/log n) that can be efficiently reconstructed from poly(log n) traces with probability 1−1/poly(n).
The basic idea is that we would like to use the code designed in Section 4.1 as the inner code C′ for the construction of C in Section 3. Then, we could apply the trace reconstruction algorithm from Section 4.1.1 on each sub-trace and mitigate the use of worst-case trace reconstruction algorithms. This idea includes some modifications to the code from Section 4.1 to allow the construction to go through.
The first issue we have to address is for the inner code C′ to satisfy Property 17. If this property holds, then the reasoning of Section 3 implies that we can focus on the trace reconstruction problem for strings of the form
∥c∥, (16)
where cϵC′ has length O(log2 n) and =O(log n), as long as we use a sub-polynomial number of traces in n. From here onwards we focus solely on this setting. If we were to directly apply the trace reconstruction algorithm from Section 4.1.1, we would run into a problem. For the aforementioned algorithm to work, we need to bootstrap it by recovering the first few bits of c using the procedure described in Lemma 14. However, in this case c only appears after a run of length =O(log n). Even though we know the previous bits, we still require poly(n) traces to recover the first bit of c in this way, which is not acceptable as we want to use poly(log n) traces. Consequently, we need an alternative bootstrapping method. Another issue we need to resolve is that the reconstruction algorithm from Section 4.1.1 assumed that all but the first few bits of c lead to a subsequence-unique string. However, this is not the case here, as we must deal with a string of the form c∥.
Before we proceed to describe a modified version of our code from Section 4.1 that avoids the issues raised above, we first prove the following lemma.
Lemma 38. Let g:{0, 1}t→{0, 1}m be the function guaranteed by Lemma 8 with k=3w and ϵ=2−10w for w=100 log m (hence t=O(log m)). For arbitrary and xϵ{0, 1}m, define the random variable Y=x+g(Ut)∥. Then, with probability at least 1−1/poly(m) we have that Y satisfies the following property.
Property 39. For any a and b such that a+w≤min(m+1, b), we have that Y [a, a+w) is not a subsequence of Y [b, b+1.1w).
Proof. Fix a pair (a, b) satisfying a+w≤min(m+1, b) and let S⊆[b, b+1.1w) be a set of size w. Let u=min(m+1, b+1.1w). Then, we have
Observing that YS is completely determined by Y [b, u) and Y [m+1, b+1.1w) and that Y [m+1, b+1.1w) is fixed, we have
for some y′ determined by y. Since x+g(Ut) is ϵ-almost 3w-wise independent and fewer than 3w coordinates are fixed, we have
Pr[Y[a,a+w)=y′,Y[b,u)=y]≤2−w−(u−b)+23wϵ.
Therefore, it follows that
Pr[Y[a,a+w)=YS]≤2u−b(2−w−(u−b)+23wϵ)≤2−w+24.1wϵ≤2−w+1.
Since there are fewer than m3 choices for pairs (a, b) and
choices for S, from the union bound, we conclude similarly to what we did in the proof of Lemma 34 that the probability that the desired event does not happen is at most
Intuitively, Lemma 38 guarantees that x+g(Ut) satisfies a stronger form of subsequence-uniqueness with high probability. In fact, not only is x+g(Ut) w-subsequence-unique with high probability based on Lemma 34, but also is it impossible to find a substring of x+g(Ut) that is a subsequence of x+g(Ut)∥ elsewhere.
We are now ready to describe our modified inner code C′ with encoder Enc′:{0, 1}m→{0, 1}m+r′. On an input message xϵ{0, 1}m, Enc′ operates as follows:
1. Set x′=∥x for =10=O(√{square root over ( )}m). Let m′=|x′| and set w=100 log m′;
2. Iterate over all zϵ{0, 1}t for t=O(log m′)=O(log m) until a z such that x′+g(z) is w-subsequence unique and simultaneously satisfies Properties 23 and 39 is found. Such a string z is guaranteed to exist because all such properties hold for x′+g(Ut) with probability 1−o(1) (see Lemmas 22, 34, and 38). Moreover, whether x′+g(z) satisfies all three properties can be checked in time poly(m);
3. Obtain z′ from z by setting z′=Encedit(0∥z), where Encedit is the encoder of the systematic code Cedit from Lemma 9 robust against |z|/2 edit errors and with redundancy O(|z|)=O(log m). Here, d is assumed to be a small enough constant so that 5d|z′|<|z|/2, i.e., Cedit can correct a 5d-fraction of edit errors in z′. This is possible because |z′|=O(|z|);
4. Define Enc′(x)=z′∥x′+g(z)=z′∥y′.
For a given message xϵ{0, 1}m, we can compute Enc′(x) in time poly(m). Furthermore, recalling that m=log2 n in the construction of Section 3.1, the redundancy of C′ is
r′=|z′|+
=O(log m+√{square root over ( )}m)=O(√{square root over ( )}m)=O(log n).
If we use C′ as the inner code in the construction of C from Section 3.1, then according to (3) we obtain an overall redundancy
for C, as desired. It is also easy to see that C′ satisfies Property 17. By the choice of z, we have w(y′ [a, a+w))≥0.4w for every a and w=100 log m′. Therefore, for any substring s such that |s|=√{square root over ( )}m we have
w(s)≥0.4|x|−|z′|≥0.39|s|
provided m is large enough, since |z′|=O(log m). As a result, the reasoning used in Section 3.1 applies to this choice of C′. To prove Theorem 6, it remains to give a trace reconstruction algorithm to recover strings of the form ∥Enc′(x)∥ from poly(m)=poly(log n) traces with probability, say, 1−n−10.
To address the problem, suppose we already have such an algorithm, and call it A. Recall (6) and the definition of the event EindFail(i) from Section 3.1. Instantiating EindFail(i) with algorithm A leads to the bound Pr[EindFail(i)]≤n−10, for all i. Combining this observation with (6) allows us to conclude that the probability that we successfully recover cϵC from poly(log n) i.i.d. traces of c is at least 1−2/n. Similarly to Section 3.1, we can boost the success probability to 1−1/p(n) for any fixed polynomial of our choice by repeating the process O(log n) times and by taking a majority vote.
4.2.1 the Trace Reconstruction Algorithm
Next, we analyze an algorithm for recovering strings of the form Enc′(x)∥ from poly(m)=poly(log n) traces with probability 1−1/poly(n). As discussed before, we proceed by adapting the algorithm from Section 4.1.1, which in turn is a modified version of the algorithm from Section 2.4.2.
The main difference between the current and the two previously discussed settings is that the original bootstrapping technique cannot be applied, as Enc′(x) is enclosed by two long runs. We start by showing that the structure of Enc′ allows for a simple alternative bootstrapping method.
Recall that c=Enc′(x)=z′∥y′, where y′=x′+g(z) and the first O(√{square root over ( )}m) bits of x′ are zero. Therefore, if we can recover z from a few traces of ∥c∥, then we can recover the first O(√{square root over ( )} m) bits of y′, which suffices for bootstrapping, by simply computing g(z). The following lemma states that we can recover z with high probability from O(log n) traces.
Lemma 40. There is an algorithm that recovers z from O(log n) traces of with probability at least 1−n−10.
Proof. We begin by recalling that z′=Encedit(0∥z), and that Cedit is systematic. This means z′1=0, and so with probability 1−d, the first 0 appearing in the trace will correspond to z′1.
Given a trace T of ∥c∥, we proceed as follows: Let u denote the position of the first 0 in T. Then,
we take {tilde over (z)}=T [u, u+(1−d)|z′|), feed {grave over (z)} into Decedit, and let the corresponding output be our guess for z. The probability that this procedure fails to yield z is at most the probability that z′1 was deleted, plus the probability that {tilde over (z)} is too far away in edit distance from z′ given that z′1 was not deleted. We proceed to bound both probabilities. First, the probability that z′1 is deleted is exactly d. Second, we assume z′1 is not deleted and let L denote the length of the trace of z′[2, ⋅] within T. We have E[L]=(1−d)(|z′|−1). Therefore, a Chernoff bound gives
Since d is a constant and |z′|=Θ(log m), we conclude that for m large enough, we have
Pr[|L−(1−d)(|z′|−1)|≥2d(|z′|−1)]<⅕.
As a result, with probability at least ⅘ we have that {tilde over (z)} is within edit distance 5d|z′|<|z|/2 from z′. If this distance condition holds, then Decedit({tilde over (z)})=z.
In summary, the procedure fails to return z with probability at most d+⅕<¼ if d is small enough. Repeating this procedure O(log n) times and taking the majority vote ensures via a Chernoff bound that we can recover z from O(log n) traces with success probability at least 1−1/p(n), for p any choice of a fixed polynomial.
Once z has been recovered, the bits of ∥c∥=∥z′∥y′∥ are known up to and including the first =O(√{square root over ( )}m) bits of y′. Our last task is to recover the remaining bits of y′, and given that we have sufficiently many initial bits from y′ we may to this end use the ideas from Section 4.1.1. The differences with respect to Section 4.1.1 are the following:
1) Instead of y, we use y″=y′∥;
2) We are only interested in recovering y″i for <i≤|y′|, since we already know all other bits of y″;
3) We change the threshold used to declare that a matching is good: In this case, if T is a trace of ∥c∥ and y″ [i−v−w, i−v] is matched with T [u−w, u], then the matching is said to be good if u−w>+|z′|. This change ensures that the bits in a good matching always come from y″=y′∥.
Two key lemmas now follow from the previous discussion. Their statements and proofs are similar to the ones of Lemmas 35 and 36 from Section 4.1.1, respectively, and we hence only discuss relevant differences. Henceforth, we use T to denote a trace of ∥c∥.
Lemma 41. The probability that a good matching occurs in Tis at least 2−(w+1).
Lemma 42. For <i≤[|y′|, the probability that the last bit of a good matching in T does not come from y″[i−v, i−v+0.1w] is at most nd−w/100≤2−100w if d is small enough.
Proof. Similarly to the proof of Lemma 36, the probability of the event in the statement of the lemma is upper bounded by the probability that more than 0.1w bits are deleted from some substring y″ [b, b+1.1w).
We explain next why this is true. First, note that the bits in a good matching must come from y″. Suppose that at most 0.1w bits are deleted from every substring y″ [b, b+1.1w). Then, y″ [i−v−w, i−v) must be a subsequence of y″ [b, b+1.1w) for some 1≤b≤|y″|−1.1w. We distinguish two cases:
1) b+1.1w>|y′|:
Recalling that v=w/d, we have i−v≤|y′|−w/d≤|y′|−1.1w<min(y′|+1, b), and so Property 39 holds for y″ [i−v−w, i−v). Therefore, y″ [i−v−w, i−v) cannot be a subsequence of y″ [b, b+1.1w) for any b such that b+1.1w>|y′|+1. Consequently, we only need to consider values of b such that b+1.1w≤|y′|;
2) b+1.1w≤|y′|:
Since y′ is w-subsequence-unique, we must have b≤i−v−w and b+1.1w≥i−v. This implies the desired result as in the proof of Lemma 36;
The remainder of the proof follows along the lines of the proof of Lemma 36.
Lemmas 41 and 42 imply that we can recovery″
i with probability 1−1/poly(n) via the same reasoning
of Section 4.1.1 with the small differences described above. The number of traces required to recover y″i is polynomial in the length of ∥c∥c, which equals
+|z′|+|y′|=O(√{square root over ( )}m+log m+m)=O(m).
Since m=log2 n, it follows that we can recover y′i with probability 1−1/poly(n) from poly(log n) traces. In particular, the success probability can be assumed to be at least 1−1/p(n) for a fixed polynomial of our choice since we can repeat the process O(log n) times and take the majority vote while still requiring poly(log n) traces. Since Lemma 40 asserts that O(log n) traces suffice to recover z with high probability, and we need to recover m=log2 n bits of y″, we overall require poly(log n) traces to recover ∥c∥ with probability 1−1/poly(n). This concludes the proof of Theorem 6.
In some embodiments, the operation of encoding each block could include encoding the blocks according to an inner code. The inner code could include, for example, an alphabet consisting of {adenine (A), cytosine (C), guanine (G), and thymine (T)}.
In various embodiments, each unique marker could be of the form M=(AC)l∥(TG)l, where l=25 log n.
In some embodiments, the encoded blocks could include approximately 50% guanine and cytosine content.
In some examples, the operations could additionally include further partitioning each block into a plurality of subblocks and inserting a second level of markers between each subblock. In such scenarios, the second level of markers could be different than the unique markers.
The memory devices described herein may include a non-transitory computer-readable medium, such as, but not limited to, read-only memory (ROM), programmable read-only memory (PROM), erasable programmable read-only memory (EPROM), electrically erasable programmable read-only memory (EEPROM), non-volatile random-access memory (e.g., flash memory), a solid state drive (SSD), a hard disk drive (HDD), a Compact Disc (CD), a Digital Video Disk (DVD), a digital tape, read/write (R/W) CDs, R/W DVDs, etc.
The operations include reading the nucleotide sequence 140 based on an alphabet consisting of {adenine (A), cytosine (C), guanine (G), and thymine (T)} and determining positions of unique markers between a plurality of encoded blocks in the nucleotide sequence 140.
The operations additionally include decoding each encoded block of the plurality of encoded blocks according to an inner code, so as to form a plurality of decoded blocks.
The operations include appending the decoded blocks to one another to provide a decoded message 230 with message length n bits.
In various embodiments, each unique marker could be of the form M=(AC)l∥(TG)l, where l=25 log n.
In some embodiments, the encoded blocks could include of approximately 50% guanine and cytosine content.
In example embodiments, the operation of encoding each block could include encoding each block according to a Hamming encoding with a relative Hamming distance.
Block 302 includes receiving a message (e.g., message 130) having a message length n bits;
Block 304 includes partitioning the message into a plurality of blocks with a maximum block length of O(log2 n).
Block 306 includes encoding each block to provide a plurality of encoded blocks.
Block 308 includes inserting unique markers between the encoded blocks so as to form an encoded message. The markers each have a minimum marker length O(log n).
Block 310 includes causing a DNA sequencer (e.g., DNA sequencer 110) to synthesize a nucleotide sequence (e.g., nucleotide sequence 140) based on the encoded message.
In some embodiments, encoding each block could include encoding according to an inner code, wherein the inner code comprises an alphabet consisting of {adenine (A), cytosine (C), guanine (G), and thymine (T)}.
In various embodiments, each unique marker could be of the form M=(AC)l∥H(TG)l, where l=25 log n.
In example embodiments, the encoded blocks could include approximately 50% guanine and cytosine content.
In some embodiments, encoding each block could include encoding each block according to a Hamming encoding with a relative Hamming distance.
In some embodiments, the method 300 could additionally include partitioning each block into a plurality of subblocks and inserting a second level of markers between each subblock. In such scenarios, the second level of markers may be different than the unique markers.
Block 402 includes receiving, at a DNA readout system, a nucleotide sequence (e.g., nucleotide sequence 240).
Block 404 includes reading the nucleotide sequence based on an alphabet consisting of {adenine (A), cytosine (C), guanine (G), and thymine (T)}.
Block 406 includes determining positions of unique markers between a plurality of encoded blocks in the nucleotide sequence.
Block 408 includes decoding each encoded block of the plurality of encoded blocks according to an inner code, forming a plurality of decoded blocks.
Block 410 includes appending the decoded blocks to one another to provide a decoded message (e.g., decoded message 230) with message length n bits.
In some embodiments, each unique marker could be of the form M=(AC)l∥(TG)l, where l=25 log n.
In various embodiments, the encoded blocks consist of approximately 50% guanine and cytosine content.
In example embodiments, encoding each block could include encoding each block according to a Hamming encoding with a relative Hamming distance.
The particular arrangements shown in the Figures should not be viewed as limiting. It should be understood that other embodiments may include more or less of each element shown in a given Figure. Further, some of the illustrated elements may be combined or omitted. Yet further, an illustrative embodiment may include elements that are not illustrated in the Figures.
A step or block that represents a processing of information can correspond to circuitry that can be configured to perform the specific logical functions of a herein-described method or technique. Alternatively or additionally, a step or block that represents a processing of information can correspond to a module, a segment, a physical computer (e.g., a field programmable gate array (FPGA) or application-specific integrated circuit (ASIC)), or a portion of program code (including related data). The program code can include one or more instructions executable by a processor for implementing specific logical functions or actions in the method or technique. The program code and/or related data can be stored on any type of computer readable medium such as a storage device including a disk, hard drive, or other storage medium.
The computer readable medium can also include non-transitory computer readable media such as computer-readable media that store data for short periods of time like register memory, processor cache, and random access memory (RAM). The computer readable media can also include non-transitory computer readable media that store program code and/or data for longer periods of time. Thus, the computer readable media may include secondary or persistent long term storage, like read only memory (ROM), optical or magnetic disks, compact-disc read only memory (CD-ROM), for example. The computer readable media can also be any other volatile or non volatile storage systems. A computer readable medium can be considered a computer readable storage medium, for example, or a tangible storage device.
While various examples and embodiments have been disclosed, other examples and embodiments will be apparent to those skilled in the art. The various disclosed examples and embodiments are for purposes of illustration and are not intended to be limiting, with the true scope being indicated by the following claims.
The present application claims the benefit of U.S. Patent Application No. 62/925,332, filed Oct. 24, 2019, the content of which is herewith incorporated by reference.
This invention was made with Government support under Grant No. CCF 16-18366 (National Science Foundation) and W911NF-18-2-0032 OM (DARPA Molecular Informatics). The Government has certain rights in the invention.
Number | Date | Country | |
---|---|---|---|
62925332 | Oct 2019 | US |