The present invention relates to a transceiver interface and a method of operation and optimization of the transceiver interface. In particular, the invention relates to minimizing interference associated with a Low Voltage Differential Signaling (LVDS) interface by adaptively iterating critical LVDS parameters ζk synchronous with concurrent transceiver system operations to optimize the LVDS interface performance.
As the radio frequency (RF) transceiver-to-digital interface clock speeds approach multiples of hundreds or even multiples of thousands of megahertz (MHz), the risk of spurious and/or other correlated noise interference coupling into low noise RF analog circuits from digital signal sources often becomes pronounced. Accordingly, a digital interface configuration may be optimized for a particular protocol while mitigating ancillary spurious coupling or other undesired responses by adjusting certain interface parameters, which may include, but are not limited to clock speed, data rate, signal drive level, clock slew rate, termination impedance, or ringing characteristics.
Furthermore, with the advent of software definable radio (SDR) wireless devices, support of wideband and broadband protocols having channel spacing from 1 MHz to 50 MHz is desired, coupled with being operationally compatible with narrow band mission critical protocols having channel spacing from 6.25 kHz up to 1 MHz. A digital interface configuration suitable for broad band applications should support high data rates (e.g. multiple tens of MHz), which may impose significant power consumption penalties and generate unacceptable noise coupling mechanisms for narrower channel spacing protocols such as Association of Public-Safety Communications Officials (APCO) and legacy FM distributed communication systems. However, a digital interface optimized for lower data rates associated with narrow band protocols may not afford sufficient bandwidth and buffer drive capability to operate at high data rates satisfactory for broadband applications. These divergent protocol requirements precipitate the need for a scalable, minimum noise, high speed digital interface between RF devices incorporating low noise analog systems, such as a RF modem, and host or digital signal processor (DSP) controllers.
In addition, a scalable digital interface may facilitate optimized partitioning of integrated circuits (ICs) for lowest cost. Bulk Complementary Metal Oxide Semiconductor (CMOS) IC processes are a low cost technology for digital logic structures used in processor or digital state machines. However, the CMOS transistor noise characteristics typically prevent their inclusion in low noise analog circuit design. While traditional Bipolar-CMOS (BiCMOS) processes typically incorporate transistor structures ideally suited for small signal low noise analog circuit designs, the BiCMOS cost per unit area is usually significantly higher than the cost per unit area of CMOS. Therefore, an adaptively scalable digital interface strategy may facilitate IC partitioning between RF and DSP integrated circuits such that each integrated circuit can have the most appropriate and least costly technology.
It is therefore desirable to have a scalable, high speed transceiver-to-digital interface that can be adaptively optimized for protocol specific requirements while simultaneously mitigating spurious interference and noise coupling into sensitive, small signal, low noise analog systems.
The accompanying figures, where like reference numerals refer to identical or functionally similar elements throughout the separate views, together with the detailed description below, are incorporated in and form part of the specification, and serve to further illustrate embodiments of concepts, and explain various principles and advantages of those embodiments.
The apparatus and method components have been represented where appropriate by conventional symbols in the drawings, showing only those specific details that are pertinent to understanding the embodiments shown so as not to obscure the disclosure with details that will be readily apparent to those of ordinary skill in the art having the benefit of the description herein. Other elements, such as those known to one of skill in the art, may thus be present.
By using a low voltage differential signaling (LVDS) interface with adjustable parameters, and by coupling the LVDS interface to a dynamic sequencer, an adaptive LVDS interface is formed which may be optimized to operate with a reduced amount of spurious interference and correlated noise emissions while still maintaining interface signal fidelity.
The first interface 40 connects the first peripheral device 20 with the second peripheral device 50 and allows for digital signals 41 to be transmitted from the first peripheral device 20 to the second peripheral device 50. The digital signals 41 transmitted on first interface 40 originate from transmitter 22 and are received by receiver 58, wherein the physical connection between a transmit-receive pair, 22, 58 respectively, may be a wired interface. The transmit-receive pair 22, 58 connected by first interface 40 form of a unidirectional adaptive transceiver interface which allows for electronic signals to pass in one direction from the first peripheral device 20 to the second peripheral device 50. The physical interface comprising first interface 40 permits low voltage differential signals (LVDS) to pass through and is therefore referred to as a LVDS interface. A second transmit-receiver pair (not shown in
By further extension, any number of transmit-receive pairs connected by a low voltage differential signal connections can be incorporated into the first and second peripheral devices 20, 50 to interconnect any desired number of additional peripherals, each being able to communicate digital signals from a transmitter to a receiver as supported by the particular interface configuration. A plurality of transmit-receive pairs can be combined to form any number of particular wired interfaces including, but not limited to: USB, RS-422, RS-485, Ethernet, PCI Express, IEEE-488, Serial Port Interface (SPI), or other serial data interfaces, and parallel data interfaces.
The adaptive transceiver interface 10 includes a transmit-receive pair composed of transmitter 22 and receiver 58, a sweep trigger 24, a dynamic sequencer 26 conjoined to transmitter 22, a dynamic sequencer 56 conjoined to receiver 58, and an analyzer 30. As illustrated in
Transmitter 22 transmits signals 41 which are received by the second peripheral device 50 via the first interface 40. While transmitter 22 preferably transmits differential signals via the first interface 40, it may transmit other types of signals, including single-ended signals. Differential signals communicate information electrically by means of using two complementary signals sent on two separate wires. Complementary signals are defined as two signals that are transmitted over two separate wires where the phase of the second signal is offset by 180 degrees from the phase of the first signal. Transmitter 22 may transmit signals 41 at a variety of voltages. Preferably, the transmitter 22 transmits a low voltage differential signal at peak offset voltage levels of about five volts or less. In one embodiment, the transmitter 22 is an LVDS transmitter which transmits differential signals at low voltage for communicating formatted sampled data. The formatted sample data preferably contains a binary representation of the formatted sampled data, a sample clock signal, and a sample framing designator.
The operational characteristic of transmitter 22 may be set by parameters ζT, which in turn may be adjusted to support various protocols and interface fidelity requirements while optimizing transmitter 22 for reduced spurious responses and correlated noise coupling. Parameters ζT that may be adjusted by the dynamic sequencer 26 may include, but are not limited to, slew rates, sample rate, clock rates, duty cycles, differential phase offset, common mode voltage offsets, termination impedance, current or voltage mode operation, and differential or single-ended amplitude levels.
Receiver 58 incorporated in the second peripheral device 50 receives signals 41 which are transmitted by transmitter 22 via the first interface 40. Preferably, receiver 58 receives differential signals via the first interface 40; however the receiver 58 may receive other types of signals, including single-ended signals. Receiver 58 may receive signals 41 at a variety of voltages. Preferably, the receiver 58 receives low voltage differential signals which are transmitted at peak offset voltage levels of about five volts or less. In one embodiment, the receiver 58 is a LVDS receiver which receives differential signals at low voltage for communicating formatted sampled data. The formatted sample data preferably contains a binary representation of the formatted sampled data, a sample clock signal, and a sample framing designator.
The operational characteristic of receiver 58 may be set by parameters ζR, which in turn may be adjusted to support various protocols and interface fidelity requirements while optimizing the receiver 58 for reduced spurious responses and correlated noise coupling. Parameters ζR that may be adjusted by dynamic sequencer 56 may include, but are not limited to, slew rates, sample rate, clock rates, duty cycles, differential phase offset, common mode voltage offsets, termination impedance, current or voltage mode operation, and differential or single-ended amplitude levels.
Transmitter 22 and receiver 58 form a transmit-receive pair 22, 58 that communicate along first interface 40. Transmit-receive pair 22, 58, together with conjoined dynamic sequencers 26 and 56, sweep trigger 24 and interfaces 40 and 42 form the adaptive transceiver interface 10. The adaptive transceiver interface 10, in conjunction with analyzer 30, may be utilized to optimize the first interface 40 for optimum signal fidelity by minimizing spurious responses or other correlated noise interference mechanisms. First interface 40 may be optimized by synchronously adjusting transmit parameters ζT and receive parameters ζR sequentially through a plurality of predetermined transmitter and receiver values αT and αR respectively, while measuring the correlated noise responses at analyzer 30 for each value combination αT and αR. From the interference results, a final transmit parameter value αTf and receive parameter value αRf may be determined The optimization sequence for first interface 40 may be initiated synchronous with concurrent systems that are incorporated into the first peripheral device 20 and/or second peripheral device 50 that may not be directly affiliated with the adaptive transceiver interface during normal operation.
Sweep trigger 24 initiates the optimization sequence of transmit-receive pair 22, 58 through trigger signal 28. Sweep trigger 24 also controls the period of time τ the transmitter 22 is to transmit when transmit parameter ζT is configured for value αT, and sets the period of time τ that receiver 58 is to receive when receive parameter ζR is configured for value αR. The sweep trigger 24 is in communication with the dynamic sequencer 26 which is conjoined to transmitter 22. Because dynamic sequencer 26 communicates through a second interface 42 to dynamic sequencer 56 located in second peripheral device 50, the sweep trigger 24 may also trigger dynamic sequencer 56 synchronous with triggering dynamic sequencer 26. Second interface 42 communicates a synchronizing signal (e.g., sync signal) to dynamic sequencer 56 during the optimization sequence for transmit-receive pair 22, 58 such that that the adjustment of transmit parameters ζT and receive parameters ζR of transmit-receive pair 22, 58 are performed in tandem. The transmit-receive pair 22, 58 subsequently operate with adjusted parameters ζT and ζR for a predetermined period of time τ, at which point the sweep trigger 24 generates a subsequent trigger event on trigger signal 28. The sweep trigger 24 may be preloaded with associated timing sequences that determine the time period during which each transmit parameters ζT and receive parameters ζR are set to their respective values αT and αR. Sweep trigger 24 is preferably located in first peripheral device 20, however, sweep trigger 24 may also be located in second peripheral device 50.
In one embodiment, for each successive trigger event generated by sweep trigger 24, dynamic sequencer 26 iterates to the next value αT associated with transmit parameter ζT, or may change which parameter ζT is being adjusted, and communicates the updated transmit parameter value αT to transmitter 22. Synchronous with iterating to the next value, dynamic sequencer 26 may trigger tandem iteration in dynamic sequencer 56 located in second peripheral device 50 by signaling through second interface 42. Upon receiving the sync signal from dynamic sequencer 26 over second interface 42, dynamic sequencer 56 iterates to the next value αR for receive parameter ζR, or may change which parameter ζR is being adjusted, and communicates the updated receiver parameter value αR to receiver 58 through link 59. In this way, transmit-receive pair 22, 58 may be synchronously configured to sequentially update various combinations of transit and receive parameters ζT and ζR with values αT and αR respectively, until sweep trigger 24 has sequenced through a predefined number of timing periods.
In one embodiment, a predefined timing sequence can be preloaded or preprogrammed into sweep trigger 24 and may be autonomously iterated by sweep trigger 24 once initiated. In another embodiment, the sweep trigger 24 is prompted to generate the trigger pulses through signal 44 generated by the analyzer 30, at which point the sweep trigger 24 generates the appropriated trigger signal 28. Whether the trigger sequence is controlled by analyzer 30 or by a preloaded sequence embedded in the sweep trigger 24, the trigger signal 28 induces dynamic sequencers 26 and 56 to update their respective transmit parameter ζT and receive parameter ζR which in turn configures the appropriate transmit-receive block. The optimization sequence continues until all predefined parameter combinations have been iterated, at which time the transmit-receive pair 22, 58 may be configured to a default operating state until final optimized values αTf and αRf for transmit parameter ζT and receive parameter ζR respectively are determined by DSP 296, as shown in
Referring to
In one embodiment, as illustrated in
Overall synchronization of a transmit-receive pair's tandem adjustment of transmit and receive parameters ζT and ζR are maintained through a synchronization signal transmitted over the second interface 42 wherein dynamic sequencer 26 and dynamic sequencer 56 synchronously adjust their respective parameters. The optimization sequence of any number of transmit-receive pairs composing the adaptive transceiver interface between first and second peripheral devices 20, 50 may occur during a training sequence of a concurrent transceiver system, a training-to-algorithm alignment, and/or during normal transmit and receive operations performed by the transmitter 22 and the receiver 58, respectively. The dynamic sequencers 26 and 56 are preferably inactive during nominal operating conditions of the first and second peripheral devices 20, 50, and are therefore not normally a source of interference or other correlated noise coupling between the first peripheral device 20 and the second peripheral device 50.
A concurrent transceiver system is a system which may be included in transceiver 32 that may operate in parallel with the adaptive transceiver interface 10. Concurrent transceiver systems encompass all fundamental portions of a transceiver 32 including, Local Oscillator (LO) frequency generation, RF receiver and transmitter filter and gain configuration, transmitter modulation systems, and Application Specific Integrated Circuits (ASIC) dedicated to specific processing tasks within the transceiver. Optimization sequencing of a transmit-receive pair 22, 58 may be correlated to the operational status of a given concurrent transceiver system including, but not limited to, synchronization to transceiver Direct Current Offset Correction (DCOC) sequencing, Automatic Gain Control (AGC) state machine status, or RF transmitter modulation training sequencing.
Analyzer 30 is in communication with transmit-receive pair 22, 58 and may also be in communication with sweep trigger 24. Analyzer 30 analyzes the signal fidelity of the signals 41 at receiver 58 as the dynamic sequencer pair 26, 56 iterates the respective transmit-receive pair 22, 58 through the tandem adjustment in transmit and receive parameters ζT and ζR during optimization sequencing of adaptive transceiver interface 10. Analyzer 30 is preferably any device which can perform calculations, and includes things such as a microprocessor, a Field Programmable Gate Array, and a Digital Signal Processor (DSP). A DSP is a specialized microprocessor tailored for real time algorithmic processing of data or real time generation of digital waveforms for radio system applications. The DSP is intended to remove ongoing radio data processing requirements from any host processor so as to improve overall system efficiencies. Preferably, the analyzer 30 correlates protocol requirements to the targeted transmit and receive parameters ζT and ζR when their respective value sequences αT and αR are preloaded into the dynamic sequencer pair 26, 56 in preparation for optimization sequencing. The analyzer 30 may select which interference metric or plurality of interference metrics that may be best suited for a given protocol to quantify any interference emissions or susceptibility the adaptive transceiver interface 10 may exhibit during optimization sequencing. In addition, the analyzer 30 may measure the interference level, using an interference metric, during a transmit-receive pair's tandem adjustment in transmit and receive parameters ζT and ζR and correlate the interference measurements in order to provide optimum final values αTf and αRf for the parameters ζT and ζR so as to produce minimum interference within the adaptive transceiver interface 10.
In one embodiment, analyzer 30 analyzes a plurality of signals 41 received at receiver 58, each signal associated with a different combination of transmit and receive parameters ζT and ζR having associated values αT and αR in order to determine which transmit-receive parameter-value combination provide the best signal fidelity for signals 41. The pertinent information contained in signals 41 and received at receiver 58 is communicated to analyzer 30 through digital connection 45. The transmit-receive parameter-value combination that produces the best signal fidelity while meeting minimum protocol requirements will correspond to the adaptive transceiver interface configuration with the least amount of spurious response or degradations due to correlated noise. Correlated noise is any undesired signal that is associated with, or correlated to, a particular signal source internal or external to the adaptive transceiver interface that produces degraded fidelity of the information being communicated through the transmit-receive pair 22, 58.
Upon analyzing signals transmitted via digital connection 45, the analyzer 30 generates an interference metric based on the quality of the signal 41 for each parameter combination ζT and ζR. The interference metric provides a quantitative measurement of the quality of signal 41 indicative of possible spurious responses or other noise coupling between the transmit-receive pair 22, 58, transceiver 32 or other analog or digital subsystems that effect the fidelity of the information contained in signal 41. The interference metric may include, but is not limited to, calculated parameters such as the signal-to-noise (SNR) ratio derived from a frequency domain Fast Fourier Transform (FFT) of signal 41, the bit-error-rate (BER) of the time domain digital bits communicated in signal 41, the signal quality estimate (SQE) as indicated by a Received Signal Strength Indication (RSSI) for a particular signal 41, the power spectral density (PSD) of desired frequency components contained within signal 41, or a quality of service (QoS) as indicated by services supported for a particular signal 41. Upon generating an interference metric for each combination of transmit and receiver parameters, analyzer 30 correlates the plurality of interference metrics with the parameter settings to determine which combination of values for parameters ζT and ζR will optimize transmit-receive pair 22, 58 for minimum spurious response or correlated noise interference.
In one embodiment, analyzer 30 analyzes a plurality of signals over digital connection 43 that originate from transceiver 32 and are to be transmitted by transmitter 22, each signal associated with a different combination of transmit and receive parameters ζr and ζR having associated values αT and αR The pertinent information that is to be transmitted by transmitter 22 is communicated to analyzer 30 through digital connection 43 and is analyzed to determine which transmit-receive parameter-value combination provides minimum noise coupling between transceiver 32 and first interface 40. The transmit-receive parameter-value combination that produces the minimum correlated noise coupling while meeting minimum protocol requirements will correspond to the adaptive transceiver interface configuration exhibiting the highest signal fidelity for digital signal 41. Upon generating an interference metric for each combination of transmit and receiver parameters, analyzer 30 correlates the plurality of interference metrics to the parameter settings to determine which combination of values for parameters ζT and ζR will optimize transmit-receive pair 22, 58 for minimum spurious response or correlated noise interference.
In one embodiment, the optimization sequence for transmit-receive pair 22, 58 is performed in a controlled environment that is conducive to minimizing a particular spurious response that may be degrading the information contained in the digital signals 41 intrinsic to interface 40 interconnecting a first and second peripheral devices 20, 50. A spurious response is defined as a degradation of the desired, on-channel received signal resulting from an increase in undesired signals within the receive channel caused by any source external or internal to transceiver 32. Since information embedded in the digital signal 41 can be degraded either in the absence of external signal (i.e., self-quieting spurs), or may require the presence of a second signal to generate undesired noise coupling (e.g., undesired off-channel spurious responses), the optimization strategy used to reduce the amount of spurious interference and/or correlated noise coupling should accommodate multiple interference environments.
For this reason, in one embodiment, optimization of the adaptive transceiver interface 10 is performed concurrent with internal baseband training routines such as Direct Current Offset Correction (DCOC) sequences associated with Direct Conversion Receivers (DCR) or Direct Conversion Transmitters (DCT) and transmit modulation path training for DCT systems incorporating Cartesian feedback. In one embodiment, optimization of the adaptive transceiver interface 10 is executed when AGC state machine 234 is set to maximum attenuation so as to minimize all received signals, on or off channel, following DCR baseband DCOC training in order to identify possible self-quieting sources intrinsic to the wireless transceiver 32 or adaptive transceiver interface 10. A self-quieting spurious response is defined as a degradation of the desired, on-channel received signal resulting from an increase in undesired signals within the receive channel caused by either direct coupling of digital signals 41 into the receive channel or when digital signals 41 is combined with other signals internally generated by transceiver 32.
In one embodiment, optimization of the adaptive transceiver interface 10 is executed when receiving off-channel signals that may induce undesired off-channel spurious responses or intermodulation (IM) interference. An off-channel spurious response is defined as a degradation of the desired, on-channel received signal due to an increase in undesired signal levels within the receive channel that results when an off-channel RF signal being received at the input of transceiver 32 is combined with the digital signals 41 intrinsic to the first interface 40. The undesired spurious response or IM interference will only be present when the undesired off-channel signal is present and adaptive optimization of transmit-receive pair 22, 58 may augment legacy IM or spurious response mitigation strategies.
The minimum required functionality of the adaptive transceiver interface 10 is dictated by protocol constraints. For example, the minimum data rate for first interface 40 must support the data rate specified by the targeted protocol. The minimum data rate for first interface 40 may necessitate a minimum clock speed for the digital signals 41 being communicated over first interface 40, which intern may set a minimum slew rate. In addition, a minimum voltage drive level may be necessary to maintain robust fidelity of digital signals 41 at a given clock speed for the stray capacitance intrinsic to real world circuits and interconnections of first interface 40. Therefore all interference metric characterizations by analyzer 30 are measured in conjunction with maintaining minimum fidelity of digital signals 41 as may be necessary to support the targeted protocol. However, added flexibility beyond these minimum requirements may be exploited to further minimize any noise coupling present between the low noise, analog RF stages and the digital processing stages while optimizing the overall system for the lowest current drain or power consumption.
The ability to quantify interference, as well as modify characteristics of signal 41 such as signal timing, transition ringing and signal shaping provides a way to optimize current drain and data transmission reliability while keeping interference with other peripheral components in proximity to the adaptive transceiver interface 10 at a minimum. The adaptive transceiver interface 10 may modify its power consumption by changing slew rate and termination impedance to meet minimum protocol requirements while simultaneously employing “soft decision decoding” of binary information communicated over first interface 40 so as to optimize link performance for electromagnetic interference (EMI) and power drain.
If a plurality of digital transmit-receive pairs 22, 58 are deployed to form a plurality of adaptive first interfaces 40, and are oriented to form bi-directional digital links from a common peripheral device 20 to a plurality of other peripheral devices, then the adaptive transceiver interface 10 may adaptively optimize only one interface (first interface 40) and assume that the optimized transmit and receive parameters ζT and ζR can be extrapolated to the other transmit-receive pairs. The goals of adaptive transceiver interface 10 include mitigation of inter-chip transmission errors while not interfering with the wireless transceiver 32 of the first peripheral device 20. This is accomplished by optimizing the transmit and receive parameters ζT and ζR that configure the various digital interfaces within the adaptive transceiver interface 10 dynamically, adaptively and in real time.
One embodiment of optimizing the adaptive transceiver interface may employ a self generated training tone of known frequency composition that may then received by an on-board receiver embedded in transceiver 32, subsequently sampled by the analog-to-digital converter (ADC) and then demodulated and digitally processed to evaluate spurious responses and correlated noise coupling. The tandem iteration of transmit and receive parameters ζT and ζR is accomplished as described in previous sections of this specification; however, the interference metric is derived by analyzing the self-generated training tone.
Transceiver 220 and the associated wireless peripherals (receiver front end 210 and transmitter final output 260) are interconnected forming systems for receive, transmit and frequency synthesis operations. The receiver subsystem comprises receiver front end 210, and various components of the transceiver 220 including mixer 222, tunable filter 224, ADC 226 and any post processing stages following the ADC prior to the first terminal 270, AGC state machine 234 and DCOC sequence manger 236. The transmit system shown in
The wireless transceiver 220 is connected to receiver front end 210 and transmitter final output 260, both of which may be connected to antenna 205 through antenna switch 206. The antenna 205 is connected to an antenna switch 206 which routes received RF signals from the antenna 205 to the receiver front end 210 in receive mode, and routes a continuous RF signal from the transmitter final output 260 to the antenna 205 in transmit mode. The antenna switch 206 may be a generic representation of a switch, or a duplexer, or any other mechanism by which RF signals are routed to- and -from appropriate radio system blocks to facilitate proper radio system operation.
The receiver front end 210 contains at least one preselector filter 212 and at least one low noise amplifier (LNA) 214. The preselector filter 212 is a RF filter that attenuates undesired out-of-band received RF signals that may be present at the antenna 205 when the transceiver is in receive mode. While
Output signal 215 from the receiver front end 210 is routed to the receiver subsystem incorporated in transceiver 220. The input receive stage for transceiver 220 is mixer 222 which mixes output signal 215 with a local oscillator (LO) signal 228 so as to translate the received RF signal to an intermediate frequency (IF) signal 223. In one embodiment, the IF signal may be a quadrature signal composed of an in-phase signal and a quadrature phase signal wherein the quadrature phase signal is phase offset from the in-phase signal by 90 degrees. In one embodiment, the LO signal and the desired on-channel received RF signal may be approximately equal, thereby designating the receiver configuration as a Direct Conversion Receiver (DCR) and the receiver mixer 222 as a down mixer. For DCR receivers, the desired IF signal 223 may range from baseband DC to tens of kHz.
The IF signal 223 is subsequently filtered at tunable IF filter 224 which functions to attenuate undesired, off-channel signals that may be present in IF signal 223. The IF bandwidth (IFBW) for the tunable IF filter 224 is variable, and may be programmed to a desired IFBW by the host controller via the SPI interface 209 to accommodate various modulation bandwidths as necessitated by various wireless protocols. In one embodiment, where the receiver is a DCR, the tunable IF filter 224 is a Low Pass filter (LPF) configuration for both the in-phase and quadrature-phase signal paths. While
The output signal from tunable IF filter 224 is subsequently sampled by ADC 226. The ADC 226 samples the filtered IF signal at a predefined sample rate as necessitated to meet specific protocol requirements, thereby converting the analog received IF signal into a sampled representation of the IF signal. Preferably, ADC 226 samples the analog IF signal at a rate that must meet or exceed the minimum threshold as defined by Nyquist Sampling Criteria in order to preserve all pertinent received information within the sampled received IF signal. The ADC sampled IF signal may be processed by other post-processing digital stages (not shown in
AGC state machine 234 may operate to adjust the gain of various gain stages that may be distributed throughout receiver front end 210 and the receiver subsystem in transceiver 220. AGC state machine 234 processes the sampled IF signal output from ADC 226 and compares the sampled IF signal level to predefined thresholds to generate a control voltage 216 for controlling at least one gain stage within the receiver system. Any number of nodes within the receiver portion of the transceiver 220 may be used to generate an input signal into the AGC state machine 234. The gain stages that may be controlled by the AGC state machine 234 may include, but are not limited to, the LNA 214 and/or IF gain stages (not shown) which may have their respective gain settings adjusted based on the received signal level and the threshold configuration of AGC state machine 234. In this way, AGC state machine 234, LNA 214, and ADC 226 providing the sampled received IF signal input to AGC state machine 234 illustrate a closed loop AGC system in
The DCOC sequence manager 236 is a control system that sequences through various training processes within the receiver portion of transceiver 220 so as to minimize distortion of the received IF signal attributed to baseband DC offset errors. DCOC training sequences controlled by sequence manager 236 mitigate degraded receiver performance caused by external parametric variations in the receiver operating environment and limitations in real world circuit designs associated with process, component tolerance and layout configurations. Generally, the DCOC sequence manager 236 may control DCOC training sequences in both analog circuits, defined as baseband circuits between the mixer 222 and ADC 226, and in digital processing stages, as defined in post-processing digital blocks following ADC 226 that algorithmically minimize DCOC errors in the sampled received IF signal. When initiating DCOC training, DCOC sequence manager 236 may interactively interrupt normal operations of AGC state machine 234 and may control various baseband operating states and post ADC digital processing states not shown in
The transceiver 220 also includes a frequency synthesis subsystem that generates LO signal 228. The frequency synthesis subsystem may include a VCO 230, a Frequency Generation Unit (FGU) 232 and filter 238 to form a Phase Locked Loop (PLL) whereby the LO signal 228 is generated. The FGU is also known as a frequency synthesizer and functions by comparing the VCO output frequency to a reference frequency source (not shown in
The transceiver 220 may also include a transmit subsystem. The transmit subsystem translates digital information from digital controller 290 into a modulated RF signal that is transmitted at antenna 205. While
The transmit baseband I/Q modulation path, also referred to as the forward I/Q modulation portion of the transmit subsystem, comprises Digital-to-Analog Converter (DAC) 246, tunable filter 244 and summer block 242. DAC 246 is a complex DAC pair for converting digital information from digital controller 290 into modulation signals, and preferably baseband I/Q transmit modulation signals. The baseband I/Q signals are defined as in-phase and quadrature-phase signal representations of Cartesian coordinates within a complex I/Q modulation system. Tunable filter 244 represents a simplified filtering strategy for complex I/Q signal pairs, wherein undesired quantization noise created by DAC 246 and non-linearities intrinsic in the circuit implementation are attenuated. Generally, the transmit baseband filter 244 may be tunable to support various transmit modulation signal bandwidth requirements, and may incorporate a Low Pass Filter topology. Summer block 242 combines a pre-distortion signal originating from the Cartesian feedback path with the I/Q baseband signal pair so as to so as to mitigate Power Amplifier (PA) non-linearity distortion effects. In one embodiment, there may be a separate transmit summer for each of quadrature modulator that may be incorporated in the transmit portion of the transceiver 220.
The transmit modulator 240, which may also be referred to as a transmitter up-mixer, combines a transmit baseband modulation signal with a LO signal to produced a modulated continuous transmit RF signal. The continuous transmit RF signal from the transmit modulator 240 may be further amplified by a transmitter final output 260 prior to being sent to the antenna switch 206 for routing to the antenna 205. In one embodiment, the transmit modulator 240 may include a quadrature mixer topology composed of an in-phase modulator and a quadrature phase modulator wherein the output signal of the quadrature phase modulator is phase offset from the in-phase modulator output signal by 90 degrees.
The Cartesian Feedback (CFB) portion of the transmit subsystem comprises coupler 264, buffer 250, delay block 252 and down mixer 254. Coupler 264 couples a potion of the modulated continuous transmit RF signal at the output of transmit PA 262 into buffer 250 thereby providing an feedback signal 266 into the CFB subsystem. Buffer 250 provides a buffering stage to isolate CFB components in transceiver 220 from external stray effects. The buffered feedback signal is down-mixed at feedback down mixer 254. For transmit portions of transceivers which incorporate a CFB compensation capability, the transmit feedback down mixer 254 functions to convert the buffered feedback signal to complex baseband error signals. The complex baseband error signals may then be combined with baseband modulation path complex IQ signals at summer 242 in order to compensate distortion effects in the modulated continuous transmit RF signal that may be induced by PA 262 non-linearities. Delay block 252 functions to delay an internally generated transmit LO signal by a set phase offset to compensate for associated delays induced in a RF signal path from the output of modulator 240 thru PA 262, coupler 264, to the output of feedback buffer 250.
Transceiver 220 also includes a transmit training sequencer 248 which iterates the transmit baseband I/Q modulation path and the CFB path of the transceiver 220 through a training sequence. By comparing the transmit CFB signal to a known training signal during a transmit training sequence, an error signal can be determined that is then used to pre-distort the baseband I/Q modulation signal so as to minimize the error. Once the pre-distortion signal for the forward I/Q modulation path is known, the pre-distortion can be digitally applied to the transmit DAC 246 and/or subsequent I/Q modulation path stages so as to mitigate non-linear distortion products that may have degraded the signal fidelity of the modulated continuous transmit RF signal. Transmit training sequencer 248 and the associated transmit modulation path compensation stages are an example of a concurrent transceiver system that can be integrated into the optimization sequencing of adaptive transceiver interface 100.
The transmitter final output 260 is a general transmitter subsystem containing the final PA 262, a coupler 264, and any other device of the transmit portion as may be necessary to properly control and route a continuous transmit RF signal. The transmit final PA 262 is the final amplifier stage in the transmit portion of the transceiver 220 and is used to increase the power of the transmit RF signal prior to radiating RF energy at the antenna 205. Coupler 264 functions to couple RF energy from the transmitter RF signal path. The coupled RF energy may be subsequently used to compensate transmit distortion effects or for power output level control (not shown).
The transceiver 220 includes a first interface terminal 270. The first interface terminal 270, in conjunction with second interface terminal 280 incorporated into digital controller 290 are connected to each other via a plurality of interface connections 204, 207, 208, and 209 to form the adaptive transceiver interface 100. The adaptive transceiver interface 100 contains a dynamic sequencer sync interface 209 and associated trigger processors and at least one, or all of the following: a receive interface 204 for communicating the sampled received data, a transmit interface 207 for communicating the transmit modulation sampled data, an SPI configuration interface 208. The adaptive transceiver interface 100 illustrated in
Adaptive transceiver interface 100 incorporates transmit-receive pair 272, 282 connected by receive interface 204. Transmitter 272 may be a high speed LVDS transmitter for transmitting information through LVDS receive interface 204. Receiver 282 may be a high speed LVDS receiver for receiving information from LVDS receive interface 204. The transmit-receive pair 272, 282 may communicate binary representation of sampled received data, sample clock signal and sample framing designators. The transmit-receive pair 272, 282 is adjustable as may be necessary to support various protocol requirements. In this manner, transceiver 220 can communicate formatted sampled receive data to digital controller 290. Transmit-receiver pair 272, 282 of
Adaptive transceiver interface 100 also incorporates transmit-receive pair 288, 278 connected by transmit interface 207. Transmitter 288 may be a high speed LVDS transmitter for transmitting information through LVDS transmit interface 207. Receiver 278 may be a high speed LVDS receiver for receiving information from LVDS transmit interface 207. The transmit-receive pair 288, 278 may communicate binary representation of transmit modulation data, sample clock signal and sample framing designators. The transmit-receive pair 288, 278 is adjustable as may be necessary to support various protocol requirements. In this manner, digital controller 290 can communicate formatted sampled transmit modulation information to transceiver 220. Transmit-receiver pair 288, 278 of
The LVDS sweep trigger 273 is a sweep trigger which controls the timing of the optimization sequence for adaptive transceiver interface 100 as described in
The LVDS dynamic sequencer pair 274, 284 is a low voltage differential signaling dynamic sequencer pair which sequences the parameters of a targeted transmit-receive pair within the adaptive transceiver interface 100. Dynamic sequencer pair 274, 284 is connected together through sync interface 209. Sync interface 209 may be any interface appropriate for maintaining synchronization between dynamic sequencer pair 274, 284, including, but not limited to, LVDS serial interface, single wire trigger interface, Small Computer System Interface (SCSI), or fiber channel. Dynamic sequencer pair 274, 284 of
The SPI interface 208 between digital controller 290 and transceiver 220 may be a bi-directional LVDS serial port interface (SPI) incorporating both transmit and receive low voltage differential signaling. The LVDS SPI transceiver pair 276, 286 communicate over SPI interface 208 and is the interface through which a host processor 294 of the digital controller 290 will configure the receive portion and/or transmit portion of the transceiver 220 for nominal operation. The SPI LVDS block 286 may be connected to a plurality of integrated circuits (IC) including the transceiver 220, and may incorporate a plurality of connections to each IC including, but not limited to a data connection, a clock connection and a “chip enable” (CE) connection. The CE connection is unique to each IC to which the SPI LVDS block 286 is connected.
Digital controller 290 is a generic controller system used to enable a variety of digital applications including command and control of wireless modem interfaces, machine access control (MAC), layer accessory drivers, and advanced digital signal processor (DSP) data manipulation. In one embodiment, digital controller 290 includes a host processor 294, a digital signal processor (DSP) 296, memory and associated memory management (not shown), and an interface system including SPI LVDS block 286 to communicate to other peripherals both inside and outside the digital controller system.
Preferably, digital controller 290 is in communication with a reference clock 292 which provides a time base from which all control and command processes are sequenced. Preferably, a plurality of reference clocks 292 are connected to different peripherals, such as integrated circuits, in radio system 200 including both the digital controller 290 and the transceiver 220, each reference clock 292 having a different operating frequency. However, the operating frequency of a given peripheral's reference clock 292 sets that peripheral's processing speed and thereby determines its maximum response time.
Host processor 294 is preferably a generic micro computer that controls the configuration of the radio system 200 and is the system that process higher level software routines that facilitate the user interface and accessory capabilities. In one embodiment, host processor 294 may trigger sweep trigger 273 to initiate an optimization sequence of adaptive transceiver interface 100 via SPI interface 208 while simultaneously initiating interference correlator block 295 to begin interference measurements.
DSP 296 is a specialized microprocessor tailored for real time algorithmic processing of data or real time generation of digital waveforms for radio system applications. The DSP 296 is intended to remove ongoing radio data processing requirements from the host processor 294 to improve overall system efficiencies. Preferably, DSP 296 correlates the protocol requirements to the sweep parameters that are preload into the dynamic sequencer pair 274, 284 within protocol select processing stage 291. The DSP 296 also targets which interference metric or plurality of metrics that may be used to characterize system interference during optimization sequencing of the adaptive transceiver interface 100 in the interference metric block 293. DSP 296 measures the interference level using the interference metric during optimization sequencing of various LVDS transmit and receive parameters ζT and ζR and correlates the measurements to final LVDS settings αTf and αRf for minimum interference in the interference correlator block 295. DSP 296 of
Moving to step 325, the interference metric or plurality of metrics to be measured when iterating the optimization sequence is selected with associated thresholds defining what are the acceptable levels of spurious response or correlated noise interference based upon the specific protocol loaded in step 315. Then, at step 330, the receive interface 204 is enabled, allowing for signals to be transmitted from the transmitter 272 to the receiver 282. Preferably, the receive interface 204 is a synchronous serial interface (SSI). Then at step 335, the DSP 296 processes samples of the signals communicated from the transceiver 220 through the transmit-receive pair 272, 282 comprising a portion of the adaptive transceiver interface 100. In a decision step 336, the DSP 296 then determines whether a previously scheduled receiver training sequence is to be executed or if an on-channel received signal is detected in the sampled received signal communicated from transceiver 220 to digital controller 290 through receive interface 204. If either condition is detected this would differentiate whether or not the radio system 200 is being trained or not, or whether or not the radio system 200 is receiving a desired on-channel signal necessitating an appropriate response as required by the particular radio application. In one embodiment, some radio receiver training processes cannot occur simultaneous with normal operations; however, either condition is compatible with conducting an optimization sequence of the adaptive transceiver interface 100. If an on-channel received signal is detected or if a receiver training process is to be executed, then the method 300 proceeds to step 340 from step 336, otherwise, the method 300 moves to step 337.
In a decision step 337, the DSP 296 determines whether a previously scheduled transmitter training process is to occur or if the radio system 200 push-to-talk (PTT) has been initiated requiring a modulation signal or other transmit information to be communicated over the transmit interface 207. If either condition is detected, this would indicate whether or not the radio system 200 is being trained or not, or whether or not the radio system 200 is communicating modulation or other transmitter signals over the transmit interface 207 necessitating an appropriate response as required by the particular radio application. In one embodiment, some radio transmitter training processes cannot occur simultaneous with normal operations, however, either condition is compatible conducting an optimization sequence of the adaptive transceiver interface 100. If a transmitter training signal or a transmit modulation signal is to be communicated over the transmit interface 207, then the method 300 moves to step 339, otherwise, the method 300 moves back to step 335.
At step 340, protocol specific processing of receive samples is enabled by the DSP 296, which processes the sampled received signals communicated from transceiver 220 over transmit-receive pair 272, 282 through interface 204. Next, at step 342, the sample received signals are demodulated to extract the desired information that is being communicated to the radio system 200 over the wireless channel. After a sufficient number of samples have been received to allow an accurate calculation of the interference metric, a receive interference metric is generated from the sample received signals communicated over transceiver 220 at step 344. At step 346, the DSP 296 determines if the interference metric previously calculated at step 344 is greater than the protocol specific threshold previously selected at step 325. If the DSP 296 calculates an interference metric that indicates an acceptable interference level, method 300 moves from step 346 to step 348 to determine if the on-channel signal is still present or whether the training process is completed. If the receive signal is still present or if the receive training process is ongoing, method 300 proceeds back to step 342 to resume demodulation of the sampled received signal. Steps 342, 344, 346, and 348 form a loop that is continuously cycled as long as the interference metric indicates acceptable interference levels while a receive process (on-channel signal or training) is ongoing. Training processes that may be conducted while cycling through steps 342, 344, 346 and 348, may include but not limited to a sequence manager 236 controlled DCOC sequence as shown in
At step 339, the transmit interface 207 is enabled by the DSP 296. Next, at step 341, a transmit baseband and RF path is enabled to allow the signals that are communicated over transmit interface 207 to be processed and modulated onto the RF signal. After a protocol specific analysis period, a transmit interference metric is generated at step 343 for the signals sent over the transmit interface 207.
At step 347, DSP 296 determines if the interference metric previously calculated at step 343 is greater than the protocol specific threshold previously set at step 325. If the interference metric indicates an acceptable interference level, method 300 moves from step 347 to step 349 to determine if the transmit modulated signal is still required or whether the transmit training process is completed. If the transmit modulation is still required (e.g., the PTT is still activated) or if the transmit training process is ongoing, method 300 proceeds back to step 341 to resume transmit operations.
Steps 341, 343, 347, and 349 form a loop that is continuously cycled as long as the interference metric indicates acceptable interference levels while a transmit process (PTT active or transmit training) is ongoing. Transmit training processes that may be conducted while cycling through steps 341, 343, 347 and 349, may include but not limited to, training sequencer 248 optimizing CFB and baseband modulation path as shown in
Once the transmit process is finished and the interference metric continues to indicate acceptable interference levels at step 347, step 349 branches back to step 330 to enable the receive interface 204 in preparation to resume normal receive channel monitoring. However, if the interference metric generated at step 347 for the signals sent over the transmit interface 207 indicates interference levels that exceeds acceptable levels, method 300 moves from step 347 to step 351 shown in
At step 351, at least one transmit and/or receive parameter ζT and/or ζR is selected for adjustment based on the protocol loaded in step 315 for the LVDS receive interface 204 and/or transmit interface 207 and/or SPI interface 208 used for communication between the transceiver 220 and the digital controller 290. The parameter ζT and/or ζR selected at step 351, and their associated range of values, may be selected based on a number of factors, including the type of interference detected (e.g.: self-quieter vs. off-channel spurious response), prioritization of the parameter and its associate values relative to predefined ranking, sensitivity analysis and gradient scaling of parameter values from past training results, and meeting minimum protocol requirements for the digital signals at the interface being optimized. The parameter values αT and αR are preloaded into dynamic sequencer pair 274, 284 as well as the associated training periods τ into sweep trigger 273 for each parameter iteration.
Moving to step 353, the LVDS optimization sequence is triggered and a series of interference metrics are generated as the optimization sequence varies values α of the selected parameter ζk. Preferably one interference metric is generated for each value α used for the selected parameter ζk. Note that α is a generic representation for αT and αR, and ζk is a generic representation for ζT and ζR.
At step 355, each interference metric and its associated transmit and/or receive values α are correlated to determine the optimum value α to produce minimum interference. This may include interpolating between two parameter values α1 and α2 to produce a third value α3 that is predicted to achieve minimum interference without actually being included in the iteration comprising the optimization sequence.
At step 357, the final value αf for the targeted parameter ζk that produces an interference metric indicating the least amount of interference is loaded into the adaptive transceiver interface 100 for use when transmitting and receiving the protocol loaded in step 315. Following optimization of the transmit-receive parameters ζk at 357, the DSP 296 and/or host processor 294 may adjust the interference metric correlator to include different parameter values or even new parameters not incorporated into the previous optimization sequence at step 359. After the correlator has been adjusted from the previous optimization sequence, the sample counter pre-trigger is set at 364 so that after a predetermined number of transmit or receive samples have been communicated over receive interface 204 or transmit interface 207, method 300 will resume normal operation.
Completion of step 364 marks the termination of the optimization sequence for the adaptive transceiver interface 100. If the optimization sequence is initiated during transmit operations as designated by node A, method 300 re-enters the transmit operations at block 341 from node C in
Moving to step 420, a plurality of time periods τN delineating when digital signals are to be transmitted and received over receive interface 104 or transmit interface 107 are preloaded into sweep trigger 173. The individual time periods τ are associated with particular combinations of parameters ζk and discrete values α. For example, if there are two parameters ζ1, ζ2, and each parameter ζ1, ζ2 has two values α selected, such as a nominal (NOM) value and an estimated (EST) “optimum” value, as shown in
At step 430 a training period τ corresponding to the particular LVDS training run is activated at sweep trigger 173, where each iteration of an optimization sequence starts at time t equal to zero. At step 435, the value αk for a targeted parameter ζk corresponding to the current training run is loaded into the appropriate LVDS interface from the dynamic sequencer pair 174, 184. After the value αk has been loaded into the LVDS interface, the sample counter in the DSP 196 is initialized at step 440, so that the value of the sample count (Scount) is set to zero. In an alternative embodiment, the sample counter may be located within sweep trigger 173 whereby the current training period time t may be measured, where upon τ expires a new trigger pulse is generated to start a subsequent training run. For both embodiments, the sample counter measures time t relative to the number of transmit-receive samples that have been communicated over a particular adaptive transceiver interface 104 or 107 with respect to the sample rate. For example, if the symbol transmission across an adaptive transceiver interface 100 is twenty thousand samples-per-second (20 ksps), then a 5 millisecond (5 mS) iteration interval will correspond to τ equal to 100 samples. By the end of step 440, all LVDS parameter values αk and associated timing interval τk that comprise a particular LVDS training run have been preloaded into the targeted transmit-receive pair and sweep trigger in preparation of measuring the interference metric for the values αk.
At step 445 the sweep trigger 173 generates a trigger pulse to start of the current LVDS training run. Step 445 corresponds to time T=0 of the current LVDS training run for parameter ζk having values αk loaded into a transmit-receive pair of adaptive transceiver interface 100
Moving to step 450, the sample counter is incremented for each sample communicated across the LVDS interface that is being optimized. Decision step 455 determines whether or not the value of the sample count has reached the appropriated number samples N corresponding to τ. If not, the method 400 proceeds from step 455 back to step 450, incrementing the sample count until the number of samples corresponding to period τk have been communicated. Once N samples corresponding to τk have been transmitted and received, the period of time τ has run out for the current LVDS training run, and the method moves from step 455 to step 460. Note that parallel processing of the received samples may be accomplished by DSP 196 while method 400 is iterating between steps 450 and 455. The parallel processing of the received samples by DSP 196 may be in support of normal communication functions of radio system 90 and may not otherwise be related to the LVDS training run; therefore the parallel processes of DSP 196 are not shown in
At step 460, the DSP 196 processes all the received samples corresponding to τk and at step 465 generates an interference metric for the recently completed LVDS training run. At decision step 470, a determination is made as to whether all LVDS training runs included in a particular optimization sequence have been completed. If the training run index LVDSRUN is less than N, where N is the number of training runs included in the current optimization sequence, method 400 moves from step 470 to step 457, increases the value of LVDSRUN by one, and then moves to step 430 to commence loading the next series of timing intervals and parameter values α.
In an alternative embodiment, DSP processing of the received samples from a previous LVDS training run designated as LVDSRUN=L, where L is the training run index being processed at block 460 and 465, may proceed in parallel with the commencement of the next LVDS training run designated by LVDSRUN=L+1. To support this alternative embodiment, processing of received samples by DSP 196 at steps 460 and 465 for LVDSRUN=L is time shared with processing of the current received samples for normal radio functions and to facilitate parallel sequencing of the next LVDS training run at steps 430 through 455 for LVDSRUN=L+1. If the training run index LVDSRUN for the current optimization sequence is not less than N, then method 400 moves from decision step 470 to step 475. Training run index LVDSRUN may correspond to the first column in Table 1, Table 2, and Table 3, labeled “LVDS training run.”
At step 475, DSP 196 correlates the plurality of previously calculated interference metrics to the associated training values ζk(αN) to identify which combination of transmit-receive parameter values αT, αR produce minimum interference. Some embodiments may include step 480 if more than one set of transmit-receive values αT, αR produce interference levels at acceptable levels. In this case, to minimize the probability of setting a parameter value at the “edge” of an acceptable value range, the DSP 196 may interpolate between two values α1 and α2 employing any number of numerical interpolating techniques as is known in the art. Interpolating techniques may include, but is not limited to, linear averaging (e.g., {α1+α2}/2) or weighted scaling based on the amount of interference produced for each value (e.g., [1−j]* α1+α2*j, where j<1 and j becomes closer to zero the closer to the interference metric limit a given α produces).
Following step 475 and 480, method 400 proceeds to step 485 where the adaptive transceiver interface 100 is updated with the final, optimized transmit-receive parameter values αTf, αRf. After the final values have been updated into the LVDS interface, method 400 may perform one final transmit-receive communication over the interface and make one final interference measurement at step 490 so as to verify the recently completed optimization sequencing results. Following step 490, method 400 terminates by resuming normal LVDS interface operations. Step 495 of method 400 may correspond to step 330 or 335 of method 300.
Referring to Table 1, a full factorial combination table for optimization of two parameters ζk (ζ1, ζ2, where k=2) for adaptive transceiver interface 100 is depicted, in accordance with one embodiment. Each parameters ζk has two values αN (where N=2, a nominal value NOM and an estimated “optimized” value EST). As a result, four possible combination of parameters ζk and discrete values αN exist, and four training runs having four periods of time τ will be performed in optimizing parameters ζk for adaptive transceiver interface 100.
Referring to Table 2, a full factorial combination table for optimization of four parameters ζk (ζ1, ζ2, ζ3, ζ4, where k=4) for adaptive transceiver interface 100 is depicted, in accordance with one embodiment. Each parameters ζk has two values αN (where N=2, a nominal value NOM and an estimated value EST). As a result, sixteen possible combination of parameters ζk and discrete values αN exist, and sixteen training runs having sixteen periods of time τ will be performed in optimizing parameters ζk for adaptive transceiver interface 100.
When simultaneously optimizing k different LVDS interface parameters ζk, each parameter ζk having M values then the number of LVDS training run corresponding to a full factorial sequence will be Mk runs.
Referring to Table 3, a full factorial combination table for optimization of two parameters ζk (ζ1, ζ2, where k=2) each having three possible values αN (where M=3 corresponding to a first value A, a second value B, and a third value C) for adaptive transceiver interface 100. As a result, nine possible combination of parameters ζk and discrete values αN exist, and nine training runs having nine periods of time τ will be performed in optimizing parameters ζk for adaptive transceiver interface 100.
In various embodiments, the disclosed methods may be implemented as a computer program product for use with a computer system. Such implementations may include a series of computer instructions fixed either on a tangible medium, such as a computer readable medium (e.g., a diskette, CD-ROM, ROM, or fixed disk) or transmittable to a computer system, via a modem or other interface device, such as a communications adapter connected to a network over a medium. The medium may be either a tangible medium (e.g., optical or analog communications lines) or a medium implemented with wireless techniques (e.g., microwave, infrared or other transmission techniques). The series of computer instructions embodies all or part of the functionality previously described herein with respect to the system. Those skilled in the art should appreciate that such computer instructions can be written in a number of programming languages for use with many computer architectures or operating systems. Furthermore, such instructions may be stored in any memory device, such as semiconductor, magnetic, optical or other memory devices, and may be transmitted using any communications technology, such as optical, infrared, microwave, or other transmission technologies. It is expected that such a computer program product may be distributed as a removable medium with accompanying printed or electronic documentation (e.g., shrink wrapped software), preloaded with a computer system (e.g., on system ROM or fixed disk), or distributed from a server or electronic bulletin board over the network (e.g., the Internet or World Wide Web). Of course, some embodiments of the invention may be implemented as a combination of both software (e.g., a computer program product) and hardware. Still other embodiments of the invention are implemented as entirely hardware, or entirely software (e.g., a computer program product).
While various embodiments of the invention have been described, it will be apparent to those of ordinary skill in the art that other embodiments and implementations are possible within the scope of the invention. Accordingly, the invention is not to be restricted except in light of the attached claims and their equivalents.
It will be understood that the terms and expressions used herein have the ordinary meaning as is accorded to such terms and expressions with respect to their corresponding respective areas of inquiry and study except where specific meanings have otherwise been set forth herein. Relational terms such as first and second and the like may be used solely to distinguish one entity or action from another without necessarily requiring or implying any actual such relationship or order between such entities or actions. The terms “comprises,” “comprising,” or any other variation thereof, are intended to cover a non-exclusive inclusion, such that a process, method, article, or apparatus that comprises a list of elements does not include only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. An element proceeded by “a” or “an” does not, without further constraints, preclude the existence of additional identical elements in the process, method, article, or apparatus that comprises the element.
Those skilled in the art will recognize that a wide variety of modifications, alterations, and combinations can be made with respect to the above described embodiments without departing from the spirit and scope of the invention and that such modifications, alterations, and combinations are to be viewed as being within the scope of the inventive concept. Thus, the specification and figures are to be regarded in an illustrative rather than a restrictive sense, and all such modifications are intended to be included within the scope of present invention. The benefits, advantages, solutions to problems, and any element(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or essential features or elements of any or all the claims issuing from this application. The invention is defined solely by any claims issuing from this application and all equivalents of those issued claims.
The Abstract of the Disclosure is provided to allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in various embodiments for the purpose of streamlining the disclosure.