Content delivery networks employ a variety of different transmission modes. For example, networks can employ broadcast, satellite, cable, and/or the Internet and IP-based transmissions. Each of these transmissions can have physical or practical limitations and may operate using different transmission formats and protocols. Within each transmission medium, various types of information can be sent or received, including audio, video, audiovisual, telephony, or other forms of data. Additional complications can arise because a single service provider may employ multiple delivery networks simultaneously, such as a legacy network in combination with a fiber-based IP (internet protocol) system.
Typically, several different devices would be needed to process and handle content delivered through these different networks and transmission modes. The expense and maintenance of equipment for each of these functions can be burdensome. This multiplication of devices is compounded for certain enterprise customers that centrally manage services provided for many end-user points, such as hotels, educational institutions, multifamily housing, commercial buildings, hospitals, airports, or other multiple-dwelling units.
Enterprise customers may also desire to combine many different transmission modes for local delivery to its managed network using a smaller number of transmission modes and/or different transmission modes. For example, over-the-air television content could be combined with a network cable feed delivered over a hybrid-fiber network, with subsequent delivery over coaxial cable within the enterprise customer's network. A further complication is that both input and output may be subject to encryption or decryption problems. Enterprise customers may have additional desires to insert locally-generated programming into the content delivered into its network, such as local advertising, custom directory or guide information, or coverage of events occurring on the premises. All of these variations could require further additional equipment to implement.
The present disclosure provides a powerful fully two-way platform that is adaptable to any enterprise service application. A gateway may be constructed from a chassis that is populated with appropriate processing or service modules to target the detailed requirements for each application. Subscription or network changes affecting the enterprise customer can be accommodated by reconfiguration of existing modules, replacement of existing modules with new modules, or installation of new modules.
An enterprise content gateway includes a passive backplane configured to receive a plurality of service modules, a power module, and a control module. The backplane transfers power and provides data transfer connections between service modules and the control module. Service modules include an input module configured to demodulate a signal to provide a transport stream to the backplane and an output module configured to receive transport streams from the passive backplane and produce a modulated signal. The control module includes a webserver hosting a remotely-accessible control interface, sends control data to the other modules, and receives monitoring data and transport streams from the other modules. The control module identifies programs from the transport streams to create a channel lineup and generates output instructions. In one implementation, the control module is also adapted to receive a content feed from an external IP port, and may include programs from the content feed in the channel lineup and output instructions. Output instructions and the streams including the selected programs are routed to the output module which assembles an output stream based on the instructions. Optionally, the control module can create multiple channel lineups for delivery through distinct output modules.
An enterprise content gateway may adapt to changes in the installed modules and configurations with minimal service interruptions. A newly-installed module sends an initialization message to the control module, which is compared to a system configuration plan. The system configuration plan may be stored in memory or received or updated from the control interface. The control module sends a control message to the service module with instructions for processing a transport stream according to the system configuration plan. The system configuration plan may be modified from the control interface, and the control module identifies service modules affected by the modification and propagates new control messages accordingly.
The enterprise content gateway also provides for improved communications with an external network. The gateway may collect data packages from multiple devices within the enterprise network and aggregate those into more aggregated packages that are transmitted through a single interface of the enterprise gateway. When used with an external network communicating with RF signals, the gateway substantially reduces the noise contribution that individual devices in the enterprise network would otherwise add to the external network. The gateway therefore enables various expanded and extended network architectures.
The disclosure also relates to automatically detecting and recovering from errors in a enterprise gateway setting. A system may load a system configuration plan with information about the expected number and types of input signals and receive an input from a service module. A signal status may be determined by comparing the input to the system configuration plan. Errors in cryptographic processes may also be detected. Errors of multiple types are reported and the system identifies unused resources which are available to correct the error(s). If an error persists, the spare resources may be deployed to correct the errors and return the system to operations conforming with the system configuration plan.
Other aspects of the disclosure relate to the detection and correction of cryptographic errors in a conditional access system. Without compromising security, a cryptographic engine may provide for a polling or query interrogation for information relating to its key exchanges and communications. In response to the interrogation, the cryptographic engine reports a record of its communications with the conditional access system. The record is evaluated against predefined rules and/or prior records for the detection of errors in key negotiations or storage prior to a cryptographic failure. Upon detecting the errors, a control message is sent to the cryptographic engine to restart and/or reauthenticate and renegotiate key information with the conditional access system. The restart may be delayed to minimize loss of service to downstream users.
As shown in
Modules 130, 140, 150 can be constructed such that no external connections are required from the rear of the device. For example, in
Control module 130 is in communication with all other modules, such as service modules 140 in
Power module 150 features two power supply sockets 152 for redundant, independent power sources, and transfers power to the other modules through backplane 120. The gateway may be implemented with dual power supplies, each with sufficient capacity to supply the other modules. Redundant power supplies may be equipped with auto-failover features to prevent outages or service interruptions. Power module 150 may be equipped with a dedicated fan unit 156 for heat dissipation. Power module 150 may be configured to report monitoring or alert information to control unit 130 via interconnects 122 and data paths 124, such as an alert when one power supply fails or is disconnected and an auto-failover event occurs. Control unit 130 may be configured to evaluate the monitoring and alert information and, as needed, automatically order service or relay information to the control interface or a remote monitor.
As shown most clearly in
Repair operations can be accomplished while the gateway 1 continues to process signals and route content so that enterprise users do not lose service unless the sensed temperature reaches an unacceptable level before the fan assembly 164 is replaced. The speed of removal and reinstallation avoids adverse temperature effects on the hardware in modules 130, 140, 150. As shown in
In
Illustrated in
Service modules 140 are usually “hot-swappable,” meaning that they can be replaced without powering down other components of the gateway and minimize any loss of service associated with replacement. Likewise, the system can be reconfigured so that the hot-swappable service modules are immediately reassigned to process data according to a new configuration. Upon installing a service module 140, the service module may send an initialization message to the control module. An initialization message may include identification, capacity, type, and status information for the service module. Information from the initialization message may be communicated to and displayed on the control interface. The control module compares the initialization message to a stored system configuration plan. If the service module is compatible with the processing needs of the plan, then the module may be placed into service. The control module may send a control message to the service module including instructions for processing data based on the system configuration plan. Instructions for processing data will typically relate to a transport stream according to the various types of modules discussed in detail below, and control module may route a transport stream to the service module for handling. If the service module is compatible with the plan but there are other resources already providing the compatible functions, the service module may be designated a “hot spare” as discussed further below. Alternately, the compatible service module may reduce the load on the previously-functioning module performing the same function. Thus, excess processing capacity may be provided to enhance services within the enterprise network, for example, by providing higher-quality content. A user may request to modify the system configuration plan using the control interface. In response to such a request, the control module may modify the stored system configuration plan and identify one or more service modules affected by the request, for example by comparing the newly stored configuration plan to the previously-stored configuration plan.
The control interface of the control module is configured to communicate with the module-specific webserver, and provides a central authentication system for command-and-control of the individual modules. The control interface will receive and recreate the module-specific control interface from the module-specific webserver. When a change to a configuration is recorded in the control interface, the control module may identify each affected service module and send control data communicating the change. The control module webserver may receive monitoring data and/or alerts from each respective module-specific webserver, which may be available through or displayed in the control interface.
Returning to
Input service modules are provided in a variety of types based on the incoming signals that will require processing. One example is a QAM input module, which is adapted to receive QAM-modulated signals through a coaxial cable connected through the front of the module and further configured to demodulate such signals to digital transport streams that can be provided to other modules via the backplane 120. A QAM input module includes multiple full-band-capture QAM tuners. Optionally, a QAM input module may include a cryptographic engine that decrypts digital channels as part of a conditional access system, such as the CableCARD™ system that is commercially available. Each QAM input module may be outfitted with multiple, multi-stream decryption cards (referred to as an “M-CARD”), each of which is capable of decoding up to six channels simultaneously. Each M-CARD may be received in a physical pocket on the blade that provides data connectivity with the blade. In one implementation, the blade may be equipped with four pockets, each capable of receiving an M-CARD, for a total of twenty-four simultaneous program decryptions. In response to instructions received from the control module 130, the blade may route demodulated data through the pocket and corresponding cryptographic engine for decryption to an unencrypted transport stream. Although the QAM input module may be adapted to support use of a cryptographic engine, it may be configured to process data without using that function. For example, in response to instructions received from control module 130, the blade can bypass a given pocket and provide a transport stream to the backplane without applying any decryption. Alternatively, a pocket could be filled with a dummy or relay card that simply transfers data back to the blade without applying a cryptographic function.
Another input module type is an ATSC input module. The ATSC input module is adapted to receive 8VSB-modulated signals such as broadcast signals from an external antenna that is connected to the front of the module via a coaxial cable. The ATSC input module is configured to demodulate such signals to digital transport streams that can be provided to other modules via the backplane 120. In one implementation, the ATSC input module is equipped with four independent tuners that can simultaneously demodulate four input signals for further processing. Each ATSC signal includes Program and System Information Protocol (P SIP) tables that include metadata about the programs in the transport stream, such as channel information and electronic program guide information. The ATSC tuner may be configured to provide PSIP data along with the transport stream to the backplane for further processing or delivery through an output module. Optionally, PSIP data may be processed separately for creation of a customized channel line-up and/or customized electronic program guide.
Another input module type is a satellite input module, which is adapted to receive a modulated signal from an external satellite receiver connected through the front of the module and further configured to demodulate such signals to digital transport streams that can be provided to other modules via the backplane 120. A satellite input module may be configured to process either or both of 8PSK- or QPSK-modulated signals.
Another input module type is a local input module, which may be adapted to receive a high-definition program or other content from one of several inputs on the front of the module, and configured to deliver a transport stream to the backplane 120. Locally-generated content can be utilized in variety of ways. For example, locally-generated content can be continuously delivered to the backplane for use in a dedicated program/channel for delivery within the enterprise network. Examples of such uses could be a hotel directory and service information, a campus television or radio station, an advertising vehicle, or live transmission of nearby events. Locally-generated content could be queued in memory for discrete delivery. Local input module may be configured to store one or more locally-generated programs received from the inputs in a buffer or carousel, and subsequently play out one or more of such programs in response to a request from control module 130. For example, local advertising can be inserted into content streams to augment or overwrite other portions of programs as they are delivered within the enterprise network.
Service modules may also be in the form of output-generating modules, such as a QAM output module. The QAM output module is configured to receive output instructions from the control module and transport streams via the backplane and assemble an output transport stream based on the output instructions. Optionally, QAM module may also include a digital up-converter and/or digital IP-to-QAM converter functionality for enhanced processing of the received transport streams. The output transport stream can then be modulated to an output signal that is transmitted through, for example, a coaxial connection on the front of the QAM module. In implementations, the QAM output module may generate thirty-two (32) QAM-256 or sixty-four (64) QAM-256 carriers, depending on application needs.
Another type of service module is a DOCSIS module compatible the DOCSIS 3.1 and/or Full Duplex DOCSIS 3.1 suite of specifications. A DOCSIS module may be configured to receive output instructions from the control module and transport streams via the backplane and assemble an output transport stream based on the output instructions, and may have enhanced processing functions such as those described above for the QAM output device. The output transport stream can then be modulated to an output signal that is transmitted through, for example, a coaxial connection. In implementations, the DOCSIS module may generate QAM-4096 carriers utilizing Orthogonal Frequency Division Multiplexing (OFDM). The DOCSIS module may also be adapted to receive modulated signals compliant with the DOCSIS 3.1 specifications through a coaxial cable connected through the front of the module and further configured to demodulate such signals to digital transport streams that can be provided to other modules via the backplane 120.
Another service module type is an IP module, which is adapted to send and receive data from an Internet Protocol (IP-based) network, such as the Internet or a Local Area Network (LAN), through an IP port 143 of
Service modules may also include cryptographic modules to encrypt or decrypt transport streams separately from any particular input or output module. A cryptographic module may be configured to add encryption at the transport stream level, for example up to sixty programs using the commercially available Pro:Idiom system. An encrypted transport stream is then redelivered to the backplane for further processing, and the encrypted transport stream can thereafter be delivered within the enterprise network via multiple output modules or formats, such as IP and QAM outputs, or, as described above, as part of different program packages delivered to different subnetworks of the enterprise. A cryptographic module can also be in the form of a Digital Rights Management (DRM) module. The DRM module may be configured to act as a client managing a variety of content permissions and device verifications using multiple DRM systems and protocols.
Service modules 140 may also include a guide module which is configured to process guide information from a variety of sources and provide a custom program guide for the enterprise's channel lineup. For example, a guide module may be equipped with an IP port input that receives electronic program guide (EPG) data from an external network. The guide module may also be configured to extract PSIP-EPG data from a transport stream available through the backplane, or may be provided PSIP-EPG data independently of transport stream. Either of these sources or both can be inserted into a content transport stream as a supplement or replacement to any guide data already included in the stream. The guide module may also be configured to use EPG data to generate an audiovisual program describing and displaying the content of the EPG guide data. For example, the available program titles and descriptions can be displayed in a scrolling or flip-page chart that is then converted to a program in a transport stream that is delivered to other modules via the backplane. Alternately, the visual guide can be generated and superimposed on or combined with video from another program, such as for example locally-generated content described above. The visual guide program can be customized to include images, advertisements, or specific styling such as fonts and colors according to the preferences of the enterprise customer.
Modules of several different types may be combined to provide various services in an enterprise network. For example,
External IP network 616 can function as both an input to and output from the gateway 1, depending on the delivered services, and can do so simultaneously. For example, IP network 616 may provide audiovisual programming which can be decoded by IPTV module function 626 to provide additional transport streams 636 to routing functions 650. IP network 616 may also provide two-way communications through enterprise modem function 627, such that individual end user devices within the enterprise network 690 receive customized data services 637. Data services 637 may include essentially any IP traffic, such as general Internet traffic, video-on-demand (VOD) services, or over-the-top (OTT) services. The IP network 616 may also provide information specifically to gateway 1 that is not for delivery to end user devices. As a specific example, guide modem function 628 may receive guide data 638 from IP network 616. Control interface 629 may send and receive management and monitoring information 639 over an external IP network 616 or a local delivery 619. In accordance with the various input modules available having different physical network connections, IP network data 616 may be received over various forms, such as fiber, small form-factor pluggable, Ethernet, or coaxial cable. Again, cryptographic processing and/or digital rights management (DRM) functions can be applied to any of the sources as required by the content provider.
The central routing function 650 handles both transport streams and IP data. Routing function 650 receives management information 639 such as system configurations and module-specific configurations and settings through communications with control interface 639. Routing function 650 provides transport streams to output functions along with instructions for processing. For example, transport streams 672 may be sent to an encrypted modulator 682 while transport streams 674 may be sent to modulator 684 for delivery without an additional encryption step. Along with the streams, modulator functions 682, 684 receive instructions for which programs from the streams to include in outputs 692 and 694, respectively, and are configured to select packets from the streams 672, 674 corresponding to programs identified in the instructions. Bandwidth on output signals 682 and 684 may therefore be conserved, and subscription limits may be enforced, as unauthorized programs can be eliminated from the signals that are delivered within the enterprise network 690. Modulator functions 682, 684 may also be equipped with additional functionality, such as upconversion and transcoding, as may be suitable to a particular installation.
Routing function 650 sends and receives user IP data 678 to and from cable modem termination system (CMTS) function 688 for delivery over IP output 698 within the enterprise network 690. User IP data 678 can include transport stream programs 636 that were received from an IP source for delivery, but may also include programs from non-IP sources such as satellite, cable, or broadcast streams (632, 633, 634, respectively). User IP data may also include data service 637 such as VOD and OTT programming, as well as general Internet traffic. CMTS function 688 may provide IP outputs with or without additional encryption or DRM protections, according to user configurations. CMTS may also be configured to relay user data from enterprise network 698 back upstream as part of user IP data 678 for subsequent processing and routing through function 650.
Also illustrated in
Variations of the installation described in
Referring to
Referring to
As seen in
The flexible enterprise gateway system also implements robust error detection, handling, and recovery processes to minimize service interruptions. Illustrated in
Referring to
A cryptographic engine 810 and conditional access system protocol may provide for interrogation of the engine 810. In response to a query or poll in step 820, cryptographic engine 810 will report a record 835 relating to its key communications in step 830. Although key data 805 may not be reported, the report may indicate when the key data was last updated, or how many times the engine has communicated with the conditional access system, such as, for example, that communications relating to key data have occurred two times in the past twenty-four hours. In an extreme example, the cryptographic engine may report that it has never been in communication with the conditional access system. These records can indicate an error state in the engine. However, such an error may be limited to the engine's memory and/or communications with the conditional access system, as discussed above, and the cryptographic engine may continue to function properly prior to expiration of the key. Upon detecting an error state in step 850, a control message 865 can be sent to the cryptographic engine 810 to instruct it to restart, reinitialize and/or reauthenticate with the conditional access system. When the key communication error is detected prior to cryptographic failure, restarting the engine can be scheduled or delayed to minimize service interruptions to the enterprise customer and/or end user devices in the enterprise network in optional step 860. For example, the restart can be delayed to a predefined time, such as the middle of the night. A low usage time may also be determined by a monitoring process 854, and the automatic restart can be delayed until a usage communication 855 is received from the monitoring process 854.
In step 850, the record of key communications can be evaluated to detect an error state prior to the cryptographic failure in several ways. For example, the record can be compared to predefined rules in step 851. One rule, as noted above, could require a restart if the cryptographic engine reports that it has no record of key communications. Another rule could require a restart if the record reflects that the communications fall below a certain frequency threshold. The frequency threshold may be set based on the particular conditional access system employed, or could be predefined threshold subject to adjustment through the control interface. Optionally, after polling the cryptographic engine, a control process may store the record of key communications in step 840. The control process may periodically interrogate the engine, such that a new record of key communications is received. The new record may be compared to the stored record to determine a state of the engine in step 853. For example, if the new record indicates a drop in the frequency of communications relative to the prior record, an error state may be detected. Alternately, if inconsistencies are detected between the records such as, for example, the key communications are recorded as being received at different times, an error state may be detected. As a further option, a predefined rule may require a periodic automatic restart of the engine. Such a scheduled restart may prevent sudden failures as described above, and may be used in combination with the other error detection techniques described herein. Predefined rules and stored record comparisons may be used in the alternative or in combination, and may be further subject to a hierarchical or prioritized ordering or weighting in evaluating the state of the cryptographic engine.
Returning to
Recovery step 730 continues with the identification of hot spares in step 734. Hot spares may be used to supply additional resources and potentially recover the signal. Due to the modular nature of gateway 1, an installation may be configured with excess capacity relative to a particular application. All excess resources are considered “hot spares” for purposes of the recovery process. For example, a redundant set of QAM input modules may be installed. As another example, a cryptographic module may have unused processing resources. Hot spares may be identified by comparing the loaded system configuration 711 to the installed modules and their assigned data load relative to their processing capacity. Alternatively, hot spares may be identified by polling service modules. Optionally, the process 734 for identifying hot spares is executed during the configurable time period for waiting in step 732. Then, once the time period expires, a compatible hot spare resource can immediately be dispatched to acquire or correct the signal in step 736.
After recovery steps 730, the source manager function 700 proceeds to diagnostic step 740. The original (failed) signal source may be identified as needing maintenance in step 741 and reported to control interface 715. However, not all failures will require maintenance. For example, loss of physical layer link such as Ethernet indicates a hardware failure requiring maintenance, as is loss of RF peak-signal-to-noise ratio (PSNR) below a specified threshold for a specified time, where both the threshold and the time are user configurable. An operator may also manually designate the source as needing maintenance or field service through the control interface 715 in step 743. Conversely, maintenance may not be necessary if a module restart is in progress, or a PSNR is fluctuating (which may indicate a temporary obstruction). For example, if a cryptographic engine reestablishes authentication into a conditional access system, as described above, no additional maintenance is necessary. If the failed source is determined as not requiring maintenance, it may be designated as a hot spare 735 for future use in step 745.
This application is a continuation of International Patent Application No. PCT/US2017/025114, filed Mar. 30, 2017, which is hereby incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
5680457 | Bestler et al. | Oct 1997 | A |
6490727 | Nazarathy et al. | Dec 2002 | B1 |
6611867 | Bowman-Amuah | Aug 2003 | B1 |
6640239 | Gidwani | Oct 2003 | B1 |
6650624 | Quigley et al. | Nov 2003 | B1 |
7039048 | Monta et al. | May 2006 | B1 |
7058559 | Roeck et al. | Jun 2006 | B1 |
7149223 | Liva et al. | Dec 2006 | B2 |
7592912 | Hasek et al. | Sep 2009 | B2 |
7688828 | Chapman et al. | Mar 2010 | B2 |
7746878 | Cha | Jun 2010 | B2 |
7787439 | Oz et al. | Aug 2010 | B1 |
7934228 | Miner | Apr 2011 | B2 |
7954131 | Cholas et al. | May 2011 | B2 |
8239913 | Munsell et al. | Aug 2012 | B2 |
8345778 | Kennedy et al. | Jan 2013 | B2 |
8472871 | Barroso | Jun 2013 | B2 |
8503447 | Lee et al. | Aug 2013 | B2 |
8584255 | Barry et al. | Nov 2013 | B2 |
8619822 | Munsell et al. | Dec 2013 | B2 |
8792336 | Barroso | Jul 2014 | B2 |
8804499 | Barroso | Aug 2014 | B2 |
8863201 | Brooks et al. | Oct 2014 | B2 |
8875190 | Barroso | Oct 2014 | B2 |
8973058 | Barroso | Mar 2015 | B2 |
9027062 | Patel et al. | May 2015 | B2 |
9055316 | Munsell et al. | Jun 2015 | B2 |
9094732 | Lerner et al. | Jul 2015 | B2 |
9131283 | Patel et al. | Sep 2015 | B2 |
9319755 | Fusco et al. | Apr 2016 | B2 |
9357247 | Cronk et al. | May 2016 | B2 |
9398336 | Markley et al. | Jul 2016 | B2 |
9461758 | Barroso | Oct 2016 | B2 |
9479834 | Elstermann et al. | Oct 2016 | B2 |
9509396 | Petrovic et al. | Nov 2016 | B2 |
9531760 | Lajoie et al. | Dec 2016 | B2 |
20020056125 | Hodge et al. | May 2002 | A1 |
20020129379 | Levinson et al. | Sep 2002 | A1 |
20020159513 | Williams et al. | Oct 2002 | A1 |
20040045032 | Cummings et al. | Mar 2004 | A1 |
20040244049 | Hahin et al. | Dec 2004 | A1 |
20040250059 | Ramelson et al. | Dec 2004 | A1 |
20060085727 | Azenkot et al. | Apr 2006 | A1 |
20070217436 | Markley et al. | Sep 2007 | A1 |
20080120667 | Zaltsman | May 2008 | A1 |
20080170853 | Rakib et al. | Jul 2008 | A1 |
20090025042 | Lubbers et al. | Jan 2009 | A1 |
20090232077 | Krieger et al. | Sep 2009 | A1 |
20100131980 | Rodriguez | May 2010 | A1 |
20100177750 | Essinger | Jul 2010 | A1 |
20100180291 | Kahn et al. | Jul 2010 | A1 |
20100239025 | Veljkovic et al. | Sep 2010 | A1 |
20100325670 | Strong et al. | Dec 2010 | A1 |
20110059690 | Petruzzelli | Mar 2011 | A1 |
20110093900 | Patel et al. | Apr 2011 | A1 |
20110107404 | Ramsdell et al. | May 2011 | A1 |
20110191797 | Lee et al. | Aug 2011 | A1 |
20120163290 | Krafft et al. | Jun 2012 | A1 |
20130151646 | Chidambaram et al. | Jun 2013 | A1 |
20130177154 | Hill-Jowett | Jul 2013 | A1 |
20130203338 | Ling et al. | Aug 2013 | A1 |
20140006667 | Sun | Jan 2014 | A1 |
20140020019 | Carter et al. | Jan 2014 | A1 |
20140053017 | Bartlett et al. | Feb 2014 | A1 |
20140075468 | Lee et al. | Mar 2014 | A1 |
20140281481 | Moroney | Sep 2014 | A1 |
20140282785 | Bowler et al. | Sep 2014 | A1 |
20140341109 | Cartmell et al. | Nov 2014 | A1 |
20140373076 | Lerner et al. | Dec 2014 | A1 |
20150020134 | Bowler et al. | Jan 2015 | A1 |
20160011894 | Reddy et al. | Jan 2016 | A1 |
20160134459 | Zaltsman et al. | May 2016 | A1 |
20160156941 | Alao et al. | Jun 2016 | A9 |
20160174129 | McNamee et al. | Jun 2016 | A1 |
20160294476 | Sun et al. | Oct 2016 | A1 |
20160381431 | Patterson et al. | Dec 2016 | A1 |
20170019689 | Ahmad | Jan 2017 | A1 |
20170054698 | Garcia | Feb 2017 | A1 |
20170055013 | Hasek et al. | Feb 2017 | A1 |
Number | Date | Country |
---|---|---|
WO 2016160262 | Oct 2016 | WO |
Entry |
---|
Search report and Written opinion dated Aug. 3, 2017, PCT Application No. PCT/US2017/025114. |
Number | Date | Country | |
---|---|---|---|
20180288829 A1 | Oct 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/US2017/025114 | Mar 2017 | US |
Child | 15722643 | US |