NEURON CALCULATOR FOR ARTIFICIAL NEURAL NETWORKS
Examples described herein include systems and methods, including wireless devices and systems with neuron calculators that may perform one or more functionalities of a wireless transceiver. The neuron calculator calculates output signals that may be implemented, for example, using accumulation units that sum the multiplicative processing results of ordered sets from ordered neurons with connection weights for each connection between an ordered neuron and outputs of the neuron calculator. The ordered sets may be a combination of some input signals, with the number of signals determined by an order of the neuron. Accordingly, a kth-order neuron may include an ordered set comprising product values of k input signals, where the input signals are selected from a set of k-combinations with repetition. As an example in a wireless transceiver, the neuron calculator may perform channel estimation as a channel estimation processing component of the receiver portion of a wireless transceiver.
Latest MICRON TECHNOLOGY, INC. Patents:
- LOCAL I/O READ CIRCUIT IN MEMORY SYSTEM
- METHOD FOR MANUFACTURING SEMICONDUCTOR DEVICE INCLUDING BITCON AND CELLCON
- Assemblies Having Conductive Structures Along Pillars of Semiconductor Material, and Methods of Forming Integrated Circuitry
- Integrated Assemblies Having Body Contact Regions Proximate Transistor Body Regions; and Methods Utilizing Bowl Etches During Fabrication of Integrated Assemblies
- Memory Array And Method Used In Forming A Memory Array
Artificial neural networks are used in many applications, including image and speech recognition. Fifth generation (5G) wireless communication systems, including those employing multiple-input multiple-output (MIMO) techniques or “massive MIMO” techniques, in which multiple antennas (more than a certain number, such as 8 in the case of example MIMO systems) are utilized for transmission and/or receipt of wireless communication signals, also have applications for artificial neural networks. However, in increasing the learning of neural networks, the number of neurons and corresponding weights of the neural network may increase exponentially, overwhelming the memory and power limits of devices implementing such schemes.
Neural networks continue to be utilized in various memory-intensive and power-intensive applications, such as image recognition, wireless communication and speech recognition. Due in part to such memory and power demands, processor implementations may become more costly as neural networks grow larger. For example, the numbers of the weights and/or dimensions of weight matrices that are used to connect neurons may increase exponentially as the number of layers of neural networks increases and/or additional neurons are added to a network. To meet these demands, in some neural network applications, weights may be compressed and/or pruned to reduce the number of weights and/or neurons. However, because an additional, often onerous, process may be employed to identify and determine which weights to reduce, such pruning or compression of neural networks may often not be implemented without introducing additional complexity to the neural network, such as increased power or memory consumption. For example, weights in conventional schemes may be determined using a least-mean squares algorithm to produce weights with a large precision value, which may undesirably utilize additional memory.
Examples described herein may calculate and provide ordered sets for neural networks that utilize input signals as the basis for the ordered sets, thereby forming a neural network that utilizes less memory, or that uses memory more efficiently, than conventional schemes. In contrast to examples of conventional neural network arrangements that may store weights/parameters unrelated to the input signals, the systems and methods described herein may utilize input signals which may already be allocated memory storage as the basis for computing weights and/or elements of the neural network.
By associating neurons in a neural network with certain combinations of the input signals, the number of elements may be finite, thereby facilitating memory allocation. An additional advantage of such memory allocation includes increasing processed speed (e.g., by utilizing already known input signals); in contrast to conventional neural networks that may decrease processing speed, while attempting to increase a precision of a given neural network. For example, in accordance with examples of methods and systems described herein, a neuron calculator may calculate ordered sets based on the input signals and an order of a respective neuron to provide ordered sets for utilization as a neural network. The ordered sets may be a multiplicative combination of a number of the input signals, with the number of signals determined by an order of the neuron. Accordingly, a kth-order neuron may include an ordered set including product values of k input signals, where the input signals are selected from a set of k-combinations with repetition.
As described herein, the ordered sets stored in memory 15 to be implemented in respective ordered neurons 30, 32, and 38 may be a multiplicative combination of a number of the input signals, with the number of signals determined by an order of the neuron. Accordingly, for the first-order neuron 30, the first-ordered set comprises pi elements, where N1 is the number of input signals:
pi(1)(n)=xi(n) (i=1,2, . . . N1),
As denoted herein, the (1) superscript of a pi element denotes the order of that element in that ordered set. Accordingly, the (1) superscript indicates a first-order. For the second-order neuron 32, the second-ordered set comprises pij elements, where Ni(2) and Nj(2) are the number of input signals.
pij(2)(n)=xi(n)xj(n) (i=1,2, . . . Ni(2)j=1,2, . . . Nj(2)).
Because the ordered sets are sets of k-combinations with repetition, the total number of the i and j input signals are the same; resulting in a maximum number of second-order elements being Ni(2)×Nj(2), which equals N2 pij elements of the second-ordered set to be utilized in the second-order neuron 32. As an example, the neuron calculator 18 may calculate a second-ordered set for three input signals x1(n), x2(n), x3(n) to be pij elements, as shown in Table 1.
In Table 1, six independent elements represent the second-order elements, and, accordingly, may be utilized as the second-ordered set representing nonlinearities of the second-order for the input signals x1(n), x2(n), x3(n). Continuing in the example, for the k′th order neuron 38, the k′th-ordered set comprises pi
pi
Accordingly, the maximum number of k′th-order elements being Nk elements of the k′th-ordered set to be utilized in the k′th-order neuron 38. As an example, the neuron calculator 18 may calculate a k′th-ordered set for three input signals x1(n), x2(n), x3(n) to be pijk elements, as shown in Table 2.
In Table 2, ten independent elements represent the third-order elements, and, accordingly, may be utilized as the third-ordered set representing nonlinearities of the third-order for the input signals x1(n), x2(n), x3(n).
Again with reference to
In Equation 1, l corresponds to each output of each neuron (e.g., neurons 30, 32, and 38), ql(·) is the activation function of the l′th output of each neuron and Wl(·) is the corresponding connection weight set between the l′th output and the k′th-ordered neuron. Using Equation 1, the connection weights can be determined by the neuron calculator 18. For example, the neuron calculator 18 may utilize a least-mean squares algorithm to determine connection weights. For example, an error, ε, may be minimized between calibration signals provided to the neuron calculator 18 and the output signals z1(n), z2(n), zl(n). In the context of Equation 2, Z(n) may be a plurality of calibration signals provided to the neuron calculator 18 at inputs 20, 22, and 28, where M denotes how many calibration signals are provided to the neuron calculator 18.
As an example of applying Equation 2 to determine connection weights with calibration signals, a gradient descent method may be utilized to optimize the value of connection weights. For example, connection weights may be initially randomly selected (e.g., all connection weights may equal zero initially). The neuron calculator 18 calculates the outputs 40, 42, and 48 for the calibration signals in accordance with Equation 1. The neuron calculator 18 calculates the error at each of the outputs 40, 42, and 48. The calculated error, δl(n), at each of the outputs 40, 42, and 48, where ordered sets and the connection weights are summed, may be represented by Equation 3; with z(n) being the corresponding output of the neuron calculator 18 (e.g., outputs 40, 42, and 48) of a total number of outputs, L; where vl(n) is the weighted summation of the l′th neuron of the outputs 40, 42, and 48; and where [ql(vl(n)]′ is the gradient of the l′th neuron of the outputs 40, 42, and 48.
Accordingly, the neuron calculator 18 may compute an individual error of each output 40, 42, and 48 after summing the ordered sets and the connection weights at the outputs 40, 42, and 48 to generate output signals z1(n), z2(n), zl(n). As an example of the summation for calculating an error of respective calibration signals, continuing with the denotation of ordered sets and connection weights of Equation 1, the neuron calculator is configured to mix (e.g., sum) at each respective output 40, 42, and 48 the ordered sets and connection weights with the calibration signals Z(n), as expressed in Equation 4.
Continuing in the example of determining the connection weights, the initial connection weights may be updated according to Equation 5.
ΔWl(i1, i1 . . . ik)=α Σn=1Mδl(n)pi
For example, the neuron calculator 18 may sum the product of the calculated error, δl(n), at each of the outputs 40, 42, and 48, with the elements of each ordered neuron. In accordance with Equation 5, that summation may be multiplied by a learning-rate factor, α. In some examples, various sets of M calibration signals may be provided to the neuron calculator 18 to continue updating the connection weights. Once the weights have converged, in accordance with gradient descent methods, the connection weights may be stored in memory 15 for use by the neuron calculator 18 to map various inputs signals to output signals. For example, the neuron calculator 18 may function as a processing component of a wireless transceiver. For example, the neuron calculator 18 may perform channel estimation as a channel estimation processing component of the receiver portion of a wireless transceiver. Accordingly, in the context of a neuron calculator 18 being a channel estimation processing component, the neuron calculator 18 may include ordered sets and connection weights that, when applied to a wireless input signal, remove or reduce an error introduced by a wireless channel. In various examples, a neuron calculator 18 or several neuron calculators may operate in conjunction with a wireless transceiver to perform various wireless processing component functionalities.
The neuron calculator 18 can be implemented using one or more processing units, for example, having any number of cores. An example processing unit can include an arithmetic logic unit (ALU), a bit manipulation unit, a multiplication unit, an accumulation unit, an adder unit, a look-up table unit, a memory look-up unit, or any combination thereof. For example, a processing unit 58 is described with reference to
In an example processor core, a set of instructions can be loaded that implements calculations performed by the neuron calculator 18. In some examples, the neuron calculator 18 may include circuitry, including custom circuitry, and/or firmware for performing functions described herein. For example, circuitry can include multiplication unit, accumulation units, and/or bit manipulation units for performing the described functions, as described herein. The neuron calculator 18 may be implemented in any type of processor architecture including but not limited to a microprocessor or a digital signal processor (DSP), or any combination thereof. In an example processor core, a set of instructions can be loaded that implements the training of the neuron calculator 18 being provided calibration signals, e.g., training the neuron calculator 18 to determine the elements of the ordered sets and the connection weights.
In
The multiplication unit/accumulation units 62a-c, 66a-c multiply two operands from the input signals 60a-c to generate a multiplication processing result that is accumulated by the accumulation unit portion of the multiplication unit/accumulation units 62a-c, 66a-c. The multiplication unit/accumulation units 62a-c, 66a-c adds the multiplication processing result to update the processing result stored in the accumulation unit portion, thereby accumulating the multiplication processing result. For example, the multiplication unit/accumulation units 62a-c, 66a-c may perform a multiply-accumulate operation such that two operands, M and N, are multiplied and then added with P to generate a new version of P that is stored in its respective multiplication unit/accumulation units.
The memory look-up units 64a-c, 68a-c retrieve ordered sets of ordered neurons and/or connections weights stored in memory 55. The output of the memory look-up units 64a-c, 68a-c is provided to the multiplication unit/accumulation units 62a-c, 66a c that may be utilized as a multiplication operand in the multiplication unit portion of the multiplication unit/accumulation units 62a-c, 66a-c. For example, the memory look-up unit can be a table look-up that retrieves a specific plurality of connection weights associated with that respective ordered neuron. As described herein, the neuron calculator 18 may calculate, dynamically, the ordered sets of the ordered neurons based on the input signals 60a-c to be used as part of the multiply-accumulate operation. In some examples, the calculated ordered sets may be stored in the memory 55 and retrieved by the memory look-up units 64a-c, 68a-c. Or the calculated ordered sets may be utilized in the multiply-accumulate operation, once calculated, as part of generating the output signals 70a-c. For example, the input signals 60a-c may be used to calculate respective ordered sets, e.g., inputs signals for a second-order neuron comprises second-order pij elements as described above with respect to
Each of the multiplication unit/accumulation units 62a-c, 66a-c may include multiple multipliers, multiple accumulation unit, or and/or multiple adders. Any one of the multiplication unit/accumulation units 62a-c, 66a-c may be implemented using an ALU. In some examples, any one of the multiplication unit/accumulation units 62a-c, 66a-c can include one multiplier and one adder that each perform, respectively, multiple multiplications and multiple additions. The input-output relationship of a multiplication/accumulation unit 62a-c, 66a-c may be represented as:
where “I” represents a number to perform the multiplications in that unit, Ci the coefficients which may be accessed from a memory, such as memory 55, and Bin(i) represents a factor from either the input data X(n) 60a-c or an output from multiplication unit/accumulation units 62a-c, 66a-c. In an example, the output of a set of multiplication unit/accumulation units, Bout, equals the sum of coefficient data, Ci multiplied by the output of another set of multiplication unit/accumulation units, Bin(i). Bin(i) may also be the input data such that the output of a set of multiplication unit/accumulation units, Bout, equals the sum of coefficient data, Ci multiplied by input data.
Electronic devices 102, 110 may include a neural network 10. For example, wireless transmitter 131 and wireless receiver 135 may include in combination a neural network 10, each having a neuron calculator 18 incorporated as part of at least on component of the respective transmitter 131 or receiver 135. In operation, the neuron calculators 18 may calculate ordered sets and provide output signals for one or more components of the transmitter 131 or the receiver 135. In an example, the wireless transmitter 133 may include a neural network 10 with several neuron calculators 18 or a single neuron calculator 18. In operation, the neuron calculator(s) 18 of the transmitter 133 may calculate ordered sets and provide output signals for one or more components of the transmitter 133. As can be appreciated, and as additionally described with respect to
Electronic devices described herein, such as electronic device 102 and electronic device 110 shown in
While not explicitly shown in
The electronic device 102 and the electronic device 110 may each include multiple antennas. For example, the electronic device 102 and electronic device 110 may each have more than two antennas. Three antennas each are shown in
Generally, systems described herein may include multiple-input, multiple-output (“MIMO”) systems. MIMO systems generally refer to systems including one or more electronic devices which transmit transmissions using multiple antennas and one or more electronic devices which receive transmissions using multiple antennas. In some examples, electronic devices may both transmit and receive transmissions using multiple antennas. Some example systems described herein may be “massive MIMO” systems. Generally, massive MIMO systems refer to systems employing greater than a certain number (e.g. 16) antennas to transmit and/or receive transmissions. As the number of antennas increase, so generally does the complexity involved in accurately transmitting and/or receiving transmissions.
Although two electronic devices (e.g. electronic device 102 and electronic device 110) are shown in
Electronic devices described herein may include receivers, transmitters, and/or transceivers. For example, the electronic device 102 of
Generally, multiple receivers, transmitters, and/or transceivers may be provided in an electronic device—one in communication with each of the antennas of the electronic device. The transmissions may be in accordance with any of a variety of protocols, including, but not limited to 5G signals, and/or a variety of modulation/demodulation schemes may be used, including, but not limited to: orthogonal frequency division multiplexing (OFDM), filter bank multi-carrier (FBMC), the generalized frequency division multiplexing (GFDM), universal filtered multi-carrier (UFMC) transmission, bi orthogonal frequency division multiplexing (BFDM), sparse code multiple access (SCMA), non-orthogonal multiple access (NOMA), multi-user shared access (MUSA) and faster-than-Nyquist (FTN) signaling with time-frequency packing. In some examples, the transmissions may be sent, received, or both, in accordance with various protocols and/or standards (e.g., NR, LTE, WiFi, etc.).
Examples of transmitters, receivers, and/or transceivers described herein, such as the wireless transmitter 131, wireless transmitter 133, wireless receiver 115, or wireless receiver 117, may be implemented using a variety of components, including, hardware, software, firmware, or combinations thereof. For example, transceivers, transmitters, or receivers may include circuitry and/or one or more processing units (e.g. processors) and memory encoded with executable instructions for causing the transceiver to perform one or more functions described herein (e.g. software).
The scrambler 304 may convert the input data to a pseudo-random or random binary sequence. For example, the input data may be a transport layer source (such as MPEG-2 Transport stream and other data) that is converted to a Pseudo Random Binary Sequence (PRBS) with a generator polynomial. While described in the example of a generator polynomial, various scramblers 304 are possible.
The coder 308 may encode the data outputted from the scrambler to code the data. For example, a Reed-Solomon (RS) encoder, turbo encoder may be used as a first coder to generate a parity block for each randomized transport packet fed by the scrambler 304. In some examples, the length of parity block and the transport packet can vary according to various wireless protocols. The interleaver 312 may interleave the parity blocks output by the coder 308, for example, the interleaver 312 may utilize convolutional byte interleaving. In some examples, additional coding and interleaving can be performed after the coder 308 and interleaver 312. For example, additional coding may include a second coder that may further code data output from the interleaver, for example, with a punctured convolutional coding having a certain constraint length. Additional interleaving may include an inner interleaver that forms groups of joined blocks. While described in the context of a RS coding, turbo coding, and punctured convolution coding, various coders 308 are possible, such as a low-density parity-check (LDPC) coder or a polar coder. While described in the context of convolutional byte interleaving, various interleavers 312 are possible.
The modulation mapping 316 may modulate the data output from the interleaver 312. For example, quadrature amplitude modulation (QAM) may be used to map the data by changing (e.g., modulating) the amplitude of the related carriers. Various modulation mappings may be used, including, but not limited to: Quadrature Phase Shift Keying (QPSK), SCMA, NOMA, and MUSA (Multi-user Shared Access). Output from the modulation mapping 316 may be referred to as data symbols. While described in the context of QAM modulation, various modulation mappings 316 are possible. The frame adaptation 320 may arrange the output from the modulation mapping according to bit sequences that represent corresponding modulation symbols, carriers, and frames.
The IFFT logic 324 may be a processor and/or a computer-readable media implementing instructions to execute an inverse fast Fourier transform. For example, the IFFT logic 324 may transform symbols that have been framed into sub-carriers (e.g., by frame adaptation 320) into time-domain symbols. Taking an example of a 5G wireless protocol scheme, the IFFT can be applied as N-point IFFT:
where Xn is the modulated symbol sent in the nth 5G sub-carrier. Accordingly, the output of the IFFT logic 324 may form time-domain 5G symbols. In some examples, the IFFT of the logic 324 may be replaced by a pulse shaping filter or poly-phase filtering banks to output symbols for frequency up-conversion 330. For example, the processor and/or the computer-readable media implementing instructions to execute an inverse fast Fourier transform may be changed or updated to implement a pulse shaping filter or poly-phase filtering banks.
In the example of
The frequency up-conversion 330 may up-convert the time-domain 5G symbols to a specific radio frequency. For example, the time-domain 5G symbols can be viewed as a baseband frequency range and a local oscillator can mix the frequency at which it oscillates with the 5G symbols to generate 5G symbols at the oscillation frequency. A digital up-converter (DUC) may also be utilized to convert the time-domain 5G symbols. Accordingly, the 5G symbols can be up-converted to a specific radio frequency for an RF transmission.
Before transmission, at the antenna 303, a power amplifier 332 may amplify the transmitter output signal xN(n) 310 to output data for an RF transmission in an RF domain at the antenna 303. The antenna 303 may be an antenna designed to radiate at a specific radio frequency. For example, the antenna 303 may radiate at the frequency at which the 5G symbols were up-converted. Accordingly, the wireless transmitter 300 may transmit an RF transmission via the antenna 303 based on the data signal 311 received at the scrambler 304.
As described above with respect to
The frequency down-conversion 412 may down-convert the frequency domain symbols to a baseband processing range. For example, continuing in the example of a 5G implementation, the frequency-domain 5G symbols may be mixed with a local oscillator frequency to generate 5G symbols at a baseband frequency range. A digital down-converter (DDC) may also be utilized to convert the frequency domain symbols. Accordingly, the RF transmission including time-domain 5G symbols may be down-converted to baseband. The guard interval removal 416 may remove a guard interval from the frequency-domain 5G symbols.
The FFT logic 420 may be a processor and/or a computer-readable media implementing instructions to execute a fast Fourier transform. For example, the FFT logic 420 may transform the time-domain 5G symbols into frequency-domain 5G symbols. Taking an example of a 5G wireless protocol scheme, the FFT can be applied as N-point FFT:
where Xn is the modulated symbol sent in the nth 5G sub-carrier. Accordingly, the output of the FFT logic 420 may form frequency-domain 5G symbols. In some examples, the FFT of the logic 420 may be replaced by poly-phase filtering banks to output symbols for synchronization 424. For example, the processor and/or the computer-readable media implementing instructions to execute a fast Fourier transform may be changed or updated to implement poly-phase filtering banks.
The synchronization 424 may detect pilot symbols in the 5G symbols to synchronize the transmitted data. In some examples of a 5G implementation, pilot symbols may be detected at the beginning of a frame (e.g., in a header) in the time-domain. Such symbols can be used by the wireless receiver 400 for frame synchronization. With the frames synchronized, the 5G symbols proceed to channel estimation 428. The channel estimation 428 may also use the time-domain pilot symbols and additional frequency-domain pilot symbols to estimate the time or frequency effects (e.g., path loss) to the received signal.
For example, a channel may be estimated according to N signals received through M antennas (in addition to the antenna 405) in a preamble period of each signal. In some examples, the channel estimation 428 may also use the guard interval that was removed at the guard interval removal 416. With the channel estimate processing, the channel estimation 428 may compensate for the frequency-domain 5G symbols by some factor to minimize the effects of the estimated channel. While channel estimation has been described in terms of time-domain pilot symbols and frequency-domain pilot symbols, other channel estimation techniques or systems are possible, such as a MIMO-based channel estimation system or a frequency-domain equalization system.
The demodulation mapping 432 may demodulate the data outputted from the channel estimation 428. For example, a quadrature amplitude modulation (QAM) demodulator can map the data by changing (e.g., modulating) the amplitude of the related carriers. Any modulation mapping described herein can have a corresponding demodulation mapping as performed by demodulation mapping 432. In some examples, the demodulation mapping 432 may detect the phase of the carrier signal to facilitate the demodulation of the 5G symbols. The demodulation mapping 432 may generate bit data from the 5G symbols to be further processed by the deinterleaver 436.
The deinterleaver 436 may deinterleave the data bits, arranged as parity block from demodulation mapping into a bit stream for the decoder 440, for example, the deinterleaver 436 may perform an inverse operation to convolutional byte interleaving. The deinterleaver 436 may also use the channel estimation to compensate for channel effects to the parity blocks.
The decoder 440 may decode the data outputted from the scrambler to code the data. For example, a Reed-Solomon (RS) decoder or turbo decoder may be used as a decoder to generate a decoded bit stream fur the descrambler 444. For example, a turbo decoder may implement a parallel concatenated decoding scheme. In some examples, additional decoding and/or deinterleaving may be performed after the decoder 440 and deinterleaver 436. For example, additional decoding may include another decoder that may further decode data output from the decoder 440. While described in the context of a RS decoding and turbo decoding, various decoders 440 are possible, such as low-density parity-check (LDPC) decoder or a polar decoder.
The descrambler 444 may convert the output data from decoder 440 from a pseudo-random or random binary sequence to original source data. For example, the descrambler 44 may convert decoded data to a transport layer destination (e.g., MPEG-2 transport stream) that is descrambled with an inverse to the generator polynomial of the scrambler 304. The descrambler thus outputs receiver output data. Accordingly, the wireless receiver 400 receives an RF transmission including input data X (i,j) 410 via to generate the receiver output data.
As described herein, for example with respect to
During processing of the signals received from the antennas 105, 107, the wireless receivers 115, 117 may provide input signals x1(n), x2(n) 221, 223 to the neuron calculator 240. For example, the input signals x1(n), x2(n) 221, 223 may be provided to the neuron calculator 240 via internal paths from an output of the wireless receiver 115 and an output of the wireless receiver 117. Accordingly, paths stemming from the wireless receivers 115, 117 and the neuron calculator 240 may be in communication with one another. The neuron calculator 240, therefore, receives a first signal x1(n) 221 associated with the wireless receiver 115 and a second signal x2(n) 223 associated with the wireless receiver 117.
Examples of neuron calculators described herein may generate and provide output signals z1(n), z2(n) 245, 247 to wireless receivers 245, 247. In generating such output signals, the neuron calculator may calculate elements of ordered sets pi,j(k) 241. For example, as described with reference to
While
Example method 600 may begin a neuron calculation method. At block 608, the method 600 includes receiving calibration signals at a neuron calculator. A neuron calculator 18 having inputs 20, 22, and 28 may receive at least respective calibration signals at each input, e.g., a first calibration signal, a second calibration signal, and a third calibration signal. Such calibration signals may be utilized to determine connection weights for the neuron calculator, as further described with respect to block 620. For example, a set of calibration signals may include a signal utilized for a wireless transmitter or wireless receiver to determine a channel estimation, e.g., a pilot signal.
At block 612, the method 600 includes calculating a plurality of ordered sets based on the calibration signals. For example, as described with respect to Table 1, calculating the plurality of ordered sets includes, multiplying each of first calibration signal, second calibration signal, and third calibration signal with one of the first calibration signal, second calibration signal, or third calibration signal to generate a second-order set of the plurality of ordered sets. Similarly, for a third-order set calculation, as described with respect to Table 2, calculating the plurality of ordered sets includes, multiplying each of the first calibration signal, second calibration signal, and third calibration signal with two signals of a set including the first calibration signal, second calibration signal, or third calibration signal to generate the third-order set. For example, with respect to the second-order set, multiplying each of first calibration signal, second calibration signal, and third calibration signal with one of the first calibration signal, second calibration signal, or third calibration signal includes multiplying the first calibration signal with the first calibration signal to generate a first multiplicative processing result of the second order set; multiplying the first calibration signal with the second calibration signal to generate a second multiplicative processing result of the second order set; multiplying the first calibration signal with the third calibration signal to generate a third multiplicative processing result of the second order set; multiplying the second calibration signal with the first calibration signal to generate a fourth multiplicative processing result of the second order set; multiplying the second calibration signal with the second calibration signal to generate a fifth multiplicative processing result of the second order set; multiplying the second calibration signal with the third calibration signal to generate a sixth multiplicative processing result of the second order set; multiplying the third calibration signal with the first calibration signal to generate a seventh multiplicative processing result of the second order set; multiplying the third calibration signal with the second calibration signal to generate an eighth multiplicative processing result of the second order set; and multiplying the third calibration signal with the third calibration signal to generate a ninth multiplicative processing result of the second order set.
At block 616, the method 600 includes allocating each ordered set of the plurality of ordered sets to a respective ordered neuron of the neuron calculator. For example, as described with respect to
At block 620, the method 600 includes generating connection weights for the neuron calculator. The neuron calculator may utilize an algorithm to implement Equations 1-5 to generate the connection weights. For example, using a gradient descent method, connection weights may be randomly selected and iterated at a learning rate factor until a convergence point is reached. A connection weight may be determined for a corresponding connection between each respective ordered neuron of the neuron calculator and a respective output of a plurality of outputs of the neuron calculator. At the outputs, at least a portion of the plurality of ordered sets may be combined/mixed with at least a portion of the connection weights to generate compensated calibration signals. In iterating, an error of compensated calibrations signals based on a summation of the plurality of connection weights and at least a portion of the plurality of ordered sets may be reduced. At block 628, the method 600 ends.
The blocks included in the described example methods 600 are for illustration purposes. In some examples, the blocks may be performed in a different order. In some other examples, various blocks may be eliminated. In still other examples, various blocks may be divided into additional blocks, supplemented with other blocks, or combined together into fewer blocks. Other variations of these specific blocks are contemplated, including changes in the order of the blocks, changes in the content of the blocks being split or combined into other blocks, etc.
Additionally or alternatively, the wireless communications connections may support various modulation schemes, including but not limited to: filter bank multi-carrier (FBMC), the generalized frequency division multiplexing (GFDM), universal filtered multi-carrier (UFMC) transmission, bi-orthogonal frequency division multiplexing (BFDM), sparse code multiple access (SCMA), non-orthogonal multiple access (NOMA), multi-user shared access (MUSA), and faster-than-Nyquist (FTN) signaling with time-frequency packing. Such frequency bands and modulation techniques may be a part of a standards framework, such as Long Term Evolution (LTE) or other technical specification published by an organization like 3GPP or IEEE, which may include various specifications for subcarrier frequency ranges, a number of subcarriers, uplink/downlink transmission speeds, TDD/FDD, and/or other aspects of wireless communication protocols.
The system 700 may depict aspects of a radio access network (RAN), and system 700 may be in communication with or include a core network (not shown). The core network may include one or more serving gateways, mobility management entities, home subscriber servers, and packet data gateways. The core network may facilitate user and control plane links to mobile devices via the RAN, and it may be an interface to an external network (e.g., the Internet). Base stations 710, communication devices 720, and small cells 730 may be coupled with the core network or with one another, or both, via wired or wireless backhaul links (e.g., S1 interface, X2 interface, etc.).
The system 700 may provide communication links connected to devices or “things,” such as sensor devices, e.g., solar cells 737, to provide an Internet of Things (“IoT”) framework. Connected things within the IoT may operate within frequency bands licensed to and controlled by cellular network service providers, or such devices or things may. Such frequency bands and operation may be referred to as narrowband IoT (NB-IoT) because the frequency bands allocated for IoT operation may be small or narrow relative to the overall system bandwidth. Frequency bands allocated for NB-IoT may have bandwidths of 50, 100, or 200 KHz, for example.
Additionally or alternatively, the IoT may include devices or things operating at different frequencies than traditional cellular technology to facilitate use of the wireless spectrum. For example, an IoT framework may allow multiple devices in system 700 to operate at a sub-6 GHz band or other industrial, scientific, and medical (ISM) radio bands where devices may operate on a shared spectrum for unlicensed uses. The sub-6 GHz band may also be characterized as and may also be characterized as an NB-IoT band. For example, in operating at low frequency ranges, devices providing sensor data for “things,” such as solar cells 737, may utilize less energy, resulting in power-efficiency and may utilize less complex signaling frameworks, such that devices may transmit asynchronously on that sub-6 GHz band. The sub-6 GHz band may support a wide variety of uses case, including the communication of sensor data from various sensors devices. Examples of sensor devices include sensors for detecting energy, heat, light, vibration, biological signals (e.g., pulse, EEG, EKG, heart rate, respiratory rate, blood pressure), distance, speed, acceleration, or combinations thereof. Sensor devices may be deployed on buildings, individuals, and/or in other locations in the environment. The sensor devices may communicate with one another and with computing systems which may aggregate and/or analyze the data provided from one or multiple sensor devices in the environment. Such data may be used to indicate an environmental characteristic of the sensor.
In such a 5G framework, devices may perform functionalities performed by base stations in other mobile networks (e.g., UMTS or LTE), such as forming a connection or managing mobility operations between nodes (e.g., handoff or reselection). For example, mobile device 715 may receive sensor data from the user utilizing the mobile device 715, such as blood pressure data, and may transmit that sensor data on a narrowband IoT frequency band to base station 710. In such an example, some parameters for the determination by the mobile device 715 may include availability of licensed spectrum, availability of unlicensed spectrum, and/or time-sensitive nature of sensor data. Continuing in the example, mobile device 715 may transmit the blood pressure data because a narrowband IoT band is available and can transmit the sensor data quickly, identifying a time-sensitive component to the blood pressure (e.g., if the blood pressure measurement is dangerously high or low, such as systolic blood pressure is three standard deviations from norm).
Additionally or alternatively, mobile device 715 may form device-to-device (D2D) connections with other mobile devices or other elements of the system 700. For example, the mobile device 715 may form RFID, WiFi, MultiFire, Bluetooth, or Zigbee connections with other devices, including communication device 720 or vehicle 745. In some examples, D2D connections may be made using licensed spectrum bands, and such connections may be managed by a cellular network or service provider. Accordingly, while the above example was described in the context of narrowband IoT, it can be appreciated that other device-to-device connections may be utilized by mobile device 715 to provide information (e.g., sensor data) collected on different frequency bands than a frequency band determined by mobile device 715 for transmission of that information.
Moreover, some communication devices may facilitate ad-hoc networks, for example, a network being formed with communication devices 720 attached to stationary objects) and the vehicles 740, 745, without a traditional connection to a base station 710 and/or a core network necessarily being formed. Other stationary objects may be used to support communication devices 720, such as, but not limited to, trees, plants, posts, buildings, blimps, dirigibles, balloons, street signs, mailboxes, or combinations thereof. In such a system 700, communication devices 720 and small cell 730 (e.g., a small cell, femtocell, WLAN access point, cellular hotspot, etc.) may be mounted upon or adhered to another structure, such as lampposts and buildings to facilitate the formation of ad-hoc networks and other IoT-based networks. Such networks may operate at different frequency bands than existing technologies, such as mobile device 715 communicating with base station 710 on a cellular communication band.
The communication devices 720 may form wireless networks, operating in either a hierarchal or ad-hoc network fashion, depending, in part, on the connection to another element of the system 700. For example, the communication devices 720 may utilize a 700 MHz communication frequency to form a connection with the mobile device 715 in an unlicensed spectrum, while utilizing a licensed spectrum communication frequency to form another connection with the vehicle 745. Communication devices 720 may communicate with vehicle 745 on a licensed spectrum to provide direct access for time-sensitive data, for example, data for an autonomous driving capability of the vehicle 745 on a 5.9 GHz band of Dedicated Short Range Communications (DSRC).
Vehicles 740 and 745 may form an ad-hoc network at a different frequency band than the connection between the communication device 720 and the vehicle 745. For example, for a high bandwidth connection to provide time-sensitive data between vehicles 740, 745, a 24 GHz mmWave band may be utilized for transmissions of data between vehicles 740, 745. For example, vehicles 740, 745 may share real-time directional and navigation data with each other over the connection while the vehicles 740, 745 pass each other across a narrow intersection line. Each vehicle 740, 745 may be tracking the intersection line and providing image data to an image processing algorithm to facilitate autonomous navigation of each vehicle while each travels along the intersection line. In some examples, this real-time data may also be substantially simultaneously shared over an exclusive, licensed spectrum connection between the communication device 720 and the vehicle 745, for example, for processing of image data received at both vehicle 745 and vehicle 740, as transmitted by the vehicle 740 to vehicle 745 over the 24 GHz mmWave band. While shown as automobiles in
While described in the context of a 24 GHz mmWave band, it can be appreciated that connections may be formed in the system 700 in other mmWave bands or other frequency bands, such as 28 GHz, 37 GHz, 38 GHz, 39 GHz, which may be licensed or unlicensed bands. In some cases, vehicles 740, 745 may share the frequency band that they are communicating on with other vehicles in a different network. For example, a fleet of vehicles may pass vehicle 740 and, temporarily, share the 24 GHz mmWave band to form connections among that fleet, in addition to the 24 GHz mmWave connection between vehicles 740, 745. As another example, communication device 720 may substantially simultaneously maintain a 700 MHz connection with the mobile device 715 operated by a user (e.g., a pedestrian walking along the street) to provide information regarding a location of the user to the vehicle 745 over the 5.9 GHz band. In providing such information, communication device 720 may leverage antenna diversity schemes as part of a massive MIMO framework to facilitate time-sensitive, separate connections with both the mobile device 715 and the vehicle 745. A massive MIMO framework may involve a transmitting and/or receiving devices with a large number of antennas (e.g., 12, 20, 64, 128, etc.), which may facilitate precise beamforming or spatial diversity unattainable with devices operating with fewer antennas according to legacy protocols (e.g., WiFi or LTE).
The base station 710 and small cell 730 may wirelessly communicate with devices in the system 700 or other communication-capable devices in the system 700 having at the least a sensor wireless network, such as solar cells 737 that may operate on an active/sleep cycle, and/or one or more other sensor devices. The base station 710 may provide wireless communications coverage for devices that enter its coverages area, such as the mobile device 715 and the drone 717. The small cell 730 may provide wireless communications coverage for devices that enter its coverage area, such as near the building that the small cell 730 is mounted upon, such as vehicle 745 and drone 717.
Generally, the small cell 730 may be referred to as a small cell and provide coverage for a local geographic region, for example, coverage of 200 meters or less in some examples. This may be contrasted with a macrocell, which may provide coverage over a wide or large area on the order of several square miles or kilometers. In some examples, a small cell 730 may be deployed (e.g., mounted on a building) within some coverage areas of a base station 710 (e.g., a macrocell) where wireless communications traffic may be dense according to a traffic analysis of that coverage area. For example, a small cell 730 may be deployed on the building in
While base station 710 and small cell 730 may provide communication coverage for a portion of the geographical area surrounding their respective areas, both may change aspects of their coverage to facilitate faster wireless connections for certain devices. For example, the small cell 730 may primarily provide coverage for devices surrounding or in the building upon which the small cell 730 is mounted. However, the small cell 730 may also detect that a device has entered is coverage area and adjust its coverage area to facilitate a faster connection to that device.
For example, a small cell 730 may support a massive MIMO connection with the drone 717, which may also be referred to as an unmanned aerial vehicle (UAV), and, when the mobile device 715 enters it coverage area, the small cell 730 adjusts some antennas to point directionally in a direction of the device 715, rather than the drone 717, to facilitate a massive MIMO connection with the vehicle, in addition to the drone 717. In adjusting some of the antennas, the small cell 730 may not support as fast as a connection to the drone 717, as it had before the adjustment. However, the drone 717 may also request a connection with another device (e.g., base station 710) in its coverage area that may facilitate a similar connection as described with reference to the small cell 730, or a different (e.g., faster, more reliable) connection with the base station 710. Accordingly, the small cell 730 may enhance existing communication links in providing additional connections to devices that may utilize or demand such links. For example, the small cell 730 may include a massive MIMO system that directionally augments a link to vehicle 745, with antennas of the small cell directed to the vehicle 745 for a specific time period, rather than facilitating other connections (e.g., the small cell 730 connections to the base station 710, drone 717, or solar cells 737). In some examples, drone 717 may serve as a movable or aerial base station.
The wireless communications system 700 may include devices such as base station 710, communication device 720, and small cell 730 that may support several connections to devices in the system 700. Such devices may operate in a hierarchal mode or an ad-hoc mode with other devices in the network of system 700. While described in the context of a base station 710, communication device 720, and small cell 730, it can be appreciated that other devices that can support several connections with devices in the network may be included in system 700, including but not limited to: macrocells, femtocells, routers, satellites, and RFID detectors.
In various examples, the elements of wireless communication system 700, such as the drone 717, may be implemented utilizing the systems, apparatuses, and methods described herein. For example, the drone 717, being implemented as the electronic device 110, may receive a wireless communication signal from base station 710. In demodulating and decoding the received wireless communications signal, the drone 717 may also implement a neuron calculator 18 to calculate output signals for one or more processing stages of a wireless receiver path. For example, the drone 717 may implement the neuron calculator 18 for channel estimation to determine an error introduced by the wireless channel between the base station 710 and the drone 717. In calculating the output signals for channel estimation as part of a neuron calculator 18, the drone 717 may utilize less-power and less-memory, as the ordered sets of the neuron calculator 18 are calculated based on the received wireless communications signal from the base station 710. Accordingly, the drone 717 may utilize less die space on a silicon chip than conventional signal processing systems and techniques that can include additional hardware or specially-designed hardware, thereby allowing the drone 717 to be of smaller size compared to drones having such conventional signal processing systems and techniques.
Additionally or alternatively, while described in the examples above in the context of the drone 717, the elements of communication system 700 may be implemented as part of any example described herein, such as electronic device 102, 110 of
The small cell 830 or any of the devices of building 810 may be connected to a network that provides access to the Internet and traditional communication links. Like the system 700, the wireless communications system 800 may facilitate a wide-range of wireless communications connections in a 5G system that may include various frequency bands, including but not limited to: a sub-6 GHz band (e.g., 700 MHz communication frequency), mid-range communication bands (e.g., 2.4 GHz), and mmWave bands (e.g., 24 GHz). Additionally or alternatively, the wireless communications connections may support various modulation schemes as described above with reference to system 700. Wireless communications system 800 may operate and be configured to communicate analogously to system 700. Accordingly, similarly numbered elements of wireless communications system 800 and system 700 may be configured in an analogous way, such as communication device 720 to communication device 820, small cell 730 to small cell 830, etc.
Like the system 700, where elements of system 700 are configured to form independent hierarchal or ad-hoc networks, communication device 820 may form a hierarchal network with small cell 830 and mobile device 815, while an additional ad-hoc network may be formed among the small cell 830 network that includes drone 817 and some of the devices of the building 810, such as networked workstations 840, 845 and IoT devices 855, 860.
Devices in wireless communications system 800 may also form (D2D) connections with other mobile devices or other elements of the wireless communications system 800. For example, the virtual reality device 850 may form a narrowband IoT connections with other devices, including IoT device 855 and networked entertainment device 865. As described above, in some examples, D2D connections may be made using licensed spectrum bands, and such connections may be managed by a cellular network or service provider. Accordingly, while the above example was described in the context of a narrowband IoT, it can be appreciated that other device-to-device connections may be utilized by virtual reality device 850.
In various examples, the elements of wireless communications system 800, such as the mobile device 815, the drone 817, the communication device 820, the small cell 830, the networked workstations 840, 845, the virtual reality device 850, the IoT devices 855, 860, and the networked entertainment device 865, may be implemented as part of any example described herein, such as electronic device 102, 110 of
The computing system 902 includes memory 950 (e.g., memory look-up unit), which may be non-transitory hardware readable medium including instructions, respectively, for calculating neuron or be memory for the retrieval, calculation, or storage of data signals to be compensated or adjusted signals based on calculated neuron. The neuron calculator 940 may control the computing system 902 with control instructions that indicate when to execute such stored instructions for calculating neuron or for the retrieval or storage of data signals to be compensated or adjusted signals based on calculated neuron. Upon receiving such control instructions, the wireless transceiver 910 may execute such instructions. For example, such instructions may include a program that executes the method 600. Communications between the neuron calculator 940, the I/O interface 970, and the network interface 990 are provided via an internal bus 980. The neuron calculator 940 may receive control instructions from the I/O interface 970 or the network interface 990, such as instructions to calculate ordered sets fur ordered neurons or connection weights.
Bus 980 may include one or more physical buses, communication lines/interfaces, and/or point-to-point connections, such as Peripheral Component Interconnect (PCI) bus, a Gen-Z switch, a CCIX interface, or the like. The I/O interface 970 can include various user interfaces including video and/or audio interfaces for the user, such as a tablet display with a microphone. Network interface 990 communications with other electronic devices, such as electronic device 900 or a cloud-electronic server, over the network 995. For example, the network interface 990 may be a USB interface.
Certain details are set forth above to provide a sufficient understanding of described examples. However, it will be clear to one skilled in the art that examples may be practiced without various of these particular details. The description herein, in connection with the appended drawings, describes example configurations and does not represent all the examples that may be implemented or that are within the scope of the claims. The terms “exemplary” and “example” as may be used herein means “serving as an example, instance, or illustration,” and not “preferred” or “advantageous over other examples.” The detailed description includes specific details for the purpose of providing an understanding of the described techniques. These techniques, however, may be practiced without these specific details. In some instances, well-known structures and devices are shown in block diagram form in order to avoid obscuring the concepts of the described examples.
Information and signals described herein may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits, symbols, and chips that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
Techniques described herein may be used for various wireless communications systems, which may include multiple access cellular communication systems, and which may employ code division multiple access (CDMA), time division multiple access (TDMA), frequency division multiple access (FDMA), orthogonal frequency division multiple access (OFDMA), or single carrier frequency division multiple access (SC-FDMA), or any a combination of such techniques. Some of these techniques have been adopted in or relate to standardized wireless communication protocols by organizations such as Third Generation Partnership Project (3GPP), Third Generation Partnership Project 2 (3GPP2) and IEEE. These wireless standards include Ultra Mobile Broadband (UMB), Universal Mobile Telecommunications System (UMTS), Long Term Evolution (LTE), LTE-Advanced (LTE-A), LTE-A Pro, New Radio (NR), IEEE 802.11 (WiFi), and IEEE 802.16 (WiMAX), among others.
The terms “5G” or “5G communications system” may refer to systems that operate according to standardized protocols developed or discussed after, for example, LTE Releases 13 or 14 or WiMAX 802.16e-2005 by their respective sponsoring organizations. The features described herein may be employed in systems configured according to other generations of wireless communication systems, including those configured according to the standards described above.
The various illustrative blocks and modules described in connection with the disclosure herein may be implemented or performed with a general-purpose processor, a digital signal processor (DSP), an application-specific integrated circuit (ASIC), a field-programmable gate array (FPGA), or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices (e.g., a combination of a DSP and a microprocessor, multiple microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration).
The functions described herein may be implemented in hardware, software executed by a processor, firmware, or any combination thereof. If implemented in software executed by a processor, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media includes both non-transitory computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A non-transitory storage medium may be any available medium that can be accessed by a general purpose or special purpose computer. By way of example, and not limitation, non-transitory computer-readable media can comprise RAM, ROM, electrically erasable programmable read only memory (EEPROM), or optical disk storage, magnetic disk storage or other magnetic storage devices, or any other non-transitory medium that can be used to carry or store desired program code means in the form of instructions or data structures and that can be accessed by a general-purpose or special-purpose computer, or a general-purpose or special-purpose processor.
Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Combinations of the above are also included within the scope of computer-readable media.
Other examples and implementations are within the scope of the disclosure and appended claims. For example, due to the nature of software, functions described above can be implemented using software executed by a processor, hardware, firmware, hardwiring, or combinations of any of these. Features implementing functions may also be physically located at various positions, including being distributed such that portions of functions are implemented at different physical locations.
Certain details are set forth herein to provide a sufficient understanding of embodiments of the present disclosure. However, it will be clear to one skilled in the art that embodiments of the present disclosure may be practiced without various of these particular details. In some instances, well-known wireless communication components, circuits, control signals, timing protocols, computing system components, telecommunication components, and software operations have not been shown in detail in order to avoid unnecessarily obscuring the described embodiments of the present disclosure.
Also, as used herein, including in the claims, “or” as used in a list of items (for example, a list of items prefaced by a phrase such as “at least one of” or “one or more of”) indicates an inclusive list such that, for example, a list of at least one of A, B, or C means A or B or C or AB or AC or BC or ABC (i.e., A and B and C). Also, as used herein, the phrase “based on” shall not be construed as a reference to a closed set of conditions. For example, an exemplary step that is described as “based on condition A” may be based on both a condition A and a condition B without departing from the scope of the present disclosure. In other words, as used herein, the phrase “based on” shall be construed in the same manner as the phrase “based at least in part on.”
From the foregoing it will be appreciated that, although specific examples have been described herein for purposes of illustration, various modifications may be made while remaining with the scope of the claimed technology. The description herein is provided to enable a person skilled in the art to make or use the disclosure. Various modifications to the disclosure will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other variations without departing from the scope of the disclosure. Thus, the disclosure is not limited to the examples and designs described herein, but is to be accorded the broadest scope consistent with the principles and novel features disclosed herein.
Claims
1. A method comprising:
- receiving a plurality of calibration signals;
- generating a second-order set for a plurality of ordered sets based at least in part on multiplying each calibration signal of the plurality with another calibration signal of the plurality of calibration signals; and
- generating a third-order set of the plurality of ordered sets based at least in part on multiplying each calibration signal of the plurality with two other calibration signals of the plurality of calibration signals;
- allocating the second-order set to a second-order neuron of a neuron calculator and the third-order set to a third-order neuron of the neuron calculator; and
- processing signals at the neuron calculator with the second-ordered neuron and the third-ordered neuron.
2. The method of claim 1, wherein generating the second-order set comprises:
- multiplying a first calibration signal of the plurality with the first calibration signal to generate a first multiplicative processing result of the second-order set;
- multiplying the first calibration signal with a second calibration signal of the plurality to generate a second multiplicative processing result of the second-order set;
- multiplying the first calibration signal with a third calibration signal of the plurality to generate a third multiplicative processing result of the second-order set;
- multiplying the second calibration signal with the first calibration signal to generate a fourth multiplicative processing result of the second-order set;
- multiplying the second calibration signal with the second calibration signal to generate a fifth multiplicative processing result of the second-order set;
- multiplying the second calibration signal with the third calibration signal to generate a sixth multiplicative processing result of the second-order set;
- multiplying the third calibration signal with the first calibration signal to generate a seventh multiplicative processing result of the second-order set;
- multiplying the third calibration signal with the second calibration signal to generate an eighth multiplicative processing result of the second-order set; and
- multiplying the third calibration signal with the third calibration signal to generate a ninth multiplicative processing result of the second-order set.
3. The method of claim 1, further comprising:
- generating a plurality of connection weights for a corresponding connection between each of the respective ordered neurons of the neuron calculator and a respective output of a plurality of outputs of the neuron calculator.
4. The method of claim 3, further comprising:
- combining, at each output of the neuron calculator, at least the second-order set or the third-order set with at least a portion of the connection weights to generate compensated calibration signals.
5. The method of claim 3, wherein generating the plurality of connection weights for the corresponding connection comprises:
- randomly selecting the plurality of connection weights;
- reducing an error of compensated calibrations signals based on a summation of the plurality of connection weights and at least the second ordered set or the third-order set.
6. The method of claim 3, further comprising
- providing, to the neuron calculator, a first radio frequency (RF) signal associated with a first frequency and a second RF signal associated with a second frequency, wherein the first RF signal received at a first antenna of a plurality of antennas and the second RF signal received at a second antenna of the plurality of antennas;
- mixing the first and second RF signals in accordance with the second-order set or the third-order set and the plurality of connection weights to generate a plurality of output signals, the plurality of output signals being representative of the first and second RF signals compensated for an error in processing the first and second RF signals.
7. The method of claim 6, wherein a quantity of the plurality of antennas corresponds to a number of antennas of a MIMO antenna array.
8. The method of claim 1, further comprising:
- for a first-order set, identifying each calibration signal of the respective calibration signals as a signal of the first-order set.
9. An apparatus comprising:
- a plurality of antennas;
- a first transceiver configured to receive a first radio frequency (RF) signal from a first antenna of the plurality of antennas;
- a second transceiver configured to receive a second radio frequency (RF) signal from a second antenna of the plurality of antennas;
- a neuron calculator coupled to the first transceiver and the second transceiver, the neuron calculator configured to mix the first and second RF signals with a plurality of ordered sets and a plurality of connection weights to generate a plurality of output signals, wherein the neuron calculator comprises a plurality of ordered neurons, each ordered neuron configured to mix a respective ordered set and the connection weights with the first and second RF signals.
10. The apparatus of claim 9, wherein the neuron calculator is further configured to calculate the plurality of ordered sets based on multiplying a calibration signal of a plurality of calibration signals with a portion of the calibration signals of the plurality of calibration signals, wherein the portion of the calibration signals comprises a number of the plurality of calibration signals corresponding to an order of the respective ordered set of the plurality of ordered sets.
11. The apparatus of claim 9, further comprising:
- a memory configured to store the plurality of ordered sets and the plurality of connection weights.
12. The apparatus of claim 9, wherein the neuron calculator is further configured to mix, at a first-order neuron and a second-order neuron of the plurality of ordered neurons, the respective ordered set with the first and second RF signals, wherein the first-order neuron calculator comprises a first ordered set of the plurality of ordered sets, and wherein the second-order neuron calculator comprises a second ordered set of the plurality of ordered sets.
13. The apparatus of claim 12, wherein the neuron calculator is further configured to mix the plurality of connection weights with outputs of the first-order neuron and the second-order neuron to generate the plurality of output signals.
14. The apparatus of claim 9, wherein the first transceiver comprises:
- an analog-to-digital (ADC) converter configured to convert the first RF signal to digital symbols;
- a digital down converter (DDC) configured to mix the digital symbols using a carrier signal to generate down-converted symbols; and
- a fast Fourier transform (FFT) logic configured to convert the down-converted symbols into symbols indicative of the first RF signal.
15. The apparatus device of claim 14, wherein the first transceiver further comprises:
- a channel estimator configured to estimate an error of a communications channel across which the symbols indicative of the first RF signal were transmitted, the channel estimator further configured to provide the symbols indicative of the first RF signal to the neuron calculator.
16. The apparatus device of claim 15, wherein the channel estimator is further configured to receive compensated symbols indicative of the first RF signal based on the neuron calculator adjusting the symbols indicative of the first RF signal with at least a portion of the plurality of ordered sets.
17. An apparatus comprising:
- a first receiver configured to process a first radio frequency (RF) signal;
- a second receiver configured to process a second RF signal; and
- a neuron calculator coupled to the first receiver and the second receiver and configured to receive a first input signal based on the first RF signal and a second input signal based on the second RF signal, the neuron calculator configured to calculate a plurality of ordered sets and a plurality of connection weights to generate a plurality of output signals, wherein the neuron calculator is configured to allocate each ordered set of the plurality of ordered sets to a kth-order neuron of a plurality of ordered neurons of the neuron calculator.
18. The apparatus of claim 17, wherein the neuron calculator is configured to perform a channel estimation of the first and second input signals and to provide the plurality of output signals as compensated symbols.
19. An apparatus comprising:
- a first receiver configured to process a first radio frequency (RF) signal;
- a second receiver configured to process a second RF signal; and
- a neuron calculator coupled to the first receiver and the second receiver and configured to receive a first input signal based on the first RF signal and a second input signal based on the second RF signal, the neuron calculator configured to calculate a plurality of ordered sets and a plurality of connection weights to generate a plurality of output signals, wherein each ordered set of the plurality of ordered sets comprises product values of at least the first and second input signals, wherein the at least first and second input signals are selected from a set of k-combinations including repetition, wherein k represents a number of input signals to select.
20. (canceled)
Type: Application
Filed: Aug 29, 2018
Publication Date: Mar 5, 2020
Applicant: MICRON TECHNOLOGY, INC. (BOISE, ID)
Inventors: Fa-Long Luo (SAN JOSE, CA), JAIME CUMMINS (BAINBRIDGE ISLAND, WA), TAMARA SCHMITZ (SCOTTS VALLEY, CA), JEREMY CHRITZ (SEATTLE, WA)
Application Number: 16/115,866