Abstract

Baseband functions like channel estimation and symbol detection of sophisticated telecommunications systems require matrix operations, which apply highly nonlinear operations like division or square root. In this paper, a scalable low-complexity approximation method of the inverse square root is developed and applied in Cholesky and QR decompositions. Computation is derived by exploiting the binary representation of the fixedpoint numbers and by substituting the highly nonlinear inverse square root operation with a more implementation appropriate function. Low complexity is obtained since the proposed method does not use large multipliers or look-up tables (LUT). Due to the scalability, the approximation accuracy can be adjusted according to the targeted application. The method is applied also as an accelerating unit of an application-specific instruction-set processor (ASIP) and as a software routine of a conventional DSP. As a result, the method can accelerate any fixed-point system where cost-efficiency and low power consumption are of high importance, and coarse approximation of inverse square root operation is required.

1. Introduction

Ever higher data rates require sophisticated transmission techniques but, on the other hand, the latest technologies allow use of advanced and more complex receiver algorithms. Such algorithms apply matrix operations which require highly nonlinear division by square root operation. For example, linear minimum mean square error (LMMSE) estimation has been proposed for the receivers of the current 3G, Universal Mobile Telecommunications System [1], and Cholesky decomposition can be used for the inevitable matrix inversion or for solving linear systems. In the upcoming 3G Long-Term Evolution (LTE) systems, multiple-input multiple-output (MIMO) receivers require demanding symbol detection methods like list sphere detector (LSD), which applies QR decomposition of a complex-valued channel matrix. When compared to matrix computation studies targeted for processing large matrices with highly parallel resources [2, 3], there are four notable differences in the baseband processing in the telecommunications field: (i)the matrices are relatively small, (ii)fixed-point number system is preferred, (iii)there are real-time limits, (iv)low complexity and low power consumption are of high importance.

In this paper, a low-complexity inverse square root approximation method is proposed for baseband matrix operations. The method relies on binary presentation of the fixed-point number system and it avoids large LUTs, large multipliers, and floating-point arithmetic units. The principal idea of the method is to substitute the highly nonlinear inverse square root function with a less nonlinear function with appropriate pre- and postprocessing. The accuracy and complexity of the method can be adjusted with one design parameter. Thus, the method lends itself to lower-complexity applications where coarse approximations and fixed-point computations are preferred. In addition to comparison of hardware implementations of inverse square root methods, we show how the proposed method can be applied as a software routine or as an accelerating unit of an ASIP. The implementations are applied for Cholesky and QR decompositions required by 3G and 3G LTE receivers.

2. Previous Work

There are several methods to compute the inverse square root function. One of the basic approaches is to use lookup tables (LUT) for obtaining an initial value for iterations, which refine the value to higher accuracy [4, 5]. The main differences among these kinds of methods are in the size and content of LUT and the used iteration algorithm. In [5], a large multiplier was used since it was available in the targeted general purpose processor. In [6], savings were obtained by using a π‘šΓ—π‘› multiplier, π‘šβ‰€π‘›, and utilizing the fact that less significant bits of intermediate result do not contribute to the accuracy of the final result. A software implementation using LUT initialization followed by iterations was presented in [7]. Another software approximation in [8] relied heavily on the binary representation of floating-point numbers.

LUTs using low-order polynomial approximation were applied in [9]. Polynomial approximation was also used in [10] where a second-degree minimax polynomial approximation was followed by modified Goldschmidt iteration. A comparison considering area costs was also given. Digit recurrence methods were proposed in [11, 12]. The main disadvantage of using digit recurrence when compared to iterative algorithms is their linear convergence. Approximation based on LUT followed by multiplication with operand modification was proposed in [13, 14] and used also in [15]. Argument reduction followed by series expansion was applied in [16]. Another approach is to work in logarithmic domain [17, 18] where the computation of the inverse square root is straightforward [19, 20].

For shorter word lengths (WLs) and for using fixed-point numbers, table addition methods have been proposed. These methods consist of parallel LUTs and multioperand additions. As a benefit, no multipliers are required. In [21], a symmetric table addition method (STAM) was developed as an extension to a simpler bipartite method. Selecting appropriate multipartite method, that is, design space exploration, was considered in [22]. The STAM enhanced with an error correction term and internal presentation in exponent and mantissa form was used in [23].

When compared to the previously mentioned methods, the proposed method in this paper is novel, that is, it is not a derivative of any of the existing methods. The area costs are kept at low as large LUTs and large multipliers are avoided. The proposed method lends itself also to software implementation. Furthermore, the proposed method can be adjusted to work only in subunitary range, which is sufficient for, for example, Cholesky decomposition, and the accuracy of the method can be adjusted along with the complexity up to a certain level while maintaining high area efficiency.

3. Targeted Matrix Decompositions in Baseband Processing

In this section, we describe where the targeted low-complexity inverse square root operations have been applied.

3.1. Baseband Processing with Fixed-Point Number System

As the baseband functions are applied in receivers of, for example, handheld telecommunications devices, low complexity is important for decreasing the area costs and power consumption. Therefore, fixed-point number system is preferred, that is, limited accuracy is applied. In this study, the targeted fractional word length (FWL) is 11 bits and integer word length (IWL) is 5 bits, that is, 16-bit words are assumed.

Targeted matrix operations are illustrative examples of baseband functions for two reasons. Firstly, the computations consist mainly of massive repetitions of a single operation, which is multiply and accumulate in this case. Secondly, an efficient mapping of computations to custom hardware or DSP is prevented by one less frequently used, but demanding, operation, which is inverse square root, 1/√π‘₯, in this case. Thus, there is a realistic need for low-complexity, limited accuracy implementations of 1/√π‘₯ function.

3.2. Cholesky Decomposition for LMMSE

The LMMSE estimation of transmitted data vector applies typically the Cholesky decomposition. Basically, the LMMSE estimate, Μ‚β€Œπ, can be expressed as a function of received data, 𝐲, channel matrix, 𝐌, and power of noise, 𝜎2:Μ‚β€Œπ=ξ€·πŒπ»πŒ+𝜎2πˆξ€Έβˆ’1𝐌𝐻𝐲,(1) where it is assumed that autocorrelation 𝐸(𝐝𝐝𝐻)=𝐈. The estimation in (1) can be derived into a form, which can be presented as a linear system with positive definite real-valued matrix. With Cholesky decomposition 𝐀=𝐋𝑇𝐋, such a linear system, 𝐀𝐱=𝐛, can be solved with the aid of two triangular systems, that is, 𝐋𝑇𝐳=𝐛 and 𝐋𝐱=𝐳.

Diagonal elements, 𝑙𝑖𝑖, of Cholesky factor 𝐋 are defined as𝑙𝑖𝑗=ξ„Άξ„΅ξ„΅βŽ·π‘Žπ‘–π‘–βˆ’π‘–βˆ’1ξ“π‘˜=1𝑙2π‘–π‘˜(2) and nondiagonal elements, 𝑙𝑖𝑗, as𝑙𝑖𝑗=1π‘™π‘–π‘—βŽ›βŽœβŽπ‘Žπ‘–π‘—βˆ’π‘—βˆ’1ξ“π‘˜=1π‘™π‘–π‘˜π‘™π‘—π‘˜βŽžβŽŸβŽ ,(3) where π‘Žπ‘–π‘— denotes the elements of 𝐀. Equations (2) and (3) show that nondiagonal elements require division by square root and diagonals square root operations. Thus, the division by square root can be replaced with multiplication with the inverse square root, that is, two demanding operations are substituted with one demanding and one less demanding operation. The square root operation of (2) can also be computed with an additional multiplication, as √π‘₯=π‘₯/√π‘₯. An important property of Cholesky decomposition is the preservation of the subunitary of matrix elements, which limits the arguments of 1/√π‘₯ operations efficiently.

3.3. QR Decomposition for LSD

The LSD is used in MIMO receivers to estimate the transmitted symbol, 𝐬, by approximating maximum likelihood detection: π¬ξ…ž=argminπ¬β€–π²βˆ’π‡π¬β€–2,(4) where 𝐲 is the received symbol vector and 𝐇 is complex-valued channel matrix whose dimensions are equal to the number of transmit and receive antennas of MIMO system. The approximation is based on substitution with QR decomposition 𝐐𝐑=𝐇, that is,π¬ξ…ž=argminπ¬β€–β€–π²ξ…žβˆ’π‘π¬β€–β€–2,where𝐲′=𝐐𝐻𝐲.(5) The LSD approximates (5) by gradually increasing the dimensions of symbol vector and computing partial Euclidean distances. With this practice, the search space can be limited efficiently.

QR factorization with modified Gram-Schmidt algorithm [24] is presented in Algorithm 1.

(1) for   π‘˜ = 1 ∢ 𝑛
(2)   𝐑 π‘˜ , π‘˜ = β€– 𝐇 1 ∢ 𝑛 , π‘˜ β€–
(3)   𝐐 1 ∢ 𝑛 , π‘˜ = 𝐇 1 ∢ 𝑛 , π‘˜ / 𝐑 π‘˜ , π‘˜
(4)  for   𝑗 = π‘˜ + 1 ∢ 𝑛
(5)    𝐑 π‘˜ , 𝑗 = 𝐐 𝐻 1 ∢ 𝑛 , π‘˜ 𝐇 1 ∢ 𝑛 , 𝑗
(6)    𝐇 1 ∢ 𝑛 , 𝑗 = 𝐇 1 ∢ 𝑛 , 𝑗 βˆ’ 𝐐 1 ∢ 𝑛 , π‘˜ 𝐑 π‘˜ , 𝑗
(7)  end
(8) end

It decomposes 𝐇𝑛×𝑛 to the orthogonal 𝐐𝑛×𝑛 and upper triangular 𝐑𝑛×𝑛. Conjugated transpose is denoted with (β‹…)𝐻. The lines 2 and 3 show that division by square root is required as the elements are divided by diagonals which are norms, β€–β‹…β€–. In a similar way as with Cholesky decomposition, the division can be substituted with multiplication by inverse square root.

4. Low-Complexity Approximation Method

The main principle of the proposed method is to avoid straightforward approximation of 1/√π‘₯ function which is highly nonlinear in subunitary range 0<π‘₯≀1. Instead, the more softly nonlinear function 1/βˆšπ‘+𝑒 with 𝑐β‰₯1 and 0<𝑒≀1 is approximated. The usage of 1/βˆšπ‘+𝑒 is justified by the following fixed-point representations in two complement formats of π‘₯, 𝑐, and 𝑒. If the positive subunitary π‘₯ has 𝛼 leading zeros, 𝑐 and 𝑒 can be defined so thatπ‘₯=0.00β‹―0ξ„Ώξ…€ξ…€ξ…€ξ…ƒξ…€ξ…€ξ…€ξ…Œπ›Όπ‘π‘βˆ’1π‘π‘βˆ’2⋯𝑐0π‘’π‘€βˆ’1π‘’π‘€βˆ’2⋯𝑒0.(6) In other words, the bits of 𝑐 and 𝑒 do not overlap and the word lengths of 𝑐 and 𝑒 are denoted with 𝑁 and 𝑀, respectively. Positive nonsubunitary range, π‘₯>1, is presented similarly, except that the number of leading zeros, 𝛼, can have negative values. Since π‘π‘βˆ’1=1 for all valid values of π‘₯, the π‘₯ can be presented with the aid of shifting by 𝛼, that is,π‘₯Γ—2𝛼=1β‹…π‘π‘βˆ’2⋯𝑐0π‘’π‘€βˆ’1π‘’π‘€βˆ’2⋯𝑒0,π‘₯=2βˆ’π›ΌΓ—1β‹…π‘π‘βˆ’2⋯𝑐0π‘’π‘€βˆ’1π‘’π‘€βˆ’2⋯𝑒0.(7) Thus, the desired form, 𝑐+𝑒, can be obtained, and we note that 𝑒 is a positive subunitary number. The targeted function can be written as1√π‘₯=1√2βˆ’π›Ό(𝑐+𝑒)=2𝛼/21βˆšπ‘+𝑒.(8)

We can distinguish two cases depending on the value of 𝛼, which represents the number of leading zeros of fixed-point binary representation of π‘₯ (6). This distinct behavior is obtained because the remainder of 𝛼/2 in (8) can be either zero or one. For even values 𝛼=2π‘˜,1√π‘₯=2π‘˜1βˆšπ‘+𝑒(9) and, for odd values 𝛼=2π‘˜+1,1√π‘₯=2π‘˜βˆš21βˆšπ‘+𝑒.(10)

In order to approximate (9) or (10), the expression 1/βˆšπ‘+𝑒 must be considered. A tempting solution is to approximate 1/βˆšπ‘+𝑒 with binomial series. In principle, the 1/βˆšπ‘+𝑒 could be approached with arbitrarily high precision, as the binomial series converges. Multipliers are required if polynomial approximation [9, 10] or series expansion [16] is applied. Although the approximation with binomial series has a solid basis, it does not lend itself to low-complexity implementations due to the high-order terms.

4.1. Linear Approximation

We attempt to identify the characteristic of 1/βˆšπ‘+𝑒 and to determine a first-degree polynomial that will give the smallest approximation error for a low-complexity hardware implementation. So, we will approximate the expression 1/βˆšπ‘+𝑒 with straight lines, that is,1βˆšπ‘+π‘’β‰ƒπ‘Žπ‘‘βˆ’π‘π‘‘(𝑐+𝑒),(11) where π‘Žπ‘‘,𝑏𝑑>0 and subscript 𝑑 is the integer interpretation of the concatenation π‘π‘βˆ’2⋯𝑐0𝛼0. The number of approximating lines, that is, the accuracy of the approximation, depends on the WL of 𝑐. Since the MSB of 𝑐 has always constant value, π‘π‘βˆ’1=1, the number of approximating lines is 2𝑁.

The range of the targeted expression is 1≀1/βˆšπ‘+𝑒≀1/√2, since 1≀𝑐+𝑒<2. The domain of 𝑐 is defined by the WL, 𝑁, that is, 1≀𝑐≀2(1βˆ’2βˆ’π‘). Naturally, the domain of 𝑒 depends on 𝑁 and 𝑀, that is, 0≀𝑒≀2βˆ’(π‘βˆ’1)βˆ’2βˆ’(𝑀+π‘βˆ’1). In practice, the approximating lines are formed by dividing the domain of 𝑐+𝑒 into evenly spaced regions, which are determined by the 𝑁 highest bits of 𝑐. The values in the start and end points are given by 1/βˆšπ‘ and the value of the last end point is 1/√2. The linear approximation is illustrated in Figure 1(a) where 1/βˆšπ‘+𝑒, with even 𝛼 approximated with 𝑁=1,2,3. The error of approximation is shown in Figure 1(b). The figures indicate that by increasing the word length 𝑁, the accuracy of the approximation can be adjusted conveniently.

For odd values 𝛼=2π‘˜+1, the √2/βˆšπ‘+𝑒 is approximated in a similar way. The lines used for even values, 𝛼=2π‘˜, cannot be used without multiplication with √2, and, therefore, different approximating lines are preferred. To obtain the final result, that is, the approximation of 1/√π‘₯, the approximating straight lines in must be scaled with 2π‘˜ as shown in (9) and (10). The scaling can be carried out easily with shift operation, whose direction depends on the sign of 𝛼.

4.2. Coefficients for Hardware Implementation

The linear approximation has the form π‘Žπ‘‘βˆ’π‘π‘‘(𝑐+𝑒), which includes multiplication. However, for obtaining low complexity, the multiplications should be avoided. Braun multiplier adds shifted values of the multiplicand multiplied with one bit of the multiplier. The principle of adding shifted values can be used to approximate the product 𝑏𝑑(𝑐+𝑒). Since 𝑏𝑑≀1/2, the product can be presented as𝑏𝑑(𝑐+𝑒)=𝑑1,𝑑𝑐+𝑒21+𝑑2,𝑑𝑐+𝑒22+β‹―+𝑑𝑀+π‘βˆ’1,𝑑𝑐+𝑒2𝑀+π‘βˆ’1,(12) where 𝑑𝑖,π‘‘βˆˆ{βˆ’1,0,1}. As division with powers of two can be implemented with hardwired shifting in hardware, an approximation of the previous form is suitable for low-complexity implementation. Naturally, the accuracy depends on the number of terms included in the sum. In the proposed method, at maximum three terms are included, that is, an approximation,𝑏𝑑(𝑐+𝑒)≃𝑑1,𝑑𝑐+𝑒2𝑒1,𝑑+𝑑2,𝑑𝑐+𝑒2𝑒2,𝑑+𝑑3,𝑑𝑐+𝑒2𝑒3,𝑑,(13) in which 𝑑𝑖,π‘‘βˆˆ{βˆ’1,0,1} and 𝑒𝑖,π‘‘βˆˆ{1,…,8}, is used. The coefficients 𝑑𝑖,𝑑 and 𝑒𝑖,𝑑 are searched for each approximating line, that is, for each 𝑐 and 𝛼0, separately. Instead of three shifters with freely variable shift count, three multiplexers can be used to select appropriate terms.

5. Inverse Square Root Unit Implementations

The block diagrams of the hardware implementations of the inverse square root units are shown in Figure 2. Figure 2(a) shows only the linear approximation π‘Žπ‘‘βˆ’π‘π‘‘(𝑐+𝑒). The top three multiplexers correspond with term 𝑏𝑑(𝑐+𝑒), and the fourth multiplexer outputs π‘Žπ‘‘. The selections of multiplexer are controlled by parity of 𝛼 and bits of 𝑐 excluding the π‘π‘βˆ’1 which has constant value.

In the next block diagram in Figure 2(b) the previous unit is instantiated in the inverse square root unit. The range of the unit in Figure 2(b) is positive subunitary, that is, 0<π‘₯≀1, which is sufficient for the Cholesky decomposition. The structure is further extended in Figure 2(c) to allow free range, that is, π‘₯>0. Basically, nonsubunitary range of π‘₯ results also in negative values of 𝛼, and, therefore, both left shifting and right shifting are required as indicated in Figure 2(c). In practice, shifters consists of hardwired shift operations from which one is selected with multiplexer. Therefore, a combination of left and right shifters can be assumed to have the same complexity of unidirectional shifter with respectively wider range of shifted bits. As the input signal π‘₯ has wider WL in Figure 2(c), the negative 𝛼 is detected by comparing the number of leading zeros and IWL.

Only basic arithmetic and logic units are being used. The key components are priority encoder, adders, multiplexers, and shifters. Part of the functionality, for example, constant scaling, is implemented by hardwiring bits to the new positions. Due to the scaling, WLs of intermediate signals are relatively short. As the targeted accuracy depends on 𝑁, different implementations can be generated according to targeted application. Figure 2(a) shows a general case, that is, the number of inputs of multiplexers and 𝑁 are free variables. In Figures 2(b) and 2(c)  𝑁=1 and, therefore, multiplexers are controlled solely by 𝛼0. If 𝑁>1, the 𝑐 is obtained from the output of the first shifter(s) and the control signal is generated by concatenation of π‘π‘βˆ’2⋯𝑐0 and 𝛼0. Only the structure of linear approximation depends on 𝑁, and the other components in Figures 2(b) and 2(c) remain unaltered if 𝑁 is increased.

6. Comparisons

Areas of the proposed method and competitive methods are estimated for a suggestive comparison. The proposed method is synthesized with 130 nm technology. The areas of other methods are estimated by considering their most expensive area components, such as multipliers and LUTs, unless more accurate details are clearly specified in the referred design. Only the mantissa of floating-point implementations is considered since its computation is similar in fixed-point number system.

6.1. Estimation of Area

Areas in terms of logic gate equivalents (GEs) of the synthesized arithmetic and logic operations with different WLs are given in Table 1. Since the basic unit of area is one NAND gate, fractions are possible. On the contrary to simple cost estimation of LUTs in [10], we have estimated the area of all LUTs individually. If structures of LUTs are not specified in detail, fair assumptions are made for the referred works. The synthesized LUTs are filled with random bits. The main reason for accurate modeling of LUT complexity is that the relative area of LUT depends both on the address line width and data WL. Estimated areas of all the LUTs are given in Table 1.

6.2. Compared Implementations

Since low area is emphasized in the targeted application domain of baseband processing, the methods are compared using the area efficiency as the ratio of accuracy versus area. The metric is defined as areaefficiency=accuracyinbitsareainGEs.(14) For single precision (SP) methods the accuracy is 23 bits and for dual precision (DP) methods 52 bits. The area efficiency results for all the methods are shown in Table 2. The average accuracy of the proposed method in Table 2 is obtained in the subunitary range. Nonsubunitary range would increase the average accuracy even further. There are four versions of the proposed method with design parameter 𝑁=1,2,3,4. The results show that the proposed method has the lowest area, and even if the accuracy is adjusted with 𝑁, the area efficiency remains the highest except with 𝑁=1. Naturally, the accuracy is relatively modest, as we have preferred the lowest area instead of high accuracy.

The first method in Table 2 was targeted to DP general purpose processor [5]. It required LUTs of sizes 210Γ—23 and 211Γ—23 and multiplier for 76Γ—76 operands. Since the implementation was targeted to the general purpose processor, the hardware resources were not dedicated only to the inverse square root function. In [6] two 16Γ—56 and one 56Γ—56 multipliers were required. The total memory size was 72192 bits divided into four tables. For smaller gate count, we have assumed uniform division to four tables of 18048 bits with WL 22 bits, which is the widest word fetched from the tables. High speed was emphasized in [10]. Therefore, we compare with the method with single multiply and accumulate unit [10], which had better area efficiency. The authors also reported the complexity of 5030 full adders and, therefore, their value is used instead of our own estimates. In [13], SP floating-point numbers were targeted. A 210Γ—25 LUT was required and a 20Γ—20 multiplier. In addition, a requirement of 15 inverters was reported. Symmetric table addition method (STAM) was used in [21]. The smallest total LUT size was obtained with four LUTs of sizes 29Γ—19, 28Γ—10, 28Γ—8, and 28Γ—6. In addition, a sum of all the data read from LUTs must be generated, which requires adders with operand sizes 19Γ—10, 8Γ—6, and 20Γ—9. Also a requirement of 45 XOR gates was reported. Both SP and DP were targeted in [16] but the method for SP gave better area efficiency. The SP method required 27Γ—36 LUT, four 4Γ—4 multipliers, and one 22Γ—23 multiplier. Fixed-point number systems were targeted in [23]. The method applied STAM enhanced with added correction value. Estimated complexity of 625 GE and LUT size of 3456 bits were given in [23]. Since the structures of LUTs were not reported, we have assumed that, due to the STAM, the memory is divided at least to two LUTs. We also assume 16-bit WL. Several smaller LUTs or shorter WL would degrade the area efficiency. The estimated complexity of LUTs is added to the reported gate count.

6.3. Power Consumption

The power consumption of the largest proposed unit (𝑁=4) with 100 MHz is 0.339 mW, which includes the power required by input and output registers. Naturally, the static power consumption is proportional to the area, and, therefore, low complexity has been targeted. The dynamic power is proportional both to the area and average switching activity of the gates. Even if the average switching activity of competitive methods cannot be estimated sufficiently accurately, the differences in the area are significant. For example, [23] has the smallest area, 1602 GE, of the referred methods and the average switching activity of [23] should get as low as 622/1602Γ—100%=39% of the average switching activity of the largest proposed unit (622 GE, 𝑁=4) to achieve roughly the same dynamic power consumption.

7. Matrix Decomposition Implementation Case Studies

In this section, the proposed method for 1/√π‘₯ approximation is applied in QR and Cholesky decomposition implementations. Many matrix decompositions are implemented with systolic arrays [25] applying inherent regularity of the algorithm, and the computations are alleviated with CORDIC [26] algorithm. However, such structures are not as flexible as programmable processors and such high parallelism can easily result in so fast processing that the array processor must idle most of the time if applied, for example, in QR decomposition of MIMO receiver.

7.1. QR Decomposition with ASIP

Complex-valued QR decomposition was implemented with transport triggered architecture (TTA) [27] processor in [28]. The TTA is an ASIP template where parallel computing resources can be tailored according to the application. The proposed 1/√π‘₯ unit is instantiated in the processor as shown in Figure 3. In addition, there are units for complex addition and subtraction and complex multiplication with optional conjugation.

Typically, MIMO systems have only a couple of transmit and receive antennas, and, therefore, a 4Γ—4 matrix decomposition is targeted. The modified Gram-Schmidt algorithm requires 2𝑛3 operations for 𝑛×𝑛 matrix [24]. The processor implementation takes 139 clock cycles for 4Γ—4 matrix. If 2048 subcarriers must be processed within a coherence time of the channel, 160 MHz clock frequency is adequate. The processor is synthesized with 130 nm technology and it takes 16.3 kGE with 160 MHz and 23.2 kGE with 269 MHz. The power consumption with 160 and 269 MHz clock frequencies is 6.91 mW and 16.79 mW, respectively.

7.2. Cholesky Decomposition with DSP

Cholesky decomposition was implemented as a software routine on TI's C55x DSP in [29]. Equations (2) and (3) show that the algorithm lends itself to the multiply and accumulate instruction, for which DSPs are typically optimized. Furthermore, an efficient hardware looping can be applied in the innermost loops as testing within the loop can be avoided. With the simple 1/√π‘₯ approximation the developed program decomposes 64Γ—64 matrix in 85070 clock cycles.

Maintenance of a continuous flow of computations is more important for an efficient software implementation than focusing on avoidance of multiplications. In other words, pipeline should be kept full by avoiding conditional branching when possible. For example, describing computation of 𝛼 as defined in (6) in C language would result in a cumbersome loop testing bits of π‘₯. However, it can be avoided as the instruction set of the applied DSP has adequate assembly instruction for obtaining the number of leading zeros. Furthermore, short branches according to the parity of 𝛼 can be avoided with guarded instructions, that is, the computations proceed uninterrupted by both branches but only the other branch affects the state. Thus, the proposed method lends itself to an efficient software implementation on a DSP with adequate instructions for obtaining the number of leading zeros and for guarded execution.

8. Conclusions

The inverse square root function is highly nonlinear function and, therefore, approximated usually with high-complexity implementation. The proposed approximation method targets moderate precision fixed-point numbers. The computation has been based on an appropriate substitute, which allowed approximation without large LUTs and large multipliers. The method has one design parameter which allows scaling of the accuracy and hardware complexity. The area efficiency of the proposed method has been given in terms of approximation accuracy per area. Comparisons with previously reported methods show that the proposed method achieves low complexity and high area efficiency. Finally, the method has been applied on the targeted baseband functions as a function unit of an ASIP and as a software routine on a DSP.