mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 10:00:23 -04:00 
			
		
		
		
	Edits to ftrsd paper.
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@6404 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
		
							parent
							
								
									50daadf7f9
								
							
						
					
					
						commit
						e8a7b4aa0c
					
				| @ -138,7 +138,7 @@ key "kv2001" | |||||||
|  Since 2001 the KV decoder has been considered the best available soft-decision |  Since 2001 the KV decoder has been considered the best available soft-decision | ||||||
|  decoder for Reed Solomon codes. |  decoder for Reed Solomon codes. | ||||||
|  We describe here a new open-source alternative called the Franke-Taylor |  We describe here a new open-source alternative called the Franke-Taylor | ||||||
|  (FT, or K9AN-K1JT) algorithm. |  (FT, or K9AN-K1JT) soft-decision decoding algorithm. | ||||||
|  It is conceptually simple, built around the well-known Berlekamp-Massey |  It is conceptually simple, built around the well-known Berlekamp-Massey | ||||||
|  errors-and-erasures algorithm, and in this application it performs even |  errors-and-erasures algorithm, and in this application it performs even | ||||||
|  better than the KV decoder. |  better than the KV decoder. | ||||||
| @ -298,7 +298,15 @@ d=n-k+1.\label{eq:minimum_distance} | |||||||
| 
 | 
 | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
| The minimum Hamming distance of the JT65 code is  | With  | ||||||
|  | \begin_inset Formula $n=63$ | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  |  and  | ||||||
|  | \begin_inset Formula $k=12$ | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  |  the minimum Hamming distance of the JT65 code is  | ||||||
| \begin_inset Formula $d=52$ | \begin_inset Formula $d=52$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
| @ -361,8 +369,11 @@ erasures. | |||||||
| \begin_inset Quotes erd | \begin_inset Quotes erd | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  With perfect erasure information up to 51 incorrect symbols can be corrected |  With perfect erasure information up to  | ||||||
|  for the JT65 code. | \begin_inset Formula $n-k=51$ | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  |  incorrect symbols can be corrected for the JT65 code. | ||||||
|  Imperfect erasure information means that some erased symbols may be correct, |  Imperfect erasure information means that some erased symbols may be correct, | ||||||
|  and some other symbols in error. |  and some other symbols in error. | ||||||
|  If  |  If  | ||||||
| @ -701,8 +712,31 @@ How might we best choose the number of symbols to erase, in order to maximize | |||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  symbols. |  symbols. | ||||||
|  Decoding will then be assured if the set of erased symbols contains at |  According to equation  | ||||||
|  least 37 errors. | \begin_inset CommandInset ref | ||||||
|  | LatexCommand ref | ||||||
|  | reference "eq:erasures_and_errors" | ||||||
|  | 
 | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  | , with  | ||||||
|  | \begin_inset Formula $s=45$ | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  |  and  | ||||||
|  | \begin_inset Formula $d=52$ | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  |  then  | ||||||
|  | \begin_inset Formula $e\le3$ | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  | , so decoding will be assured if the set of erased symbols contains at least | ||||||
|  |   | ||||||
|  | \begin_inset Formula $40-3=37$ | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  |  errors. | ||||||
|  With  |  With  | ||||||
| \begin_inset Formula $N=63$ | \begin_inset Formula $N=63$ | ||||||
| \end_inset | \end_inset | ||||||
| @ -826,19 +860,32 @@ The Franke-Taylor Decoding Algorithm | |||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| Example 3 shows how statistical information about symbol quality should | Example 3 shows how statistical information about symbol quality should | ||||||
|  make it possible to decode received frames having a large number of errors. |  make it possible to decode received frames having a large number of errors. | ||||||
|  In practice the number of errors in the received word is unknown, so we |  In practice the number of errors in the received word is unknown, so our | ||||||
|  use a stochastic algorithm to assign high erasure probability to low-quality |  algorithm simply assigns a high erasure probability to low-quality symbols | ||||||
|  symbols and relatively low probability to high-quality symbols. |  and relatively low probability to high-quality symbols. | ||||||
|  As illustrated by Example 3, a good choice of erasure probabilities can |  As illustrated by Example 3, a good choice of erasure probabilities can | ||||||
|  increase by many orders of magnitude the chance of producing a codeword. |  increase by many orders of magnitude the chance of producing a codeword. | ||||||
|  Note that at this stage we must treat any codeword obtained by errors-and-erasu |  Once erasure probabilities have been assigned to each of the 63 received | ||||||
| res decoding as no more than a  |  symbols, the FT algorithm uses a random number generator to decide whether | ||||||
|  |  or not to erase each symbol according to its assigned erasure probability. | ||||||
|  |  The list of erased symbols is then submitted to the BM decoder which either | ||||||
|  |  produces a codeword or fails to decode. | ||||||
|  |   | ||||||
|  | \end_layout | ||||||
|  | 
 | ||||||
|  | \begin_layout Standard | ||||||
|  | The process of selecting the list of symbols to erase and calling the BM | ||||||
|  |  decoder comprises one cycle of the FT algorithm. | ||||||
|  |  The next cycle proceeds with a new selection of erased symbols. | ||||||
|  |  At this stage we must treat any codeword obtained by errors-and-erasures | ||||||
|  |  decoding as no more than a  | ||||||
| \emph on | \emph on | ||||||
| candidate | candidate | ||||||
| \emph default | \emph default | ||||||
| . | . | ||||||
|  Our next task is to find a metric that can reliably select one of many |  Our next task is to find a metric that can reliably select one of many | ||||||
|  proffered candidates as the codeword actually transmitted. |  proffered candidates as the codeword actually transmitted. | ||||||
|  |   | ||||||
| \end_layout | \end_layout | ||||||
| 
 | 
 | ||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| @ -898,7 +945,7 @@ The FT algorithm uses quality indices made available by a noncoherent 64-FSK | |||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  of the symbol's fractional power  |  of the symbol's fractional power  | ||||||
| \begin_inset Formula $p_{1,\,j}$ | \begin_inset Formula $p_{1,\, j}$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  in a sorted list of  |  in a sorted list of  | ||||||
| @ -923,7 +970,8 @@ The FT algorithm uses quality indices made available by a noncoherent 64-FSK | |||||||
| \end_layout | \end_layout | ||||||
| 
 | 
 | ||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| We use an empirical table of symbol error probabilities derived from a large | We use a 3-bit quantization of these two metrics to index the entries in | ||||||
|  |  an 8x8 table of symbol error probabilities derived empirically from a large | ||||||
|  dataset of received words that were successfully decoded. |  dataset of received words that were successfully decoded. | ||||||
|  The table provides an estimate of the  |  The table provides an estimate of the  | ||||||
| \emph on | \emph on | ||||||
| @ -938,10 +986,22 @@ a priori | |||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  metrics. |  metrics. | ||||||
|  These probabilities are close to 1 for low-quality symbols and close to |  This table is a key element of the algorithm, as it will define which symbols | ||||||
|  0 for high-quality symbols. |  are effectively  | ||||||
|  | \begin_inset Quotes eld | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  | protected | ||||||
|  | \begin_inset Quotes erd | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  |  from erasure. | ||||||
|  |  The a priori symbol error probabilities are close to 1 for low-quality | ||||||
|  |  symbols and close to 0 for high-quality symbols. | ||||||
|  Recall from Examples 2 and 3 that candidate codewords are produced with |  Recall from Examples 2 and 3 that candidate codewords are produced with | ||||||
|  higher probability when  |  higher probability when the number of erased symbols is larger than the | ||||||
|  |  number of symbols that are in error, i.e. | ||||||
|  |  when  | ||||||
| \begin_inset Formula $s>X$ | \begin_inset Formula $s>X$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
| @ -968,7 +1028,7 @@ t educated guesses to select symbols for erasure. | |||||||
| , the soft distance between the received word and the codeword:  | , the soft distance between the received word and the codeword:  | ||||||
| \begin_inset Formula  | \begin_inset Formula  | ||||||
| \begin{equation} | \begin{equation} | ||||||
| d_{s}=\sum_{j=1}^{n}\alpha_{j}\,(1+p_{1,\,j}).\label{eq:soft_distance} | d_{s}=\sum_{j=1}^{n}\alpha_{j}\,(1+p_{1,\, j}).\label{eq:soft_distance} | ||||||
| \end{equation} | \end{equation} | ||||||
| 
 | 
 | ||||||
| \end_inset | \end_inset | ||||||
| @ -986,7 +1046,7 @@ Here | |||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  if the received symbol and codeword symbol are different, and  |  if the received symbol and codeword symbol are different, and  | ||||||
| \begin_inset Formula $p_{1,\,j}$ | \begin_inset Formula $p_{1,\, j}$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  is the fractional power associated with received symbol  |  is the fractional power associated with received symbol  | ||||||
| @ -1030,7 +1090,7 @@ In practice we find that | |||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| \begin_inset Formula  | \begin_inset Formula  | ||||||
| \begin{equation} | \begin{equation} | ||||||
| u=\frac{1}{n}\sum_{j=1}^{n}S(c_{j},\,j).\label{eq:u-metric} | u=\frac{1}{n}\sum_{j=1}^{n}S(c_{j},\, j).\label{eq:u-metric} | ||||||
| \end{equation} | \end{equation} | ||||||
| 
 | 
 | ||||||
| \end_inset | \end_inset | ||||||
| @ -1063,7 +1123,7 @@ The correct JT65 codeword produces a value for | |||||||
| 
 | 
 | ||||||
|  bins containing noise only. |  bins containing noise only. | ||||||
|  Thus, if the spectral array  |  Thus, if the spectral array  | ||||||
| \begin_inset Formula $S(i,\,j)$ | \begin_inset Formula $S(i,\, j)$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  has been normalized so that the average value of the noise-only bins is |  has been normalized so that the average value of the noise-only bins is | ||||||
| @ -1078,7 +1138,7 @@ The correct JT65 codeword produces a value for | |||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| \begin_inset Formula  | \begin_inset Formula  | ||||||
| \begin{equation} | \begin{equation} | ||||||
| \bar{u}_{1}=1+y,\label{eq:u1-exp} | \bar{u}_{c}=1+y,\label{eq:u1-exp} | ||||||
| \end{equation} | \end{equation} | ||||||
| 
 | 
 | ||||||
| \end_inset | \end_inset | ||||||
| @ -1090,7 +1150,7 @@ where | |||||||
|  is the signal-to-noise ratio in linear power units. |  is the signal-to-noise ratio in linear power units. | ||||||
|  If we assume Gaussian statistics and a large number of trials, the standard |  If we assume Gaussian statistics and a large number of trials, the standard | ||||||
|  deviation of measured values of  |  deviation of measured values of  | ||||||
| \begin_inset Formula $u_{1}$ | \begin_inset Formula $u$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  is |  is | ||||||
| @ -1099,7 +1159,7 @@ where | |||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| \begin_inset Formula  | \begin_inset Formula  | ||||||
| \begin{equation} | \begin{equation} | ||||||
| \sigma_{1}=\left(\frac{1+2y}{n}\right)^{1/2}.\label{eq:sigma1} | \sigma_{c}=\left(\frac{1+2y}{n}\right)^{1/2}.\label{eq:sigma1} | ||||||
| \end{equation} | \end{equation} | ||||||
| 
 | 
 | ||||||
| \end_inset | \end_inset | ||||||
| @ -1143,12 +1203,28 @@ i.e. | |||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| \begin_inset Formula  | \begin_inset Formula  | ||||||
| \begin{equation} | \begin{equation} | ||||||
| \sigma_{i}=\frac{1}{n}\left[n+2y(k-1)\right]^{1/2}.\label{eq:sigma2} | \sigma_{i}=\frac{1}{n}\left[n+2y(k-1)\right]^{1/2},\label{eq:sigma2} | ||||||
| \end{equation} | \end{equation} | ||||||
| 
 | 
 | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  | where the subscript  | ||||||
|  | \begin_inset Quotes eld | ||||||
|  | \end_inset | ||||||
| 
 | 
 | ||||||
|  | i | ||||||
|  | \begin_inset Quotes erd | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  |  is an abbreviation for  | ||||||
|  | \begin_inset Quotes eld | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  | incorrect | ||||||
|  | \begin_inset Quotes erd | ||||||
|  | \end_inset | ||||||
|  | 
 | ||||||
|  | . | ||||||
| \end_layout | \end_layout | ||||||
| 
 | 
 | ||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| @ -1162,11 +1238,11 @@ If | |||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  to be drawn from a population with statistics described by  |  to be drawn from a population with statistics described by  | ||||||
| \begin_inset Formula $\bar{u}_{1}$ | \begin_inset Formula $\bar{u}_{c}$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  and  |  and  | ||||||
| \begin_inset Formula $\sigma_{1}.$ | \begin_inset Formula $\sigma_{c}.$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
|  If no tested codeword is correct,  |  If no tested codeword is correct,  | ||||||
| @ -1235,14 +1311,8 @@ reference "sec:Theory,-Simulation,-and" | |||||||
| \end_layout | \end_layout | ||||||
| 
 | 
 | ||||||
| \begin_layout Standard | \begin_layout Standard | ||||||
| Technically the FT algorithm is a list decoder. | As with all decoding algorithms that generate a list of possible codewords, | ||||||
|  Among the list of candidate codewords found by the stochastic search algorithm, |  a stopping criterion is necessary. | ||||||
|  only the one with the largest  |  | ||||||
| \begin_inset Formula $u$ |  | ||||||
| \end_inset |  | ||||||
| 
 |  | ||||||
|  is retained. |  | ||||||
|  As with all such algorithms, a stopping criterion is necessary. |  | ||||||
|  FT accepts a codeword unconditionally if the Hamming distance  |  FT accepts a codeword unconditionally if the Hamming distance  | ||||||
| \begin_inset Formula $X$ | \begin_inset Formula $X$ | ||||||
| \end_inset | \end_inset | ||||||
| @ -1312,7 +1382,7 @@ For each received symbol, define the erasure probability as 1.3 times the | |||||||
| a priori | a priori | ||||||
| \emph default | \emph default | ||||||
|  symbol-error probability determined from soft-symbol information  |  symbol-error probability determined from soft-symbol information  | ||||||
| \begin_inset Formula $\{p_{1}\textrm{-rank},\,p_{2}/p_{1}\}$ | \begin_inset Formula $\{p_{1}\textrm{-rank},\, p_{2}/p_{1}\}$ | ||||||
| \end_inset | \end_inset | ||||||
| 
 | 
 | ||||||
| . | . | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user