The present disclosure relates to remote counting of serially connected components, and more specifically, to remote counting for serially connected light emitting diodes (LEDs) using a controller.
A variety of electrical components can be connected serially in a strip. For example, a series of LEDs can be connected in an LED light strip. Remotely counting the number of LEDs in a serially connected LED strip can be useful for many reasons. For example, many checkout areas at retail stores (e.g., checkout lanes and self-checkout systems) use serially connected strips of LEDs to illuminate and identify components in the point of sale (POS) system. Remotely counting the number of LEDs in a serially connected LED strip can be used to distinguish between different strips, can be used to identify missing LEDs, and can be used to identify malfunctioning LEDs.
Embodiments disclosed herein include a method. The method includes transmitting a first plurality of bits from a controller to a first light emitting diode (LED) of a plurality of serially connected LEDs, the plurality of serially connected LEDs including. the first LED coupled to the controller and a last LED coupled to a latch circuit. The method further includes determining, using the controller, that the latch circuit is set. The latch circuit is set based on an output of the last LED after the transmitting the first plurality of bits. The method further includes identifying a first number of active LEDs in the plurality of serially connected LEDs based on the determining that the latch circuit is set.
Embodiments disclosed herein further include a system. The system includes a plurality of serially connected light emitting diodes (LEDs), a latch circuit, and a controller including logic configured to perform an operation. The operation includes transmitting a first plurality of bits from the controller to a first LED of the plurality of serially connected LEDs, the plurality of serially connected LEDs including the first LED coupled to the controller and a last LED coupled to the latch circuit. The operation further includes determining, using the controller, that the latch circuit is set. The latch circuit is set based on an output of the last LED after the transmitting the first plurality of bits. The operation further includes identifying a first number of active LEDs in the plurality of serially connected LEDs based on the determining that the latch circuit is set.
Embodiments disclosed herein further include a computer program product for counting serially connected light emitting diodes (LEDs), the computer program product including a computer-readable storage medium having computer-readable program code embodied therewith, the computer-readable program code executable by one or more computer processors to perform an operation. The operation includes transmitting a first plurality of bits from a controller to a first LED of a plurality of serially connected LEDs, the plurality of serially connected LEDs including the first LED coupled to the controller and a last LED coupled to a latch circuit. The operation further includes determining, using the controller, that the latch circuit is set. The latch circuit is set based on an output of the last LED after the transmitting the first plurality of bits. The operation further includes identifying a first number of active LEDs in the plurality of serially connected LEDs based on the determining that the latch circuit is set.
As discussed above, a variety of electrical components can be connected serially in a strip. For example, light emitting diodes (LEDs) can be connected serially in a strip for a checkout area in a retail environment. Manned checkout and self-checkout areas, including point of sale (POS) systems, can include serially connected LED strips to illuminate various aspects of the checkout areas and POS systems. These LED strips can provide guidance to customers and employees, focus customer or employee attention on particular parts of the checkout areas, provide safety lighting, etc.
Remotely diagnosing problems with these serially connected LED strips can be difficult. For example, a retail store could have a back office (or central office) administration system that monitors the checkout area and detects problems. Because this system is remotely located, an administrator cannot simply look at the LED strips to diagnose any problems. Further, employees tasked with assisting with the checkout area may not have the training or expertise to identify and diagnose problems.
One more techniques disclosed herein relate to counting serially connected electrical components in a strip (e.g., a strip of LEDs). By counting the number of active LEDs (or other electronic components), and comparing it with an expected number of active LEDs for a given LED strip, a remote administrator can diagnose problems.
For example, a given checkout area might have multiple LED strips intended to be plugged into different areas. An employee could mistakenly plug one or more of the strips into the wrong area, resulting in incorrect LED placement and lighting. By determining the number of active LEDs in each strip, a remote administrator can identify this mistake and can provide guidance to the employee to fix the problem. As another example, an LED strip might have one or more LEDs that have stopped functioning. A remote lighting controller could identify a bad LED by detecting a lack of feedback (e.g. a count of MAX+1 as discussed below with regard to
Further, one or more techniques disclosed herein can use a controller to remotely count serially connected LEDs without the use of interrupts. In one embodiment, one could use a software interrupt to be triggered by the last LED's output in a strip to identify the malfunction of an LED. For example, LEDs in a strip can be fed by an output pin of a controller, and if the interrupt does not occur the strip is faulted. This can be used to identify and signal the pass or fail of the LED strip without counting. But software interrupts are often very slow, with varying delays, relative to the LED programming protocol, resulting in errors when trying to count LEDs or diagnose issues. One or more embodiments disclosed herein can remotely count serially connected LEDs (e.g., using the circuit configuration 200 illustrated in
Each manned checkout lane 120A-N includes at least one strip of LEDs. For example, the manned checkout lane 120A includes an LED strip 122. The LED strip 122 is made up of multiple LEDs, connected serially. In an embodiment, the manned checkout lane 120A can include multiple strips of LEDs, each strip including LEDs connected serially.
For example, the LED strip 122 can include one or more guidance lights to assist customers and employees with the checkout process. The LED strip 122 can include a lane light indicating the status of the lane or POS system (e.g., with a color indicating whether the lane is open, the POS is active, etc.). The LED strip 122 can further include lights indicating a receipt printer, coupon slot, cashback return, or other components of the POS system. In an embodiment, one or more of the lights in the LED strip 122 can be animated (e.g., to draw customer attention). These are merely examples, and other LEDs can be used.
In an embodiment, each manned checkout lane 120A-N includes a controller. For example, the manned checkout lane 120A includes a controller 124. In an embodiment, the controller 124 can be used for counting the LEDs in the LED strip 122 (e.g., as discussed in
Each self-checkout lane 130A-N also includes at least one strip of LEDs. For example, the self-checkout lane 130A includes an LED strip 132. The LED strip 132 is made up of multiple LEDs, connected serially. In an embodiment, the self-checkout lane 130A can include multiple strips of LEDs, each strip including LEDs connected serially. Further, as discussed above for the LED strip 122, the LED strip 132 can include one or more guidance lights or other LEDs to assist customers and employees with the checkout process.
In an embodiment, a controller is used with the self-checkout lanes 130A-F. For example, a controller 134 can be used with all of the self-checkout lanes 130A-N. In an embodiment, the controller 134 can be used for counting the LEDs in the LED strip 132 (e.g., as discussed in
The checkout area 110 is connected with an administration system 150 using a communication network 140. In an embodiment, the communication network 140 can be any suitable communication network, including a local area network (LAN), wide area network (WAN), or the Internet. The checkout area 110 can connect with the communication network 140 using any suitable technology, including a wired connection, a WiFi connection, a Bluetooth™ connection, a cellular connection, or any other suitable connection.
For example, each manned checkout lane 120A-A can include a POS system with network components suitable to connect with the network 140. Similarly, the self-checkout lanes 130A-N can include POS systems with network components suitable to connect with the network 140. In an embodiment, each self-checkout lane 130A-N includes network components and connects with the network 140. Alternatively, the self-checkout lanes 130A-N share a central POS component with network components to connect with the network 140.
The administrative system 150 can be used to administer various aspects of the checkout area 110. For example, the administrative system 150 can be used to configure and troubleshoot the various POS components in each of the manned checkout lanes 120A-N and the self-checkout lanes 130A-N. In this example, the administration system 150 can be a back office system located in or near a retail store, a central office system, or any other suitable system.
Further, as discussed in more detail below, the administrative system can be used to request a count of LEDs in the LED strips 122 and 132, can receive the count, and can take an appropriate action after receiving the count. For example, the administration system 150 can run periodic diagnostics on the components of the checkout area 110 (e.g., the POS components). As part of these diagnostics, the administration system 150 can count LEDs in the LED strips 122 and 132 and take appropriate actions. For example, if the administration system 150 determines that an LED strip 122 or 132 includes an unexpected number of LEDs, the administration system can trigger an alarm, transmit an alert to an administrator, provide an alert to the relevant POS system, or take any other suitable action. In an embodiment, the administrative system 150 can be any suitable computer system. One example system is described in connection with
As discussed further below with regard to
For example, each of the LEDs 220A-N can be a Red-Green-Blue-White (RGBW) LED, meaning the controller can program the Red tone, the Green tone, the Blue tone, and the White tone for each LED. Each tone consumes a particular number of bits to program the value for that tone. For example, assume each tone uses 8 bits to set its value. The controller 210 should transmit 32 bits to the LED 220A to program the color value for the LED 220A: 8 bits for Red, 8 bits for Green, 8 bits for Blue, and 8 bits for White. Similarly, the controller 210 should transmit 32 bits to the LED 220B to set the color value for the LED 220B, 32 bits to the LED 220C to set the color value for the LED 220C, etc.
In an embodiment, the LEDs 220A-N are connected serially. The controller 210 can set the color for all of the LEDs by transmitting a bit string 222 that includes 32 bits of data for each of the LEDs. That is, assume an LED strip 220 includes four LEDs 220A-D, including a first LED 220A coupled with the controller 210 and a last LED 220D coupled with a latch circuit 260 (via an OR gate 250).
The LEDs 220A-D are connected serially, and each requires 32 bits of data to set its color. The controller 210 can send a bit string 222 that is 128 bits long (i.e., 32 bits*4 LEDs). The first LED 220A consumes the first 32 bits, to program its color, and passes the remaining 96 bits to the second LED 220B. The LED 220B consumes the next 32 bits, and passes the remaining 64 bits to the third LED 220C. The LED 220C consumes the next 32 bits and passes the remaining 32 bits to the fourth LED 220D. The LED 220D consumes the last 32 bits, and the bit string 222 is empty. In an embodiment, this can be done for any number of bits per LED and any number of LEDs in the LED strip 220.
In an embodiment, as discussed further below with regard to
For example, assume that the LED strip 220 includes three LEDs 220A-C, each of which consumes 32 bits. The controller 210 expects that that the LED strip 220 includes four LEDs, and so it sends 128 bits in the bit string 222 to set the color value for all four LEDs 220A-N. The LED strip 220 will only consume 96 bits (because it includes only 3 LEDS). The extra 32 bits will be transmitted to the OR gate 250 and the input of the latch circuit 260, setting the latch to high. This sets the RET value at the controller to high, and tells the controller that fewer than four LEDs are active in the LED strip 220. As discussed in further detail below with regard to
Further, if the LED strip 220 includes an LED that is malfunctioning, not active (e.g., LED 220C), the failed LED will fail to communicate (e.g., fail to pass bits to the next LED in the strip). This will result in the latch circuit 260 always remaining low, no matter how many bits are sent to the LED strip 220. As discussed below with regard to
In an embodiment, the OR gate 250 facilitates counting multiple strips of LED with a single controller 210 and latch 260. For example, the latch 260 can be a standard D flip-flop with its Q permanently set high. The latch 260 can have its state set to low by toggling the clear input (e.g., CLR as illustrated), and can be clocked to a high state by a feedback pulse through the OR gate 250 from any of the LED strips on the input side of the OR gate 250 (e.g., any of the LED strips 220A-N, 230A-N, and 240A-N). A feedback pulse through the OR gate 250 sets the latch high by toggling the latch clock. Since only one strip is tested at a time, the source of the latch state (e.g., which LED strip has triggered the latch being set to high) is known.
Although the memory 310 is shown as a single entity, the memory 310 may include one or more memory devices having blocks of memory associated with physical addresses, such as random access memory (RAM), read only memory (ROM), flash memory, or other types of volatile and/or non-volatile memory. The memory 310 generally includes program code for performing various functions related to use of the controller 300. The program code is generally described as various functional “applications” or “modules” within the memory 310, although alternate implementations may have different functions and/or combinations of functions. The memory 310 includes an LED counting module 312. In an embodiment, this LED counting module 312 can be used to count LEDs in a serially connected LED strip, as illustrated in
At block 402, the LED counting module sets the initial count boundaries. In an embodiment, this includes setting a MIN value, a MAX value, and a MIDPOINT value. The MIN value can be set to 0, the MAX value can be set to a value higher than the expected number of LEDs, and the MIDPOINT can be set to half of the MAX+MIN value.
As an example, assume that the LED counting module is operating using the controller 210 illustrated in
At block 404, the LED counting module determines whether MAX−MIN is less than or equal to 1. Continuing the example above, MAX is set to 101 and MIN is set to 0. Thus, MAX−MIN is equal to 101. This is greater than 1, so the flow proceeds to block 406.
At block 406, the LED counting module clears the latch (e.g., sets the value low). For example, in the circuit configuration 200, the controller 210 can set the value of the latch circuit 260 low.
At block 408, the LED counting module sends a bit string that is sufficient to provide bits to MIDPOINT number of LEDS. Following the example above, MIDPOINT is 50. Assume each LED in the LED strip 220 consumes 32 bits (e.g., for a RGBW LED that uses 8 bits for each tone, as discussed above with regard to
As discussed above, the LED strip 220 includes 25 LEDs, so it consumes 800 (25*32) bits. This leaves 800 unconsumed bits. Because the bit string includes unconsumed bits, as discussed above with regard to
At block 410, the LED counting module determines whether the latch is set to high. Here, it is, so the flow proceeds to block 412.
At block 412, the LED counting module updates the counting boundaries to the lower half of the remaining search set. In an embodiment, this means setting the MAX equal to the prior MIDPOINT, and setting the MIDPOINT to the lower quartile: floor(MIN+MIDPOINT)/2. In our example, MAX is set to 50 (the prior MIDPOINT) and MIDPOINT is set to 25 ((0+50)/2).
The flow then returns to block 404. MAX is now 50, MIN is still 0, and MIDPOINT is 25. MAX−MIN is 50, still greater than 1, so the flow proceeds to block 406. At block 406 the LED counting module again clears the latch.
At block 408, the LED counting module sends a bit string sufficient for MIDPOINT number of LEDs to consume: 800 (25*32) bits. As discussed above the LED strip 220 includes 25 LEDs, so the LED strip 220 consumes all 800 bits. This means no bits are leftover, the input to the OR gate 250 is low and, assuming the other inputs are also low, the input to the latch circuit 260 is low.
At block 410, the LED counting module determines that the latch is not set (e.g., it is low). The flow proceeds to block 414.
At block 414, the LED counting module sets the counting boundaries to the upper half of the remaining search set. In an embodiment the LED counting module sets the MIN to the prior MIDPOINT and sets the MIDPOINT to (MAX+MIDPOINT)/2. Here, the LED counting module sets the MIN to 25 and sets the MIDPOINT to 37.
The flow returns to block 404. MAX is still 50. MIN is now 25. And MIDPOINT is 37. MAX−MIN is 25, still greater than 1, so the flow proceeds to block 406. At block 406, the LED counting module clears the latch (e.g., sets it to low).
At block 408, the LED counting module sends a bit string sufficient for MIDPOINT LEDs: 1184 (37*32). The LED strip 220 consumes only 800 bits (25*32), so the OR gate 250 is high, the input to the latch circuit 260 is high, and the latch is set to high at the next clock cycle.
At block 410, the LED counting module determines that the latch is set to high, so the flow proceeds to block 412. At block 412 the LED counting module updates the MAX to the prior MIDPOINT and the MIDPOINT to halfway between the prior MIN and the prior midpoint (MIN+MIDPOINT)/2. MAX is set to 37 and MIDPOINT is set to 31.
The flow again returns to block 404. MAX is now 37, MIN is still 25, and MIDPOINT is now 31. MAX-MIN is greater than 1, so the flow continues to iterate. After the next iteration, at block 412 the LED counting module sets MAX to 31, sets MIDPOINT to 28, and MIN remains 25. The MAX-MIN is still greater than 1, so the flow iterates again. This time at block 412 the LED counting module sets MAX to 28, sets MIDPOINT to 26, and MIN remains 25. Again, MAX-MIN is greater than 1, so the flow iterates again. This time at block 412 the LED counting module sets MAX to 26, sets MIDPOINT to 25, and MIN remains 25.
The flow returns to block 404. MAX is 26, MIDPOINT is 25, and MIN is 25. MAX−MIN (26−25) is now 1. So the flow proceeds to block 416.
At block 416, the LED counting module returns the value of MIN. Here, MIN is 25, so 25 is returned as the count for the number of LEDs in the LED strip 220. As discussed above, in this example, this is accurate.
Further, the techniques illustrated in
At block 502, an LED counting module (e.g., the LED counting module 312 illustrated in
At block 504, the LED counting module compares the last two results. At block 506, the LED counting module determines whether the last two results match. If they match, the flow proceeds to block 510 and the LED counting module returns the last result.
If the last two results do not match, the flow proceeds to block 508. At block 508, the LED counting module runs the algorithm illustrated in the flowchart 400 again, and then returns to block 504 and then proceeds to block 506 to check whether the results now match. If so, the flow proceeds to block 510 and returns the last result.
CPU 610 retrieves and executes programming instructions stored in memory 625 as well as stores and retrieves application data residing in the storage 630. For example, the CPU 610 can correspond with the processor 302 illustrated in
Illustratively, memory 625 includes an operating system 627 and a database management system (DBMS) 629, while storage 630 includes a data repository 618 (e.g., a database). Further, as discussed above, the memory 625 can include the additional modules described above with regard to
One or more of the embodiments discussed above generally relate to counting LEDs in a serially connected strip of LEDs. This is merely one example. One or more the techniques disclosed herein could be used to count or monitor serially connected electronic components for a variety of applications, including security systems, or the suitable systems.
The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.
In the following, reference is made to embodiments presented in this disclosure. However, the scope of the present disclosure is not limited to specific described embodiments. Instead, any combination of the following features and elements, whether related to different embodiments or not, is contemplated to implement and practice contemplated embodiments. Furthermore, although embodiments disclosed herein may achieve advantages over other possible solutions or over the prior art, whether or not a particular advantage is achieved by a given embodiment is not limiting of the scope of the present disclosure. Thus, the following aspects, features, embodiments and advantages are merely illustrative and are not considered elements or limitations of the appended claims except where explicitly recited in a claim(s). Likewise, reference to “the invention” shall not be construed as a generalization of any inventive subject matter disclosed herein and shall not be considered to be an element or limitation of the appended claims except where explicitly recited in a claim(s).
Aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.”
The present invention may be a system, a method, and/or a computer program product. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
These computer readable program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
Embodiments of the invention may be provided to end users through a cloud computing infrastructure. Cloud computing generally refers to the provision of scalable computing resources as a service over a network. More formally, cloud computing may be defined as a computing capability that provides an abstraction between the computing resource and its underlying technical architecture (e.g., servers, storage, networks), enabling convenient, on-demand network access to a shared pool of configurable computing resources that can be rapidly provisioned and released with minimal management effort or service provider interaction. Thus, cloud computing allows a user to access virtual computing resources (e.g., storage, data, applications, and even complete virtualized computing systems) in “the cloud,” without regard for the underlying physical systems (or locations of those systems) used to provide the computing resources.
Typically, cloud computing resources are provided to a user on a pay-per-use basis, where users are charged only for the computing resources actually used (e.g. an amount of storage space consumed by a user or a number of virtualized systems instantiated by the user). A user can access any of the resources that reside in the cloud at any time, and from anywhere across the Internet. In context of the present invention, a user may access applications (e.g., the administration system 150 illustrated in
While the foregoing is directed to embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.