The application generally relates to method, system and apparatus for camera tracking of asynchronous variable pulse position modulation light (VPPM). More specific embodiments of the disclosure relate to method and apparatus to track and compensate frequency offset between the symbol rate of incoming light and the frame rate of the camera which receives the symbols contained in the incoming light.
Wireless communication is the transfer of information between two or more points that are not connected by an electrical conductor. Optical communication is a form of wireless communication that uses light to carry information. Optical wireless communication is a form of optical communication in which unguided visible, infrared (IR), or ultraviolet (UV) light is used to carry communication signals.
A composite optical waveform consists of two parts. A lower frequency time varying amplitude component that, when subsampled by a low frame rate camera, results in alias induced flicker or blinking (also known as “twinkle”) which is useful for quickly identifying which light sources are modulated with data. And a high data rate portion using variable pulse position modulation (VPPM) that varies the duty cycle of the pulses to generate the lower frequency time varying amplitude component while simultaneously sending higher rate data via pulse position modulation (PPM). This high rate VPPM waveform is Nyquist sampled by a high frame rate camera, using region-of-interest subsampling, to extract the high rate data. This higher rate VPPM data transmission from an LED light source is asynchronous with respect to the receiving camera. That is, the data rate timing clocks are close in frequency but they are not frequency synchronous. As is typical of asynchronous communication of this type (e.g., RS-232), the beginning of a data packet is distinguished by a start frame delimiter (SFD) which is used to establish quasi-stationary timing for the duration of the relatively short data packet.
To identify modulated lights, the duty cycle is periodically changed in the waveform to induce an AM envelope at a frequency higher than the response of the human eye. The waveform is then sampled by a camera which produces an alias frequency that produces noticeable blinking. The desired camera frame rate in relationship to the modulation bit rate is only approximately correct. SFD is conventionally used to synchronize the camera and the composite waveform. However, there is a frequency offset between the camera and composite waveform timing clocks in long packet transmission even after synchronization through SFD. There is a need for a detection algorithm with timing clock offset tracking.
These and other embodiments of the disclosure will be discussed with reference to the following exemplary and non-limiting illustrations, in which like elements are numbered similarly, and where:
Various embodiments are generally directed to an apparatus, system, and method for improved optical wireless communication techniques. Various embodiments enable more efficient optical wireless communication between signal transmitters, such as light emitting diodes, and a signal receiver, such as a camera, by using a composite waveform. Various embodiments enable a first component of the composite waveform to indicate a second component of the composite waveform is modulated with data. Various embodiments enable the first component of the composite waveform to be decoded by a signal receiver operating at a low frequency (e.g. 1-1,000 Hz). Various embodiments enable the second component of the composite waveform to be decoded by a signal receiver operating at a high frequency (e.g. 1-1,000 kHz).
In some embodiments, the first component of the composite waveform may include a lower frequency time varying amplitude component to enable quick identification of signal sources modulated with data. In various embodiments, the second component of the composite waveform may include a higher frequency pulse position modulated component to enable high rate data communication. In various such embodiments, the higher frequency pulse position modulated component may use variable pulse position modulation (VPPM) to vary the duty cycle of pulses to generate the lower frequency time varying amplitude component.
Various embodiments of the protocols described herein may be used in conjunction with random access networks, networks that operate in unlicensed bands, and/or networks that operate in accordance with one or more standards, such as the Institute of Electrical and Electronics Engineers (IEEE) 802.11, 802.15, and/or 802.11ay standards.
Various embodiments may comprise one or more elements. An element may comprise any structure arranged to perform certain operations. Each element may be implemented as hardware, software, or any combination thereof, as desired for a given set of design parameters or performance constraints. Although an embodiment may be described with a limited number of elements in a certain topology by way of example, the embodiment may include more or less elements in alternate topologies as desired for a given implementation. It is worthy to note that any reference to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrases “in one embodiment,” “in some embodiments,” and “in various embodiments” in various places in the specification are not necessarily all referring to the same embodiment.
When processing a complete frame of pixels, a camera generally has a relatively low frame rate (e.g., ˜30 frames per second (FPS)) which sets the Nyquist sampling rate for the camera operating in this mode. The low frame rate can decode the first component of the composite waveform. However, by processing a subset of the pixels, called the region-of-interest (ROI), the camera may significantly increase the frame rate such that the resulting Nyquist sampling rate is high enough to be able to individually decode the second component of the composite waveform. In some embodiments, the second component includes high rate data pulses.
Referring to
When the high rate pulse duty cycle is varied in a period manner, at a sufficiently low frequency, then the first camera may still only detect the high rate pulses, while the second camera may detect that the light has a time variant intensity at the lower frequency.
With reference to
When a pulse occurs in the first half of a bit time (e.g. light ON), then that may be encoded as one logic level. When the pulse occurs in the second half of a bit time then that may be encoded as the other logic level. In some embodiments, the pulse width may not be relevant when compared to the pulse position within the bit time.
Accordingly, in some embodiments, a camera with a sufficiently long exposure time (or human eye) may see a light that is flickering at a lower frequency. Yet a camera with a sufficiently short exposure time, along with knowledge of bit timing, may ascertain the position of the pulse within the bit time slot. In various embodiments, the optical wireless communication system may then make a bit decision therefrom.
With reference to
For example, using a 30-fps camera, with a sufficiently short exposure setting that can detect the 105 Hz flicker, the 105 Hz is aliased to 15 Hz by the following equation:
105−3*30=105−90=15 Hertz
The techniques described herein may enable a full-frame camera to record a short video of a scene and then ascertain which lights are modulated by observing which lights appear to be blinking. ROI sub-sampling may then be performed on the blinking lights.
The apparent blinking, as seen by the camera, may either be due to a blinking frequency that is slower than the camera frame rate, or it may be due to sub-sampling aliasing produced by the camera of a light that blinks faster than the human flicker perception frequency.
The composite waveform, as described above, includes two parts. In some embodiments, the first part may include a lower frequency time varying amplitude component that, when subsampled by a low frame rate camera, results in alias induced flicker (i.e. blinking, twinkle). In various embodiments, the flicker may be useful for quickly identifying which light sources are modulated with data. In some embodiments, the second part may include a high data rate portion using VPPM that may vary the duty cycle of the pulses to generate the lower frequency time varying amplitude component while simultaneously sending high rate data via PPM. This high rate VPPM waveform may be Nyquist sampled by a high frame rate camera, using ROI subsampling, to extract the high rate data. This higher rate VPPM data transmission from a light source, such as an LED, may be asynchronous with respect to the receiving camera; that is, the data rate timing clocks may be close in frequency, but they are not frequency synchronous.
The beginning of a data packet may be distinguished by a start frame delimiter (SFD), which may be used to establish quasi-stationary timing for the duration of the relatively short data packet. As described herein, the SFD may satisfy the demands of the composite waveform by initiating the proper decoding of the higher rate VPPM data packets while supporting the lower frequency amplitude envelope twinkle.
The pulses shown in
In certain disclosed embodiments, the PPM signal processing circuitry determines which sample phases to keep and which sample phases to discard. This may be accomplished with the information provided by the SFD which is described further in reference to
The following is a description of the maximum run length for a normal VPPM symbol according to one embodiment of the disclosure.
Camera integration time induced ISI will now be described in more detail. Cameras include a pixel integration time, perhaps more commonly called the exposure time, which may be the time duration that the pixel is exposed to the light source. When the camera exposure time overlaps a logic level transition then the result is ISI. This makes the ‘bit pattern’ have sloped edges instead of sharp transitions as shown in
As stated, frequency offset develops between the camera's sampling rate (fc) and the modulated LED timing clock (i.e., symbol rate (fs)). For example, the camera may take four samples per symbol. Ideally, the relationship of Equation (1) holds as follows:
4fc=fs (1)
In this context, a positive frequency offset is a condition where 4fc≥fs and negative frequency offset is a condition where 4fc≤fs. Frequency offset is particularly pronounced during transmission of long packets after the SFD. In certain embodiments, the disclosure provides detection algorithms and apparatus with timing clock offset tracking capabilities using the composite waveform. In one implementation, the sampling patterns generated by a composite waveform during one bit period are studied. Different composite waveform duty cycles and timing clock offsets may be used to generate a set of possible sample patterns. The sampling patterns of the composite waveform may be compared with the generated set of sample patterns to make tracking decisions.
Conversely, negative frequency offset occurs when camera sampling rate is faster than the bit rate or bit symbol rate. To address negative frequency offset, the camera sampling rate should be compensated differently than in the positive frequency offset. Conditions in which the bit rate and the symbol rate remain consonant are neutral and the camera sampling need not be changed.
In certain embodiments, the disclosure addresses positive or negative frequency offset by considering the most recent four sampling bits as well as the immediately preceding bit to render a current bit decision. The samples associated with any one bit are received S−3, S−2, S−1 and S0, where S0 is the newest camera sample and S−3 is the oldest camera sample. For example, if the most current samples (S−3, S−2, S−1 and S0) are 0001, the previous bit was 0 and the current bit is 1, then the camera and symbol rate are tracking and no further action is necessary (i.e., there is no cameral offset). This condition is shown in the second row of Table A.
On the other hand, if the four current samples (S−3, S−2, S−1 and S0) are 0010, the previous bit was 1 and the current bit is 1 (as show in the third row of Table B), then camera tracking action is slow. Here, the current last sample is kept and three new samples are taken during the next symbol. This makes a total of 4 samples altogether which are then used according to the hard decisions and tracking tables of
As another example, if the four current samples (S−3, S−2, S−1 and S0) are 0100, the previous bit was 0 and the current bit is 0 (as show in the fifth row of Table A), then camera tracking action is fast. Here, five new samples are taken during the next symbol and the first is discarded.
In Tables A and B, the rows that are grey-filled are considered illegal symbol samples and no action may be taken. Also, row 7 of Table A and row 10 of Table B show conditions where two possible outcomes may result depending on the state of current bit selection. As will be shown in greater detail below, an algorithm may be devised to consider all possible sampling and tracking decisions.
Tables A and B of
It should be noted that in the disclosed embodiments, the amplitudes have been normalized to have values of 0 or 1. In certain implementations, the sample values may be extracted from an eight-bit analog to digital converter (ADC) and may have corresponding amplitude values. To obtain the normalized levels 0 and 1, the received samples are thresholded. In an exemplary embodiment, the threshold value can be ascertained using the SFD histogram. The sample combinations may be affected by the (N+1)th bit and both cases bitN+1=0 and bitN+1=1 have to be considered.
As discussed in relation to
Referring again to
At step 2425, SFD synchronization begins as described above. That is, once the ROI and SFD are identified, synchronization begins. In certain embodiments, synchronization is implemented using the prior bit sampling as shown in step 2430 and as discussed in relation to Tables A and B of
Step 2445-2450, 2455 and 2460 illustrate frequency offset tracking. Specifically, at step 2455 a decision is made as to whether there is negative, positive or neutral frequency offset. If negative frequency (i.e., video frame rate is too slow) is detected, at step 2450, the most current last sample is kept and three new samples are loaded. The process then reverts to step 2430 where the new samples are analyzed and a new bit decision is made.
If frequency offset is positive (i.e., video frame rate is too fast), the subsequent five samples are loaded and the last four samples are also kept. The process reverts to step 2430 where the newly loaded samples and the four older samples are used to make a bit decision.
If no frequency offset is detected, at step 2455, no action is taken and four new samples are loaded. The process reverts to step 2430 where the four new samples are used to analyze frequency offset and to make a new bit decision.
It should be noted that the embodiment of claim 25 is exemplary and non-limiting in nature. For brevity, shift register 2500 is shown as a four-bit shift register. In certain implementations of the disclosed principles, after a tracking decision (e.g., fast tracking, per
Comparators 2520, 2521, 2522 and 2523 are aligned to receive output from each of the corresponding shift registers SM, SM-1, SM-2 and SM-3, as shown. Each comparator compares the input with a so-called hard decision threshold. For example, each of the incoming bits (SM, SM-1, SM-2 and SM-3) are compared with the hard decision samples (S0, SN−1, SN−2 and SN−3) as shown in the first columns of Tables A and B of
Controller 2530 may comprise a processor circuitry and a memory circuitry. Controller 2530 may be implemented in hardware, software or a combination of hardware and software. In one embodiment, controller 2530 implements decision logic and tacking algorithm consistent with the disclosed embodiments. In addition to the current bit decision, controller 2530 also receives prior bit decision input (Z−1) and a subsequent bit (BN−1).
In certain embodiments, controller 2530 uses these inputs to determine a bit decision for bitN. In addition, controller 2530 may identify frequency offset by implementing a tracking algorithm as disclosed herein. For example, controller 2530 may apply the exemplary algorithm disclosed in relation to
The human eye has a cutoff frequency near 100 Hz, whereas the camera's cutoff response can significantly exceed 100 Hz depending upon the exposure speed setting (integration time). Under intense light conditions the exposure can be set to well under 1 ms and still result in satisfactory performance. As suspected, the techniques described herein require a relatively intense light source (i.e., high Signal-to-Noise Ratio).
As used in this application, the terms “system” and “component” and “module” are intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution, examples of which are provided by the exemplary computing architecture 3200. For example, a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers. Further, components may be communicatively coupled to each other by various types of communications media to coordinate operations. The coordination may involve the uni-directional or bi-directional exchange of information. For instance, the components may communicate information in the form of signals communicated over the communications media. The information can be implemented as signals allocated to various signal lines. In such allocations, each message is a signal. Further embodiments, however, may alternatively employ data messages. Such data messages may be sent across various connections. Exemplary connections include parallel interfaces, serial interfaces, and bus interfaces.
The computing architecture 3200 includes various common computing elements, such as one or more processors, multi-core processors, co-processors, memory units, chipsets, controllers, peripherals, interfaces, oscillators, timing devices, video cards, audio cards, multimedia input/output (I/O) components, power supplies, and so forth. The embodiments, however, are not limited to implementation by the computing architecture 3200.
As shown in
The system bus 3208 provides an interface for system components including, but not limited to, the system memory 3206 to the processing unit 3204. The system bus 3208 can be any of several types of bus structure that may further interconnect to a memory bus (with or without a memory controller), a peripheral bus, and a local bus using any of a variety of commercially available bus architectures. Interface adapters may connect to the system bus 3208 via a slot architecture. Example slot architectures may include without limitation Accelerated Graphics Port (AGP), Card Bus, (Extended) Industry Standard Architecture ((E)ISA), Micro Channel Architecture (MCA), NuBus, Peripheral Component Interconnect (Extended) (PCI(X)), PCI Express, Personal Computer Memory Card International Association (PCMCIA), and the like.
The system memory 3206 may include various types of computer-readable storage media in the form of one or more higher speed memory units, such as read-only memory (ROM), random-access memory (RAM), dynamic RAM (DRAM), Double-Data-Rate DRAM (DDRAM), synchronous DRAM (SDRAM), static RAM (SRAM), programmable ROM (PROM), erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), flash memory, polymer memory such as ferroelectric polymer memory, ovonic memory, phase change or ferroelectric memory, silicon-oxide-nitride-oxide-silicon (SONOS) memory, magnetic or optical cards, an array of devices such as Redundant Array of Independent Disks (RAID) drives, solid state memory devices (e.g., USB memory, solid state drives (SSD) and any other type of storage media suitable for storing information. In the illustrated embodiment shown in
The computer 3202 may include various types of computer-readable storage media in the form of one or more lower speed memory units, including an internal (or external) hard disk drive (HDD) 3214, a magnetic floppy disk drive (FDD) 3216 to read from or write to a removable magnetic disk 3218, and an optical disk drive 3220 to read from or write to a removable optical disk 3222 (e.g., a CD-ROM or DVD). The HDD 3214, FDD 3216 and optical disk drive 3220 can be connected to the system bus 3208 by a HDD interface 3224, an FDD interface 3226 and an optical drive interface 3228, respectively. The HDD interface 3224 for external drive implementations can include at least one or both of Universal Serial Bus (USB) and IEEE 1394 interface technologies.
The drives and associated computer-readable media provide volatile and/or nonvolatile storage of data, data structures, computer-executable instructions, and so forth. For example, a number of program modules can be stored in the drives and memory units 3210, 3212, including an operating system 3230, one or more application programs 3232, other program modules 3234, and program data 3236. In one embodiment, the one or more application programs 3232, other program modules 3234, and program data 3236 can include, for example, the various applications and/or components of the optical wireless communication system.
A user can enter commands and information into the computer 3202 through one or more wire/wireless input devices, for example, a keyboard 3238 and a pointing device, such as a mouse 3240. Other input devices may include microphones, infra-red (IR) remote controls, radio-frequency (RF) remote controls, game pads, stylus pens, card readers, dongles, finger print readers, gloves, graphics tablets, joysticks, keyboards, retina readers, touch screens (e.g., capacitive, resistive, etc.), trackballs, trackpads, sensors, styluses, and the like. These and other input devices are often connected to the processing unit 3204 through an input device interface 3242 that is coupled to the system bus 3208, but can be connected by other interfaces such as a parallel port, IEEE 1394 serial port, a game port, a USB port, an IR interface, and so forth.
A monitor 3244 or other type of display device is also connected to the system bus 3208 via an interface, such as a video adaptor 3246. The monitor 3244 may be internal or external to the computer 3202. In addition to the monitor 3244, a computer typically includes other peripheral output devices, such as speakers, printers, and so forth.
The computer 3202 may operate in a networked environment using logical connections via wire and/or wireless communications to one or more remote computers, such as a remote computer 3248. The remote computer 3248 can be a workstation, a server computer, a router, a personal computer, portable computer, microprocessor-based entertainment appliance, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 3202, although, for purposes of brevity, only a memory/storage device 3250 is illustrated. The logical connections depicted include wire/wireless connectivity to a local area network (LAN) 3252 and/or larger networks, for example, a wide area network (WAN) 3254. Such LAN and WAN networking environments are commonplace in offices and companies, and facilitate enterprise-wide computer networks, such as intranets, all of which may connect to a global communications network, for example, the Internet.
When used in a LAN networking environment, the computer 3202 is connected to the LAN 3252 through a wire and/or wireless communication network interface or adaptor 3256. The adaptor 3256 can facilitate wire and/or wireless communications to the LAN 3252, which may also include a wireless access point disposed thereon for communicating with the wireless functionality of the adaptor 3256.
When used in a WAN networking environment, the computer 3202 can include a modem 3258, or is connected to a communications server on the WAN 3254, or has other means for establishing communications over the WAN 3254, such as by way of the Internet. The modem 3258, which can be internal or external and a wire and/or wireless device, connects to the system bus 3208 via the input device interface 3242. In a networked environment, program modules depicted relative to the computer 3202, or portions thereof, can be stored in the remote memory/storage device 3250. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers can be used.
The computer 3202 is operable to communicate with wire and wireless devices or entities using the IEEE 802 family of standards, such as wireless devices operatively disposed in wireless communication (e.g., IEEE 802.16 over-the-air modulation techniques). This includes at least Wi-Fi (or Wireless Fidelity), WiMax, and Bluetooth™ wireless technologies, among others. Thus, the communication can be a predefined structure as with a conventional network or simply an ad hoc communication between at least two devices. Wi-Fi networks use radio technologies called IEEE 802.11x (a, b, g, n, etc.) to provide secure, reliable, fast wireless connectivity. A Wi-Fi network can be used to connect computers to each other, to the Internet, and to wire networks (which use IEEE 802.3-related media and functions).
As shown in
The client(s) 3302 and the servers 3304 may communicate information between each other using a communication framework 3306 such as in an optical wireless communication system. The communications framework 3306 may implement any well-known communications techniques and protocols. The communications framework 3306 may be implemented as a packet-switched network (e.g., public networks such as the Internet, private networks such as an enterprise intranet, and so forth), a circuit-switched network (e.g., the public switched telephone network), or a combination of a packet-switched network and a circuit-switched network (with suitable gateways and translators).
The communications framework 3306 may implement various network interfaces arranged to accept, communicate, and connect to a communications network. A network interface may be regarded as a specialized form of an input output interface. Network interfaces may employ connection protocols including without limitation direct connect, Ethernet (e.g., thick, thin, twisted pair 10/100/1900 Base T, and the like), token ring, wireless network interfaces, cellular network interfaces, IEEE 802.11a-x network interfaces, IEEE 802.16 network interfaces, IEEE 802.20 network interfaces, and the like. Further, multiple network interfaces may be used to engage with various communications network types such as an optical wireless communication network. For example, multiple network interfaces may be employed to allow for the communication over broadcast, multicast, and unicast networks. Should processing requirements dictate a greater amount speed and capacity, distributed network controller architectures may similarly be employed to pool, load balance, and otherwise increase the communicative bandwidth required by clients 3302 and the servers 3304. A communications network may be any one and the combination of wired and/or wireless networks including without limitation a direct interconnection, a secured custom connection, a private network (e.g., an enterprise intranet), a public network (e.g., the Internet), a Personal Area Network (PAN), a Local Area Network (LAN), a Metropolitan Area Network (MAN), an Operating Missions as Nodes on the Internet (OMNI), a Wide Area Network (WAN), a wireless network, a cellular network, and other communications networks.
Various embodiments may be implemented using hardware elements, software elements, or a combination of both. Examples of hardware elements may include processors, microprocessors, circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, application specific integrated circuits (ASIC), programmable logic devices (PLD), digital signal processors (DSP), field programmable gate array (FPGA), logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth. Examples of software may include software components, programs, applications, computer programs, application programs, system programs, machine programs, operating system software, middleware, firmware, software modules, routines, subroutines, functions, methods, procedures, software interfaces, application program interfaces (API), instruction sets, computing code, computer code, code segments, computer code segments, words, values, symbols, or any combination thereof. Determining whether an embodiment is implemented using hardware elements and/or software elements may vary in accordance with any number of factors, such as desired computational rate, power levels, heat tolerances, processing cycle budget, input data rates, output data rates, memory resources, data bus speeds and other design or performance constraints.
One or more aspects of at least one embodiment may be implemented by representative instructions stored on a machine-readable medium which represents various logic within the processor, which when read by a machine causes the machine to fabricate logic to perform the techniques described herein. Such representations, known as “IP cores” may be stored on a tangible, machine readable medium and supplied to various customers or manufacturing facilities to load into the fabrication machines that actually make the logic or processor. Some embodiments may be implemented, for example, using a machine-readable medium or article which may store an instruction or a set of instructions that, if executed by a machine, may cause the machine to perform a method and/or operations in accordance with the embodiments. Such a machine may include, for example, any suitable processing platform, computing platform, computing device, processing device, computing system, processing system, computer, processor, or the like, and may be implemented using any suitable combination of hardware and/or software. The machine-readable medium or article may include, for example, any suitable type of memory unit, memory device, memory article, memory medium, storage device, storage article, storage medium and/or storage unit, for example, memory, removable or non-removable media, erasable or non-erasable media, writeable or re-writeable media, digital or analog media, hard disk, floppy disk, Compact Disk Read Only Memory (CD-ROM), Compact Disk Recordable (CD-R), Compact Disk Rewriteable (CD-RW), optical disk, magnetic media, magneto-optical media, removable memory cards or disks, various types of Digital Versatile Disk (DVD), a tape, a cassette, or the like. The instructions may include any suitable type of code, such as source code, compiled code, interpreted code, executable code, static code, dynamic code, encrypted code, and the like, implemented using any suitable high-level, low-level, object-oriented, visual, compiled and/or interpreted programming language.
The following embodiments are presented to illustrate exemplary and non-limiting aspects of the disclosure. Example 1 is directed to a receiver circuitry to correct frequency offset between a receiving camera and a transmitting LED source, comprising: a shift register to receive incoming data from the LED source, the incoming data having a plurality of symbols and a symbol rate (fs), the shift register having a plurality of storage cells, each storage cell to receive and store one data bit per clock cycle, each bit of data representing a sampled pixel state and each bit of data sampled at a camera frame rate (fc); a plurality of comparator logic gates to correspond to a first group of the shift register storage cells, the plurality of logic gates configured to receive a sampled bit of data from a corresponding shift register storage cell during a clock cycle; and a controller to receive an output from the first plurality of comparator logic gates to identify a frequency offset between the symbol rate (fs) and the camera frame rate (fc) as one of a positive, negative or neutral frequency offset, the controller configured to compensate for the frequency offset if the frequency offset is one of the positive or negative frequency offset.
Example 2 is directed to the receiver circuitry of example 1, wherein the shift register receives and stores data at a long exposure mode and switches to short exposure mode to identify a region of interest (ROI) of modulated light.
Example 3 is directed to the receiver circuitry of example 1, wherein the shift register receives a start frame delimiter (SFD) in the incoming data and synchronizes the camera frame rate (fc) to the SFD.
Example 4 is directed to the receiver circuitry of example 1, wherein the plurality of comparators logic gates receive multiple sampled data and compare the sampled data with a threshold.
Example 5 is directed to the receiver circuitry of example 1, wherein the controller determines the frequency offset by comparing a sampled bit sequence of a first symbol (S−3, S−2, S−1, S0) of a first bit (BN) with a predetermined threshold sequence.
Example 6 is directed to the receiver circuitry of example 5, wherein the controller further identifies the bit values for a prior bit (BN−1) and a current bit decision (BN).
Example 7 is directed to the receiver circuitry of example 5, wherein the controller compensates for the negative frequency offset by sampling a subsequent symbol to obtain at least three new data samplings.
Example 8 is directed to the receiver circuitry of example 5, wherein the controller compensates for the positive frequency offset by sampling a subsequent symbol to obtain at least five new data samplings and discarding a first of the five samplings.
Example 9 is directed to a tangible machine-readable non-transitory storage medium that contains instructions, which when executed by one or more processors result in performing operations to correct frequency offset between a receiving camera and a transmitting LED source, the instructions comprising: receiving an incoming light at a pixel array of an optical receiving device; identifying a modulated light from the incoming light, the modulated light received at region of interest (ROI) of the pixel array, the modulated light carrying a data stream having a plurality of symbols and a symbol rate (fs); identifying a start frame delimiter (SFD) in the data stream and sampling the plurality of symbols at a camera frame rate (fc); determining a frequency offset between the camera frame rate (fc) and the symbol rate (fs) of the data stream; identifying the frequency offset as one of a positive, negative or neutral and compensating for the frequency offset if the frequency offset is one of the positive or negative frequency offset.
Example 10 is directed to the medium of example 9, wherein the modulated light defines a variable pulse modulation (VPPM) wave to modulate the data stream into a carrier wave.
Example 11 is directed to the medium of example 9, wherein receiving an incoming light at a pixel array further comprises recording the incoming light a long exposure mode and wherein identifying modulated light further comprises switching to short exposure mode.
Example 12 is directed to the medium of example 9, wherein identifying a start frame delimiter further comprises synchronizing the receiving camera frame rate (fc) to the SFD.
Example 13 is directed to the medium of example 9, wherein determining the frequency offset further comprises comparing a sampled bit sequence (S−3, S−2, S−1, S0) of a first bit (BN) with a predetermined threshold sequence.
Example 14 is directed to the medium of example 13, wherein determining the frequency offset further comprises identifying the bit values for a prior bit (BN−1) and a current bit decision (BN).
Example 15 is directed to the medium of example 13, further comprising compensating for the negative frequency offset by sampling a subsequent symbol to obtain at least three new data samplings.
Example 16 is directed to the medium of example 13, further comprising compensating for the positive frequency offset by sampling a subsequent symbol to obtain at least five new data samplings and discarding a first of the five samplings.
Example 17 is directed to a method to correct frequency offset between a receiving camera and a transmitting LED source, the method comprising: receiving an incoming light at a pixel array of an optical receiving device; identifying a modulated light from the incoming light, the modulated light received at region of interest (ROI) of the pixel array, the modulated light carrying a data stream having a plurality of symbols and a symbol rate (fs); identifying a start frame delimiter (SFD) in the data stream and sampling the plurality of symbols at a camera frame rate (fc); determining a frequency offset between the camera frame rate (fc) and the symbol rate (fs) of the data stream; identifying the frequency offset as one of a positive, negative or neutral and compensating for the frequency offset if the frequency offset is one of the positive or negative frequency offset.
Example 18 is directed to the method of example 17, wherein the modulated light defines a variable pulse modulation (VPPM) wave to modulate the data stream into a carrier wave.
Example 19 is directed to the method of example 17, wherein receiving an incoming light at a pixel array further comprises recording the incoming light a long exposure mode and wherein identifying modulated light further comprises switching to short exposure mode.
Example 20 is directed to the method of example 17, wherein identifying the SFD further comprises synchronizing the camera frame rate (fc) to the SFD.
Example 21 is directed to the method of example 17, wherein determining the frequency offset further comprises comparing a sampled bit sequence (S−3, S−2, S−1, S0) of a first bit (BN) with a predetermined threshold sequence.
Example 22 is directed to the method of example 21, wherein determining the frequency offset further comprises identifying the bit values for a prior bit (BN−1) and a current bit decision (BN).
Example 23 is directed to the method of example 21, further comprising compensating for the negative frequency offset by sampling a subsequent symbol to obtain at least three new data samplings.
Example 24 is directed to the method of example 21, further comprising compensating for the positive frequency offset by sampling a subsequent symbol to obtain at least five new data samplings and discarding a first of the five samplings.
While the principles of the disclosure have been illustrated in relation to the exemplary embodiments shown herein, the principles of the disclosure are not limited thereto and include any modification, variation or permutation thereof.
Number | Name | Date | Kind |
---|---|---|---|
4344180 | Cummiskey | Aug 1982 | A |
4355423 | Theall | Oct 1982 | A |
4882776 | Uzawa et al. | Nov 1989 | A |
5295012 | Wilson et al. | Mar 1994 | A |
5319487 | Sato et al. | Jun 1994 | A |
5517518 | Morson et al. | May 1996 | A |
5710774 | Suh et al. | Jan 1998 | A |
5808760 | Gfeller | Sep 1998 | A |
7043541 | Bechtolsheim et al. | May 2006 | B1 |
7082425 | Guy et al. | Jul 2006 | B2 |
7376152 | Saado | May 2008 | B2 |
7953324 | Leung et al. | May 2011 | B2 |
7991296 | Johnston et al. | Aug 2011 | B1 |
8334901 | Ganick et al. | Dec 2012 | B1 |
8406633 | Johnston et al. | Mar 2013 | B1 |
8818204 | Roberts | Aug 2014 | B2 |
8855249 | Nemeth | Oct 2014 | B2 |
8861976 | Roberts et al. | Oct 2014 | B2 |
9065629 | Helmschmidt | Jun 2015 | B2 |
9148250 | Roberts et al. | Sep 2015 | B2 |
9178615 | Roberts et al. | Nov 2015 | B2 |
9203541 | Roberts et al. | Dec 2015 | B2 |
9385807 | Roberts | Jul 2016 | B2 |
20020054409 | Bartur et al. | May 2002 | A1 |
20020172103 | Yamawaki | Nov 2002 | A1 |
20030086366 | Branlund et al. | May 2003 | A1 |
20030156603 | Rakib et al. | Aug 2003 | A1 |
20040005023 | Ham et al. | Jan 2004 | A1 |
20040161246 | Matsushita et al. | Aug 2004 | A1 |
20040196926 | Chien et al. | Oct 2004 | A1 |
20050123069 | Akasaka | Jun 2005 | A1 |
20070242337 | Bradley | Oct 2007 | A1 |
20080187085 | Nuth | Aug 2008 | A1 |
20080232509 | Jonsson et al. | Sep 2008 | A1 |
20090097588 | El-Agha et al. | Apr 2009 | A1 |
20110128384 | Tiscareno et al. | Jun 2011 | A1 |
20130129349 | Maxik et al. | May 2013 | A1 |
20140003823 | Roberts et al. | Jan 2014 | A1 |
20140006907 | Roberts et al. | Jan 2014 | A1 |
20140093238 | Roberts | Apr 2014 | A1 |
20140093249 | Roberts et al. | Apr 2014 | A1 |
20140219663 | Roberts | Aug 2014 | A1 |
20140270799 | Roberts et al. | Sep 2014 | A1 |
20140308048 | Roberts et al. | Oct 2014 | A1 |
20150092791 | Cornett et al. | Apr 2015 | A1 |
20150280817 | Roberts | Oct 2015 | A1 |
20160047888 | Roberts | Feb 2016 | A1 |
20160191163 | Preston et al. | Jun 2016 | A1 |
20170085337 | Cornett et al. | Mar 2017 | A1 |
20170187455 | Roberts et al. | Jun 2017 | A1 |
Number | Date | Country |
---|---|---|
2012002431 | Jan 2012 | WO |
2017116604 | Jul 2017 | WO |
Entry |
---|
Roberts et al., “Techniques for Optical Wireless Communication”, U.S. Appl. No. 15/088,897, filed Apr. 1, 2016, 69 Pages. |
Notice of Allowance received for U.S. Appl. No. 15/088,897 dated Sep. 6, 2017, 5 pages. |
Office Action received for U.S. Appl. No. 15/088,897 dated Jun. 1, 2017, 7 pages. |
Office Action received for U.S. Appl. No. 15/088,897 dated Feb. 1, 2017, 7 pages. |
International Search Report and Written Opinion received for International Application No. PCT/US2016/064384, dated Mar. 16, 2017, 12 pages. |
Office Action received for U.S. Appl. No. 14/210,390 dated May 12, 2017, 13 pages. |
Office Action received for U.S. Appl. No. 14/210,390 dated Oct. 31, 2016, 12 pages. |
Office Action received for U.S. Appl. No. 14/210,390 dated Apr. 27, 2016, 13 pages. |
Office Action received for U.S. Appl. No. 14/210,390 dated Aug. 11, 2015, 14 pages. |