Control methods and apparatus for coupling multiple image acquisition devices to a digital data processor

Information

  • Patent Grant
  • 6684402
  • Patent Number
    6,684,402
  • Date Filed
    Wednesday, December 1, 1999
    25 years ago
  • Date Issued
    Tuesday, January 27, 2004
    20 years ago
Abstract
A hub that controls the acquisition of images from a plurality of image sources utilizes image acquisition logic that selectively applies a first set of control signals (e.g., “shutter” signals) to imaging devices, causing them to acquire images. The logic applies a second set of control signals (e.g., “readout” signals) to the devices, causing them to output the images to the hub. Those images are transferred by the hub to a host over an isochronous communications medium.
Description




BACKGROUND OF THE INVENTION




The invention pertains to image acquisition and, particularly, to the acquisition of image data from multiple sources. The invention has application in acquiring images from video cameras and other acquisition devices used in machine vision and in other industrial, research and recreational environments.




It is increasingly common to couple video cameras, and other image acquisition devices, to computers. This has been made possible by increases in computer processing power and storage capacity, as well as by decreases in equipment costs. It is also a consequence of the rise in popularity of the Internet, for which the transmission and display of images is increasingly norm.




Cameras and computers have long been used together in machine vision, which involves the automated analysis of images, typically, to determine characteristics of objects shown in them. It is often employed in automated manufacturing lines, where images of components are analyzed to determine placement and alignment prior to assembly. Machine vision is also used for quality assurance. For example, in the semiconductor device industry, images of chips are analyzed to insure that leads, solder paste and other components do not overrun designated boundaries.




As the machine vision industry has recognized, and consumers are soon to realize, one camera is often not enough. When machine vision is used in manufacturing, for example, it may be desirable to generate multiple simultaneous views of an object. Alternatively, it may be necessary to generate multiple views without moving the camera or the object. Within the consumer domain, web cams and Internet-based videoconferencing are among the applications which are likely to benefit from such uses of multiple cameras.




Notwithstanding the benefits of coupling computers to multiple cameras, no general purpose solutions exist. Some personal computers or workstations are equipped with only a single port capable of receiving high-speed video input streams. That port can be a universal serial bus (USB 2, hereinafter referred to, simply, as “USB”) port, though, it may alternatively be an IEEE 1394-compatible (“FireWire”) port. The machine vision industry relies on digital data processors with multiple video ports, however, these “vision processors” can represent an unnecessary expense in situations where the resources of a engineering workstation or personal computer are otherwise available.




In view of the foregoing, an object of this invention is to provide improved methods and apparatus for image acquisition.




A more particular object is to provide such methods and apparatus as permit multiple image acquisition devices to be coupled to a digital data processor.




A still more particular object is to provide such methods and apparatus as permit multiple image acquisition devices to be coupled to a personal computer, workstation or other digital data processor via a single port.




Still another object of the invention is to provide such methods and apparatus as support such coupling through a conventional high-speed serial port, such as a USB port, a FireWire port, or the like.




Still yet further objects of the invention are to provide such methods and apparatus as can be utilized with charge coupled device image acquisition devices.




Yet still further objects of the invention are to provide such methods and apparatus as permit the coupling of multiple video sources to a digital data processor, regardless of whether those sources are image acquisition devices.




SUMMARY OF THE INVENTION




These and other objects are met by the invention which provides, in one aspect, a hub that controls the acquisition of images from a plurality of image sources. Image acquisition logic operating within the hub selectively applies a first set of control signals (e.g., “shutter” signals) to the sources, causing them to acquire images. The logic applies a second set of control signals (e.g., “readout” signals) to the sources, causing them to output acquired images to the hub. The hub then transmits those images to a host over an isochronous communications medium, e.g., a USB or FireWire bus. As used herein, “isochronous” medium refers to a medium that permits creation of a connection (virtual or otherwise) between a source and a destination and that allows allocation of a minimum guaranteed bandwidth for transfer of information between such source and destination, regardless of the existence of other demands for bandwidth allocation or information transfer over that medium. Isochronous also refers to a medium that supports only isochronous transfers or, alternatively, to isochronous phases of a medium that supports isochronous and other types of transfers (e.g., asynchronous). An example of such an isochronous medium is a bus compatible with the aforementioned IEEE 1394 standard.




A hub or other image acquisition control apparatus as described above is advantageous, among other reasons, because it permits multiple image sources to be connected to a personal computer, work station or other host device via a single high-speed port, e.g., a FireWire port or a USB port.




Further aspects of the invention provide a hub (or other image acquisition control apparatus) as described above in which the image sources are cameras or other image acquisition devices and, more particularly, charge coupled device (CCD) image acquisition devices.




Related aspects of the invention provide such a hub for use with CCD or other image acquisition devices of the type that are responsive to a shutter signal for acquiring image data, and to a readout signal for outputting that data. The hub applies the first and second controls signals to such devices in such a way as to cause them to acquire or generate images substantially simultaneously, yet, output them sequentially (or with a desired degree of simultaneity) to the hub.




A hub as described above can operate utilizing instructions issued by the host, which can be for example a personal computer, workstation or other digital data processing device. Such a hub can, further, transfer image data received at its device interfaces substantially immediately to its host interface.




Still further aspects of the invention provide methods of operating hubs or image acquisition control apparatus paralleling the foregoing.




Hubs or image acquisition control apparatus and methods as described above provide numerous advantages in machine vision as well as in other industrial, research, home and recreational environments. Such apparatus and methods take advantage of the storage capabilities of CCD or other image capture devices, permitting multiple images to be acquired, e.g., simultaneously, while minimizing or virtually eliminating the need for buffering image data that are being transferred from the acquisition devices to the host.




These and other aspects of the invention are evident in the drawings and in the description that follows.











BRIEF DESCRIPTION OF THE DRAWINGS




A more complete understanding of the invention may be attained by reference to the drawings, in which:





FIG. 1

depicts a system. according to the invention in which a host device is coupled to multiple image acquisition devices via a hub; and





FIG. 2

depicts a hub according to the invention for use in a system of the type depicted in FIG.


1


.











DETAILED DESCRIPTION OF THE ILLUSTRATED EMBODIMENT





FIG. 1

depicts a system


10


according to the invention in which a host device


12


is coupled to multiple image acquisition devices


14


,


16


,


18


via a hub


20


. The illustrated system


10


is configured for use in machine vision, though, related configurations and the teachings herein may be applied to any industrial, research, home, recreational or other application.




Host device


12


comprises a workstation, personal computer, digital data processor or other device equipped with a port (or other interface) for receiving image data transmitted over an isochronous communications medium


22


. In the illustrated machine vision embodiment, host device


12


comprises an engineering workstation executing conventional machine vision software, as well as for exchanging data and control signals with hub


20


in accord with the teachings herein.




Communications medium


22


comprises any network, bus or other medium capable of effecting isochronous communications. In the illustrated embodiment, this is a FireWire bus—i.e., a bus compatible with the IEEE 1394 standard. Other embodiments operate medium


22


in accord with the universal serial bus (USB) standard, or in accord with other isochronous media standards.




Devices


14


-


18


comprise sources of image data. In the illustrated embodiment, these are image acquisition devices and, more particularly, charge coupled device (CCD) cameras constructed and operated in accord with the teachings of U.S. patent application Ser. Nos. 09/087,592 and 09/404,559, the teachings of which are incorporated herein by reference. The cameras taught in those applications permit image integration (herein referred to as “igeneration” or “acquisition”) that is independent of readout. Thus, for example, they respond to applied shutter signals for acquiring images, and to applied readout signals for outputting those images, e.g., over lines


24


-


28


. Devices


14


-


18


may comprise, alternatively or in addition, CMOS cameras or other image acquisition devices and video sources of the types available in the marketplace.




As noted, hub


20


is coupled to image acquisition devices


14


-


18


via lines


24


-


28


. These may comprise any network, bus or other communications media (including, by non-limiting example, Ethernet, gigabit Ethernet, USB buses, FireWire buses, and so forth) capable of carrying image data from the devices


14


-


18


to the hub.




Hub


20


is also coupled to devices


14


-


18


via control lines


30


-


34


. It may also be coupled to illumination sources, motion platforms and other auxiliary equipment (not shown) for facilitating image acquisition. In the illustrated embodiment, lines


30


-


34


are independent of lines


24


-


28


over which image data are carried. In any event, lines


30


-


34


are equipped to cary at least selected control signals, such as shutter signals, from the hub


20


to the devices


14


-


18


without substantial delay—thus, permitting the hub


20


to more accurately control the timing of image acquisition.





FIG. 2

depicts in greater detail a hub


20


according to the invention. The hub comprises a host interface


36


of conventional construction and operation that transmits data (including image data) and control signals to and from medium


22


. Hub


20


likewise includes devices interfaces


38


,


42


,


44


that transmit image data and control signals to and from media


24


-


28


,


30


-


34


, as illustrated. Each interface


36


-


42


includes conductors, multiplexors, buffers and other circuitry (not shown) of the type known in the art for use in transferring data with the respective buses, networks, conductor sets or other media.




Hub


20


also include a central processing unit or other logic


44


(e.g., ASICs, gate arrays or the like) that controls the transfer of control and data signals over media


22


-


28


,


30


-


34


based on instructions maintained in EEPROM, DRAM or other memory


46


. Those instructions can be pre-stored in memory


46


(e.g., as in the case of EEPROM) and/or may be downloaded from host


12


via medium


22


.




Regardless of the instruction source, logic


44


controls the acquisition (or generation) and readout of images by devices


14


-


18


in accord with the teachings below. This can be based, for example, on trigger events, e.g., received from an external source via external input line


45


. In the illustrated embodiment, the logic


44


signals the devices


14


-


18


in such a manner as to cause them to acquire images, e.g., simultaneously, or as otherwise commanded by host


12


, and to sequentially output their respective image data to the hub


20


for transfer to host


12


over medium


22


. By sequencing the output of image data from the respective devices


14


-


18


and transferring that data substantially immediately from interfaces


38


-


42


to interface


36


, the logic


44


minimizes or eliminates the need to buffer or otherwise store that data (e.g., in frame or FIFO memory) en route.




Referring again to

FIG. 1

, there is shown a sequence of steps executed by devices


12


-


20


to effect the control of image acquisition and transfer according to the invention.




In step


1


, the host


12


transmits set-up instructions to the hub


20


for image acquisition. This includes specifying the acquisition devices


14


-


18


that will be used for image capture, as well as parameters necessary or desirable for such purposes. Examples include camera orientations (e.g., in the case of rotatable or positionable devices), trigger events, aperture settings, strobe settings, illumination levels and so forth. In a preferred embodiment, the host provides such instructions utilizing a protocol paralleling or identical to that under definition for the transfer of digital video data in connection with standard IEEE 1394. Although image data are transferred from hub


20


to host


12


using the isochronous phase of medium


22


, instructions, control and other data can be sent during asynchronous or other phases.




In step


2


, the hub


20


initiates the medium


22


for isochronous transfers and acquires a channel for transmission of image data thereon to the host


12


. In the case of a FireWire medium, this is accomplished using conventional channel allocation techniques, e.g., involving the CHANNELS_AVAILABLE register and the BANDWIDTH_AVAILABLE register. The hub preferably allocates the channel(s) with sufficient capacity to accommodate the combined image data output by devices


14


-


18


. Thus, for example, if each device


14


-


18


outputs image data at a rate of 1 MByte per frame and 50 milliseconds per frame, the hub


20


allocates 20 Mbytes per second of isochronous channel capacity on medium


22


to accommodate the combined output of those three devices


14


-


18


. In this example, the latency between a trigger event requesting simultaneous acquisition and the completion of three acquisitions would be 150 milliseconds.




In steps


3




a


-


3




c


, the hub


20


sets up each image acquisition device. This is accomplished by sending control signals to each device


14


-


18


along control lines


30


-


34


and/or data lines


24


-


28


utilizing parameters defined by host


12


in step


1


, as well as any other parameters desirable or necessary to condition the devices


14


-


18


for image acquisition. As noted above, these can include orientation, aperture, strobe, illumination, and so forth.




In step


4


, the hub applies shutter signals to the respective device interfaces


38


-


42


(via lines


30


-


34


), causing the devices


14


-


18


to acquire images. Application of the shutter signals can be keyed to a clock or other event, e.g., in accord with instructions sent from the host


12


to hub


20


in step


1


. In the illustrated embodiment, the shutter signals are applied substantially simultaneously to the devices


14


-


18


, thereby, causing them to acquire images substantially simultaneously. Of course, the hub


20


can apply shutter signals at different times to effect other image acquisition timings, as well, e.g., in accord with instructions from host


12


.




In step


5




a


, the hub applies a readout signal to the interface


38


, causing associated image acquisition device


14


to output image data previously acquired by it. The readout signal can be transmitted along control lines


30


or along data lines


24


. Image data output by device is returned along line


24


. See step


5




b.


Similar sequences are executed with respect to devices


16


-


18


. See steps


6




a


-


6




b


and


7




a


-


7




b.






As image data output by devices


14


-


18


is received by hub


20


, the hub transmits that along medium


22


to host


12


. In the illustrated embodiment, the hub transfers each pixel of image data received at an interface


38


-


42


directly to interface


36


, with only such buffering as is required to construct packets or other structures necessitated by the protocol of medium


22


. To this end, logic


44


preferably times steps


5


-


7


for accord with the allocated isochronous channel on medium


22


, insuring that the channel will be ready to accept image data as it becomes available from the devices


14


-


18


. Logic


44


also sequences the individual readout signals applied in steps


5




a


,


6




a


and


7




a


, respectively, to minimize any undesired overlap in receipt of image data from the respective devices


14


-


18


, thereby, further minimizing or eliminating a need for buffering that data. In alternate embodiments, the hub


20


buffers data received from the devices


14


-


18


prior to transmitting it to the host.




Described above are methods and apparatus meeting the desired objectives. Those skilled in the art will appreciate that the embodiments shown in the drawings and discussed herein are examples of the invention, and that other embodiments incorporating changes thereto fall within the scope of the invention. Thus, by way of non-limiting example, it will be appreciated that medium


22


can support isochronous protocols other than those defined under the IEEE 1394 or USB standards. By way of further example, it will be appreciated that the hub can be used to control the transfer of video data other than that generated by image acquisition devices. By way of still further example, it will be appreciated that CMOS or other solid state cameras or image acquisition devices may be substituted for the charge coupled devices (CCDs) referred to above.



Claims
  • 1. A hub for controlling acquisition of images from a plural of sensors, the hub comprising:a plurality of device interfaces, each of which exchanges information with an associated one of the plural sensors, each of the plural sensors being responsive to an applied shutter signal to acquire a frame of image data and being responsive to an applied readout signal to initiate output of that frame of image data, wherein the sensor does not acquire a new frame of image data prior to output of a previously acquired frame of image data, a host interface that exchanges information with a host over an isochronous communications medium, image acquisition logic, coupled to the device interfaces and to the host interface, the image acquisition logic (i) selectively applying shutter signals to the device interfaces to cause the associated sensors to acquire image data, (ii) selectively applying readout signals the device interfaces to cause the associated sensors to output image data acquired by them, (iii) transferring image data received at the device interface to the host interface for output to the host over the communications medium, the image acquisition logic applying (i) shutter signals to the device interfaces so as to cause the associated sensors to acquire image data substantially simultaneously with respect to one another, (ii) readout signals to the device interfaces so as to cause the associated sensors to output the acquired image data in a sequence with respect to one another, wherein the image acquisition logic transfers substantially immediately to the host interface image data at a said device interface, and wherein the image acquisition logic buffers substantially no more image data than required to construct data packets from data received at a said device interface prior to output to the host interface.
  • 2. A hub according to claim 1 that operates in accord with instructions from the host.
  • 3. Control apparatus for controlling acquisition of images from a plurality of image acquisition devices, the control apparatus comprising:at least one device interface that transfers information between the control apparatus and the plurality of image acquisition devices, each of the plural image acquisition devices being responsive to an applied shutter signal to acquire a frame of image data and being responsive to an applied readout signal to initiate output of that frame of image data, wherein the image acquisition device does not acquire a new frame of image data prior to output of a previously acquired frame of image data, a host interface that transfers information between the control apparatus and a host over an isochronous communications medium, image acquisition logic, coupled to at least one device interface and to the host interface, the image acquisition logic (i) selectively applying shutter signals to the at least one device interface to cause each of the plurality of image acquisition devices to acquire image data, (ii) selectively applying readout signals to the at least one device interface to cause each of the plurality of image acquisition devices to output image data acquired by them, (iii) transferring image data output by the image acquisition devices to the host over the communications medium, the image acquisition logic applying (i) shutter signals to the at least one device interface so as to cause the associated image acquisition devices to acquire image data substantially simultaneously with respect to one another, (ii) readout signals to the at least one device interface so as to cause the associated image acquisition devices to output the acquired image data independently with respect to one another wherein the image acquisition logic transfers substantially immediately to the host interface image data at a said device interface, and wherein the image acquisition logic buffers substantially no more image data than required to construct data packets from data received at a said device interface prior to output to the host interface.
  • 4. Control apparatus according to claim 3, wherein the image acquisition logic applies the shutter and readout signals to the at least one device interface so as to effect sequential transfer to the host of image data captured substantially simultaneously by the image acquisition devices.
  • 5. Control apparatus according to claim 4, wherein the image acquisition logic applies the shutter signals to the at least one device interface to cause the plurality of image acquisition devices to acquire image data substantially simultaneously with respect to one another and wherein the image acquisition logic applies the readout signals to to the at least one device interface to cause the plurality of image acquisition devices to output image data acquired by them in a selected sequence.
  • 6. A hub for controlling acquisition of images from a plurality of image acquisition devices, the hub comprising:a plurality of device interfaces, each of which exchanges information with an associated one of the plural image acquisition devices, each of the plural image acquisition devices being responsive to an applied shutter signal to acquire a frame of image data and being responsive to an applied readout signal to initiate output of that frame of image data, wherein each image acquisition devices does not acquire a new frame of image data prior to output of a previously acquired frame of image data, a host interface that exchanges information with a host over a communications medium that supports information transfers in accord with an IEEE 1394 standard, image acquisition logic, coupled to the device interfaces and to the host interface, the image acquisition logic (i) selectively applying shutter signals to the device interfaces to cause the associated image acquisition devices to acquire image data, (ii) selectively applying readout signals the device interfaces to cause the image acquisition devices to output image data acquired by them, (iii) transferring image data received at the device interfaces to the host interface for output to the host over the communications medium, the image acquisition logic applying (i) shutter signals to the device interfaces so as to cause the associated image acquisition devices to acquire image data substantially simultaneously with respect to one another, (ii) readout signals to the device interfaces so as to cause the associated image acquisition devices to output the acquired image data in a sequence with respect to one another, wherein the image acquisition logic outputs image data received at a device interface substantially immediately via the host interface, and wherein the image acquisition logic buffers substantially no more image data than required to construct data packets from data received at a said device interface prior to output to the host interface.
  • 7. A hub according to claim 6 that operates in accord with instructions from the host.
  • 8. Control apparatus for controlling acquisition of images from a plurality of image sources, the control apparatus comprising:a plurality of device interfaces, each of which exchanges information with an associated one of the plural image sources, each of the plural image sources being responsive to an applied shutter signal to acquire a frame of image data and being responsive to an applied readout signal to initiate output of that frame of image data, wherein each image source does not acquire a new frame of image data prior to output of a previously acquired frame of image data, each device interface including a control line for transferring a shutter signal from the apparatus to the associated image source to cause it to capture an image, a host interface that exchanges information with a host over an isochronous communications medium, image acquisition logic, coupled to the device interfaces and to the host interface, the image acquisition logic (i) selectively applying shutter signals to the control lines to cause the associated image sources to acquire image data, (ii) selectively applying readout signals the device interfaces to cause the image sources to output image data acquired by them, (iii) transferring image data received at the device interfaces to the host interface for output to the host over the communications medium, the image acquisition logic applying (i) shutter signals to the control lines so as to cause the associated image sources to acquire image data substantially simultaneously with respect to one another, (ii) readout signals to the device interfaces so as to cause the associated image sources to output the acquired image data independently with respect to one another, wherein the image acquisition logic transfers substantially immediately to the host interface image data at the device interfaces, and wherein the image acquisition logic buffers substantially no image data received at a said device interface prior to output to the host interface.
  • 9. Control apparatus according to claim 8, wherein each control line is arranged for transferring an applied shutter signal to the associated image source substantially without delay.
  • 10. Control apparatus according to claim 9, wherein the control line comprises a communications medium independent of that over which the image data is transferred by the associated device interface.
  • 11. Control apparatus according to claim 10, wherein each device interface transfers the shutter signal to the associated image source over a line independent of the line over which image data is transferred by the associated device interface.
  • 12. Control apparatus according to claim 8, wherein the image acquisition logic acquires bandwidth on the communications medium.
  • 13. Control apparatus according to claim 8, wherein the image acquisition logic applies the shutter and readout signals to the plurality of image sources so as to effect sequential transfer to the host of images captured substantially simultaneously by the image sources.
  • 14. Control apparatus according to claim 13, wherein the image acquisition logic applies the shutter signals substantially simultaneously to the plurality of image sources and wherein the image acquisition logic applies the readout signals to those devices in a selected sequence.
  • 15. Control apparatus according to claim 8 that operates in accord with instructions from the host.
  • 16. Control apparatus according to claim 8, wherein the host interface transfers information with a communications medium that supports information transfers in accord with an IEEE 1394 standard.
  • 17. Control apparatus according to claim 9, wherein the host interface transfers information with a communications medium that supports information transfers in accord with a Universal Serial Bus (USB) standard.
  • 18. A method for controlling acquisition of images from a plurality of image acquisition devices, the method comprising:A. providing a hub including a plurality of device interfaces, each of which exchanges information with an associated one of the plural image acquisition devices, each of the plural image acquisition devices being responsive to an applied shutter signal to acquire a frame of image data and being responsive to an applied readout signal to initiate output of that frame of image data, wherein each image acquisition device does not acquire a new frame of image data prior to output of a previously acquired frame of image data, a host interface that exchanges information with a host over an isochronous communications medium, B. selectively applying shutter signals to the device interfaces to cause the associated image acquisition devices to acquire image data, C. selectively applying readout signals the device interfaces to cause the image acquisition devices to output image data acquired by them, D. transferring image data received at the device interfaces to the host interface for output to the host over the communications medium E. performing steps B and C so as (i) to cause the image acquisition devices to acquire image data substantially simultaneously with respect to one another, (ii) to cause the associated image acquisition devices to output the acquired image data in a sequence with respect to one another, F. performing step D so as to transferred image data at a said device interface substantially immediately to the host interface, and buffering substantially no more image data than required to construct data packets from data received at a said device interface prior to output to the host interface.
  • 19. A method according to claim 18, comprising executing steps (B) and (D) in accord with instructions from the host.
  • 20. A method for controlling acquisition of images from a plurality of image sources, the method comprising:A. providing a control device having at least one device interface that transfers information between the control device and the plurality of image sources, each of the plural image sources being responsive to an applied shutter signal to acquire a frame of image data and being responsive to an applied readout signal to initiate output of that frame of image data, wherein each image source does not acquire a new frame of image data prior to output of a previously acquired frame of image data, a host interface that transfers information between the control device and a host over an isochronous communications medium, B. selectively applying shutter signals to the image sources to cause each of them to acquire image data, C. selectively applying readout signals to the image sources to cause each of them to output, for tansfer to the control device, the image data captured by that image acquisition device, D. transferring image data output by the image sources to the host over the communications medium, E. performing steps B and C so as (i) to cause the image acquisition devices to acquire image data substantially simultaneously with respect to one another, (ii) to cause the associated image acquisition devices to output the acquired image data independently with respect to one another, F. performing step D so as to transferred image data at a said device interface substantially immediately to the host interface, and buffering substantially no more image data than required to construct data packets from data received at a said device interface prior to output to the host interface.
  • 21. A method according to claim 20, comprising applying the shutter and readout signals to the plurality of image sources so as to effect sequential transfer to the host of images captured substantially simultaneously by the image acquisition devices.
  • 22. A method according to claim 21, comprising applying the shutter signals substantially simultaneously to the plurality of image sources and comprising applying the readout signals to those devices in a selected sequence.
  • 23. A method for controlling acquisition of images from a plurality of image acquisition devices, the method comprising:A. providing a hub including a plurality of device interfaces, each of which exchanges information with an associated one of the plural image acquisition devices, each of the plural image acquisition devices being responsive to an applied shutter signal to acquire a frame of image data and being responsive to an applied readout signal to initiate output of that frame of image data, wherein each image source does not acquire a new frame of image data prior to output of a previously acquired frame of image data, a host interface that exchanges information with a host over a communications medium that supports information transfers in accord with an IEEE 1394 standard, B. selectively applying shutter signals to the device interfaces to cause the associated image acquisition devices to acquire image data, C. selectively applying readout signals the device interfaces to cause the image acquisition devices to output image data acquired by them, D. transferring image data received at the device interfaces to the host interface for output to the host over the communications medium, E. performing steps B and C so as (i) to cause the image acquisition devices to acquire image data substantially simultaneously with respect to one another, (ii) to cause the associated image acquisition devices to output the acquired image data in a sequence with respect to one another F. performing step D so as to transferred image data at a said device interface substantially immediately to the host interface, and buffering substantially no more image data than required to construct data packets from data received at a said device interface prior to output to the host interface.
  • 24. A method according to claim 23 comprising operating in accord with instructions from the host.
  • 25. A method according to claim 23, comprising applying shutter and readout signals to the device interfaces to effect sequential output of image data by the plural image acquisition devices of images acquired substantially simultaneously by them.
  • 26. A hug according to claim 25, comprising applying the shutter signal substantially simultaneously to the plurality of image acquisition devices and comprising applying the readout signals to those devices in a selected sequence.
  • 27. A method for controlling acquisition of images from a plurality of image sources, the method comprising:A. providing a control apparatus including a plurality of device interfaces, each of which exchanges information with an associated one of the plural image sources, each of the plural image sources being responsive to an applied shutter signal to acquire a frame of image data and being responsive to an applied readout signal to initiate output of that frame of image data, wherein each image source does not acquire a new frame of image data prior to output of a previously acquired frame of image data, each device interface including a control line for transferring a shutter signal from the apparatus to the associated image source to cause it to capture an image, a host interface that exchanges information with a host over an isochonous communications medium, B. selectively applying shutter signals to the control lines to cause the associated image sources to acquire image data, C. selectively applying readout signals the device interfaces to cause the image sources to output image data acquired by them, D. transferring image data received at the device interfaces to the host interface for output to the host over the communications medium, E. performing steps B and C so as (i) to cause the image acquisition devices to acquire image data substantially simultaneously with respect to one another, (ii) to cause the associated image acquisition devices to output the acquired image data in a sequence with respect to one another F. performing step D so as to transferred image data at a said device interface substantially immediately to the host interface, and buffering substantially no more image data than required to construct data packets from data received at a said device interface prior to output to the host interface.
  • 28. A method according to claim 27, comprising transferring an applied shutter signal over a control line to the associated device substantially without delay.
  • 29. A method according to claim 28, wherein the control line comprises a communications medium independent of that over which the image data is transferred by the associated device interface.
  • 30. A method according to claim 29, comprising transferring the shutter signal to the associated image acquisition apparatus over a line independent of the line over which image data is transferred by the associated device interface.
  • 31. A method according to claim 27, comprising acquiring bandwidth on the communications medium.
  • 32. A method according to claim 27, comprising applying the first and readout signals to the plurality of image sources so as to effect sequential transfer to the host of images captured substantially simultaneously by the image acquisition devices.
  • 33. A method according to claim 32, comprising applying the shutter signals substantially simultaneously to the plurality of image sources and comprising applying the readout signals to those devices in a selected sequence.
  • 34. A method according to claim 27 comprising operating in accord with instructions from the host.
  • 35. A method according to claim 27, comprising transferring image data at a said device interface substantially immediately to the host interface.
  • 36. A method according to claim 35, comprising buffering substantially no image data received at a said device interface prior to output to the host interface.
  • 37. A method according to claim 27, comprising transferring information over the host interface in accord with an IEEE 1394 standard.
  • 38. A method according to claim 28, comprising transferring information over the host interface in accord with a Universal Serial Bus (USB) standard.
US Referenced Citations (213)
Number Name Date Kind
3816722 Sakoe et al. Jun 1974 A
3936800 Ejiri et al. Feb 1976 A
3967100 Shimomura Jun 1976 A
3968475 McMahon Jul 1976 A
3978326 Shimomura Aug 1976 A
4011403 Epstein et al. Mar 1977 A
4115702 Nopper Sep 1978 A
4115762 Akiyama et al. Sep 1978 A
4183013 Agrawala et al. Jan 1980 A
4200861 Hubach et al. Apr 1980 A
4254400 Yoda et al. Mar 1981 A
4286293 Jablonowski Aug 1981 A
4300164 Sacks Nov 1981 A
4385322 Hubach et al. May 1983 A
4435837 Abernathy Mar 1984 A
4441124 Heebner et al. Apr 1984 A
4441206 Kuniyoshi et al. Apr 1984 A
4519041 Fant et al. May 1985 A
4534813 Williamson et al. Aug 1985 A
4541116 Lougheed Sep 1985 A
4570180 Baier et al. Feb 1986 A
4577344 Warren et al. Mar 1986 A
4581762 Lapidus et al. Apr 1986 A
4606065 Beg et al. Aug 1986 A
4617619 Gehly Oct 1986 A
4630306 West et al. Dec 1986 A
4641349 Flom et al. Feb 1987 A
4688088 Hamazaki et al. Aug 1987 A
4706168 Weisner Nov 1987 A
4707647 Coldren et al. Nov 1987 A
4728195 Silver Mar 1988 A
4730260 Mori et al. Mar 1988 A
4731858 Grasmueller et al. Mar 1988 A
4736437 Sacks et al. Apr 1988 A
4742551 Deering May 1988 A
4752898 Koenig Jun 1988 A
4758782 Kobayashi Jul 1988 A
4764870 Haskin Aug 1988 A
4771469 Wittenburg Sep 1988 A
4776027 Hisano et al. Oct 1988 A
4782238 Radl et al. Nov 1988 A
4783826 Koso Nov 1988 A
4783828 Sadjadi Nov 1988 A
4783829 Miyakawa et al. Nov 1988 A
4809077 Norita et al. Feb 1989 A
4831580 Yamada May 1989 A
4860374 Murakami et al. Aug 1989 A
4860375 McCubbrey et al. Aug 1989 A
4876457 Bose Oct 1989 A
4876728 Roth Oct 1989 A
4891767 Rzasa et al. Jan 1990 A
4903218 Longo et al. Feb 1990 A
4907169 Lovoi Mar 1990 A
4912559 Ariyoshi et al. Mar 1990 A
4914553 Hamada et al. Apr 1990 A
4922543 Ahlbom et al. May 1990 A
4926492 Tanaka et al. May 1990 A
4932065 Feldgajer Jun 1990 A
4953224 Ichinose et al. Aug 1990 A
4955062 Terui Sep 1990 A
4959898 Landman et al. Oct 1990 A
4962423 Yamada et al. Oct 1990 A
4972359 Silver et al. Nov 1990 A
4982438 Usami et al. Jan 1991 A
5012402 Akiyama Apr 1991 A
5012524 LeBeau Apr 1991 A
5027419 Davis Jun 1991 A
5046190 Daniel et al. Sep 1991 A
5054096 Beizer Oct 1991 A
5060276 Morris et al. Oct 1991 A
5063608 Siegel Nov 1991 A
5073958 Imme Dec 1991 A
5081656 Baker et al. Jan 1992 A
5081689 Meyer et al. Jan 1992 A
5086478 Kelly-Mahaffey et al. Feb 1992 A
5090576 Menten Feb 1992 A
5091861 Geller et al. Feb 1992 A
5091968 Higgins et al. Feb 1992 A
5093867 Hori et al. Mar 1992 A
5113565 Cipolla et al. May 1992 A
5115309 Hang May 1992 A
5119435 Berkin Jun 1992 A
5124622 Kawamura et al. Jun 1992 A
5133022 Weideman Jul 1992 A
5134575 Takagi Jul 1992 A
5143436 Baylor et al. Sep 1992 A
5145432 Midland et al. Sep 1992 A
5151951 Ueda et al. Sep 1992 A
5153925 Tanioka et al. Oct 1992 A
5155775 Brown Oct 1992 A
5159281 Hedstrom et al. Oct 1992 A
5159645 Kumagai Oct 1992 A
5164994 Bushroe Nov 1992 A
5168269 Harlan Dec 1992 A
5179419 Palmquist et al. Jan 1993 A
5185810 Freischlad Feb 1993 A
5185855 Kato et al. Feb 1993 A
5189712 Kajiwara et al. Feb 1993 A
5206820 Ammann et al. Apr 1993 A
5216503 Paik et al. Jun 1993 A
5225940 Ishii et al. Jul 1993 A
5230027 Kikuchi Jul 1993 A
5243607 Masson et al. Sep 1993 A
5253306 Nishio Oct 1993 A
5253308 Johnson Oct 1993 A
5265173 Griffin et al. Nov 1993 A
5271068 Ueda et al. Dec 1993 A
5287449 Kojima Feb 1994 A
5297238 Wang et al. Mar 1994 A
5297256 Wolstenholme et al. Mar 1994 A
5299269 Gaborski et al. Mar 1994 A
5307419 Tsujino et al. Apr 1994 A
5311598 Bose et al. May 1994 A
5315388 Shen et al. May 1994 A
5319457 Nakahashi et al. Jun 1994 A
5327156 Masukane et al. Jul 1994 A
5329469 Watanabe Jul 1994 A
5337262 Luthi et al. Aug 1994 A
5337267 Colavin Aug 1994 A
5363507 Nakayama et al. Nov 1994 A
5367439 Mayer et al. Nov 1994 A
5367667 Wahlquist et al. Nov 1994 A
5371690 Engel et al. Dec 1994 A
5388197 Rayner Feb 1995 A
5388252 Dreste et al. Feb 1995 A
5398292 Aoyama Mar 1995 A
5432525 Maruo et al. Jul 1995 A
5440699 Farrand et al. Aug 1995 A
5455870 Sepai et al. Oct 1995 A
5455933 Schieve et al. Oct 1995 A
5471312 Watanabe et al. Nov 1995 A
5475766 Tsuchiya et al. Dec 1995 A
5477138 Efjavic et al. Dec 1995 A
5481712 Silver et al. Jan 1996 A
5485570 Bushboom et al. Jan 1996 A
5491780 Fyles et al. Feb 1996 A
5495424 Tokura Feb 1996 A
5495537 Bedrosian et al. Feb 1996 A
5500906 Picard et al. Mar 1996 A
5506617 Parulski et al. Apr 1996 A
5506682 Pryor Apr 1996 A
5511015 Flockencier Apr 1996 A
5519840 Matias et al. May 1996 A
5526050 King et al. Jun 1996 A
5528703 Lee Jun 1996 A
5532739 Garakani et al. Jul 1996 A
5539409 Mathews et al. Jul 1996 A
5544256 Brecher et al. Aug 1996 A
5548326 Michael Aug 1996 A
5550763 Michael Aug 1996 A
5553859 Kelly et al. Sep 1996 A
5557410 Huber et al. Sep 1996 A
5557690 O'Gorman et al. Sep 1996 A
5566877 McCormack Oct 1996 A
5568563 Tanaka et al. Oct 1996 A
5574668 Beaty Nov 1996 A
5574801 Collet-Beillon Nov 1996 A
5581632 Koljonen et al. Dec 1996 A
5583949 Smith et al. Dec 1996 A
5583954 Garakani Dec 1996 A
5586058 Aloni et al. Dec 1996 A
5592562 Rooks Jan 1997 A
5594859 Palmer et al. Jan 1997 A
5602937 Bedrosian et al. Feb 1997 A
5608490 Ogawa Mar 1997 A
5608872 Schwartz et al. Mar 1997 A
5640199 Garakani et al. Jun 1997 A
5640200 Michael Jun 1997 A
5642158 Petry, III et al. Jun 1997 A
5647009 Aoki et al. Jul 1997 A
5657403 Wolff et al. Aug 1997 A
5673334 Nichani et al. Sep 1997 A
5676302 Petry, III Oct 1997 A
5696848 Patti et al. Dec 1997 A
5715369 Spoltman et al. Feb 1998 A
5717785 Silver Feb 1998 A
5724439 Mizuoka et al. Mar 1998 A
5742037 Scola et al. Apr 1998 A
5751853 Michael May 1998 A
5754679 Koljonen et al. May 1998 A
5757956 Koljonen et al. May 1998 A
5761326 Brady et al. Jun 1998 A
5768443 Michael et al. Jun 1998 A
5784581 Hannah Jul 1998 A
5793899 Wolff et al. Aug 1998 A
5796386 Lipscomb et al. Aug 1998 A
5796868 Dutta-Choudhury Aug 1998 A
5801966 Ohashi Sep 1998 A
5805722 Cullen et al. Sep 1998 A
5809658 Jackson et al. Sep 1998 A
5818443 Schott Oct 1998 A
5825483 Michael et al. Oct 1998 A
5825913 Rostami et al. Oct 1998 A
5835622 Koljonen et al. Nov 1998 A
5845007 Ohashi et al. Dec 1998 A
5848189 Pearson et al. Dec 1998 A
5850466 Schott Dec 1998 A
5859923 Petry, III et al. Jan 1999 A
5861909 Garakani et al. Jan 1999 A
5872870 Michael Feb 1999 A
5878152 Sussman Mar 1999 A
5900975 Sussman May 1999 A
5901241 Koljonen et al. May 1999 A
5909504 Whitman Jun 1999 A
5912768 Sissom et al. Jun 1999 A
5912984 Michael et al. Jun 1999 A
5918196 Jacobson Jun 1999 A
5933523 Drisko et al. Aug 1999 A
5943441 Michael Aug 1999 A
6084631 Tonkin et al. Jul 2000 A
6105143 Kim Aug 2000 A
6356793 Martin Mar 2002 B1
6389029 McAlear May 2002 B1
Foreign Referenced Citations (11)
Number Date Country
0 527 632 Feb 1993 EP
0 777 381 Nov 1996 EP
WO 9521376 Aug 1995 WO
WO 9522137 Aug 1995 WO
WO 9721189 Jun 1997 WO
WO 9722858 Jun 1997 WO
WO 9724692 Jul 1997 WO
WO 9724693 Jul 1997 WO
WO 9852349 Nov 1998 WO
WO 9859490 Dec 1998 WO
WO 9915864 Apr 1999 WO
Non-Patent Literature Citations (20)
Entry
Grimson, W. Eric L. and Huttenlocher, Daniel P., “On the Sensitivity of the Hough Transform for Object Recognition”, May 1990, IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 12, No. 3.
Medina-Mora et al. (1981) An Incremental Programming Environment, IEEE Transactions on Software Eng. SE-7:472-482.
Teitelbaum et al. (19810 The Cornell Program Synthesizer: A Syntax-Directed Programming Environment, Communications of the ACM 24:563-573.
Newsletter from Acquity Imaging, Inc., “Remote Vision Support Package —The Phones Are Ringing!,” 1 page.
PictureTel Corporation Product Brochure “PictureTel Live PCS 100(tm) Personal Visual Communications System,” 3 pp. (1993).
PictureTel Corporation Product Brochure “PictureTel System 1000: Complete Videoconferencing for Cost Sensitive Applications,” 4 pp. (1993).
PictureTel Corporation Product Brochure, “PictureTel System 4000(tm) A Family of Models to Fit Your Applications from Offices to Boardrooms, Classrooms, and Auditorium,” 4 pp. (1993).
Symantec Corporation, “The Norton pcAnywhere User's Guide,” Table of Contents 8 pp; Introduction of pcAnywhere Technology pp i-vii; Chapter 7 —Sessions; pp. 191-240 (1991).
Bursky, Dave, “CMOS Four-Chip Set Process Images at 20-MHz Data Rates,” Electronic Design, May 28, 1987, pp. 39-44.
Plessey Semiconductors, Preliminary Information, May 1986, Publication No. PS2067, May 1986, pp. 1-5.
NEC Electronics Inc., PD7281 Image Pipelined Processor, Product Information Brochure, pp. 2-169-2-211.
Horn, Berthold Klaus Paul. “Robot Vision”, The Massachusetts Institute for Technology, 1986.
Racca Roberto G., Stephenson Owen, and Clements Reginald M. High-speed video analysis system using multiple shuttered charge-coupled device imagers and digital storage. Optical Engineering (Jun. 1992) 31;6.
Gevorkian David Z., Astola Jaakko T., and Atourian Samvel M. “Improving Gil-Werman Algorithm for Running Min and Max Filters” IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 19, No. 5, May 1997, pp. 526-529.
Gil, Joseph and Werman Michael. “Computing 2-D Min, Median, and Max Filters” IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 15, No. 5, May 1993, pp. 504-507.
Chapter 3: “Guidelines for Developing MMX Code,” Intel.
Chapter 4: “MMX Code Development Strategy,” Intel.
Chapter 5: “MMX Coding Techniques,” Intel.
Chapter 3: “Optimization Techniques for Integer Blended Code,” Intel.
Rosenfeld, Azriel. “Computer Vision: Basic Principles,”Proceedings of the IEEE. vol. 76, No. 8, Aug. 1988. pp. 863-868.