In some aspects, techniques for wireless signal decoding are described. In some instances, a number of superposition codes are computed based on a set of orthogonal binary codes. The set of orthogonal binary codes includes multiple subsets; each superposition code corresponds to one of the subsets and includes a combination of the binary codes in the corresponding subset. One of the subsets is selected based on a correlation between a wireless signal and the superposition code that corresponds to the subset. One of the binary codes is then selected from the selected subset based on a correlation between the wireless signal and the binary code. The wireless signal is decoded based on the selected binary code.
|
1. A method of decoding a wireless signal, the method comprising:
identifying superposition codes based on a set of orthogonal binary codes, the set comprising a plurality of subsets, each superposition code corresponding to one of the subsets and comprising a combination of the binary codes in the corresponding subset;
selecting a first subset of the plurality of subsets based on a correlation between a wireless signal and a first superposition code, the first superposition code corresponding to the first subset;
selecting a first binary code from the first subset based on a correlation between the wireless signal and the first binary code; and
decoding the wireless signal by operation of a data processor based on the first binary code.
9. A wireless signal processing system comprising:
a radio system configured to detect a wireless signal; and
a data processing system configured to perform operations comprising:
receiving the wireless signal from the radio system;
obtaining superposition codes based on a set of orthogonal binary codes, the set comprising a plurality of subsets, each superposition code corresponding to one of the subsets and comprising a combination of the binary codes in the corresponding subset;
selecting a first subset from the plurality of subsets based on a correlation between the wireless signal and a first superposition code, the first superposition code corresponding to the first subset;
selecting a first binary code from the first subset based on a correlation between the wireless signal and the first binary code; and
decoding the wireless signal based on the first binary code.
2. The method of
computing superposition code correlations between the wireless signal and the superposition codes, the superposition code correlations including the correlation between the wireless signal and the first superposition code;
selecting the first subset based on a peak in the correlation between the wireless signal and the first superposition code;
computing individual code correlations between the wireless signal and at least two of the binary codes in the first subset, the individual code correlations including the correlation between the wireless signal and the first binary code; and
selecting the first binary code based on a peak in the correlation between the wireless signal and the first binary code.
3. The method of
identifying, for the current iteration, a current subset of the binary codes;
dividing the current subset into two inspection subsets for the current iteration;
identifying superposition codes based on the two inspection subsets for the current iteration; and
based on correlations between the wireless signal and the superposition codes for the two inspection subsets, selecting one of the two inspection subsets as the current subset for the next iteration.
5. The method of
generating phased codes by applying a distinct phase to each binary code in the subset; and
summing the phased codes.
6. The method of
7. The method of
8. The method of
10. The wireless signal processing system of
computing superposition code correlations between the wireless signal and the superposition codes, the superposition code correlations including the correlation between the wireless signal and the first superposition code;
selecting the first subset based on a peak in the correlation between the wireless signal and the first superposition code;
computing individual code correlations between the wireless signal and at least two of the binary codes in the first subset, the individual code correlations including the correlation between the wireless signal and the first binary code; and
selecting the first binary code based on a peak in the correlation between the wireless signal and the first binary code.
11. The wireless signal processing system of
identifying, for the current iteration, a current subset of the binary codes;
dividing the current subset into two inspection subsets for the current iteration;
identifying superposition codes based on the two inspection subsets for the current iteration; and
based on correlations between the wireless signal and the superposition codes for the two inspection subsets, selecting one of the two inspection subsets as the current subset for the next iteration.
12. The wireless signal processing system of
13. The wireless signal processing system of
generating phased codes by applying a distinct phase to each binary code in the subset; and
summing the phased codes.
14. The wireless signal processing system of
15. The wireless signal processing system of
|
This specification relates to identifying a code for signal decoding.
Communication signals can be encrypted, orthogonalized, randomized, or otherwise manipulated using a large set of codes during transmission in a communication network. For example, scrambling codes can be used to distinguish the distinct transmitters of communication signals in a communication network. In the case of WCDMA uplink transmissions, users are assigned orthogonal scrambling codes derived from a very large set. A set can have a large number of codes (e.g., 224=16,777,216).
In a general aspect, a code is identified for decoding a wireless signal.
In some aspects, a method of decoding a wireless signal includes identifying multiple superposition codes based on a set of orthogonal binary codes. The set includes a number of subsets; each superposition code corresponds to one of the subsets and includes a combination of the binary codes in the corresponding subset. A first subset of the number of subsets is selected based on a correlation between a wireless signal and a first superposition code. The first superposition code corresponds to the first subset. A first binary code is selected from the first subset based on a correlation between the wireless signal and the first binary code. The wireless signal is decoded based on the first binary code.
In some aspects, a wireless signal processing system includes a radio system configured to detect a wireless signal and a data processing system. The data processing system is configured to obtain the wireless signal and superposition codes. The superposition codes are based on a set of orthogonal binary codes, and the set includes a number of subsets. Each superposition code corresponds to one of the subsets and includes a combination of the binary codes in the corresponding subset. A first subset is selected based on a correlation between the wireless signal and a first superposition code. The first superposition code corresponds to the first subset. A first binary code is selected from the first subset based on a correlation between the wireless signal and the first binary code. The wireless signal is decoded based on the first binary code.
The details of one or more implementations are set forth in the accompanying drawings and the description below. Other features, objects, and advantages will be apparent from the description and drawings, and from the claims.
Like reference symbols in the various drawings indicate like elements.
In some aspects of what is described here, a code is identified for signal decoding. A communication signal (e.g., a wireless signal transmitted over radio frequency (RF) spectrum or a wireline signal transmitted over copper, optical fiber, or other media) can be multiplied, encrypted, or otherwise manipulated with a code before transmission. The code can be selected from a large code set. To decode the received communication signal, the particular code used by the communication signal is identified. In some implementations, one or more of the example techniques described here can reduce the search space for identifying the code, and thus improve the efficiency and accuracy of the search.
In some implementations, a set of codes can be combined in such a way that a single search can yield results over numerous codes. Using the uplink WCDMA scenario as an example, 2,000 codes can be amalgamated within a single search in some instances. As such, the overall search space can be reduced, for example, from 16 million (224=16,777,216) to 8,000. The codes can be amalgamated in various ways depending on the application. For example, different phases and amplitudes can be applied to a given code or set of codes prior to combination, and yield different results depending on the intended performance metrics.
In some implementations, the combination of multiple orthogonal codes can be referred to as superposition, and the resulting combination of the set of codes can be referred to as a superposition code or a super-code. Once a certain superposition code has been confirmed to be present, an iterative search method can be implemented to use successive superposition codes (of decreasing size) to find the individual code, in some instances, in a maximum of log(n) steps, where n is the superposition depth of the current superposition code. Here, the superposition depth n represents the number of codes, out of the allowable code space of the communication system, that are combined to create one code in the super-code dictionary.
The superposition depth n can generally range from 1 to N, where N represents the total number of codes in the allowable code space of the communication system. If n=N, there would be only one super-code in the super-code dictionary; all signals would correlate and the super-code dictionary would have no discriminating ability. If n=1, the super-code dictionary would be equivalent to the allowable code space of the communication system, and no speedup would be obtained. A superposition depth between these two extremes (i.e., greater than 1 and less than N) can provide a tradeoff search space with the ability to discriminate codes and code-sets. In some cases, log(N/n) steps will be required to link a particular signal to a super-code, and log(N/n)+log(n) steps will be required to identify one particular code.
For example, an iterative binary search can be implemented to take a current set of orthogonal codes, split it into two halves (each has a half of the total number of orthogonal codes) and correlate both sets with the communication signal. The set with a higher correlation value can be selected as the winning set. The winning set can be further split into two halves and the above procedure can be repeated in a tree-like fashion, eventually leading to the code that was used to encode the communication signal.
In some implementations, the selected individual code can give higher noise resolution on the user and, thus, can allow extraction of precise signal-to-noise ratio (SNR) number of the user. In some implementations, the search time for the detection of a code can be reduced significantly. For example, in the monitoring of WCDMA uplink quality, one or more of the example techniques described here may help provide a more “real-time” view of users entering and leaving a network as well as detecting their specific impact on the overall network. This may include assessing the power control response, the spectral content, and many other metrics that can be attributed to a specific user in a given system.
In some implementations, the time difference of arrival (TDOA) of multiple users can be extracted from the sensor node, for example, by identifying a peak in the correlation result. Such ranging information can be used to cluster users within a certain geographical loci. The ranging information can also be used by multiple sensing nodes using triangulation to identify more precise user location. In some implementations, the magnitude of a correlation result can be used to identify the distance of a user from a sensing terminal. Such information can be combined with the knowledge of base station location to aid in the precise detection of the user location.
Although WCDMA is described as an example application, the techniques described here can be applied to other systems that use large sets of codes. In some instances, one or more of the example techniques described here can be used without dependence on a connection to either a user or base station. In some instances, one or more of the example techniques described here can offer a low-complexity search space without requiring a handshaking mechanism.
A base station 120 typically provides wireless service for multiple user equipment (e.g., smartphones, tablets, Internet-of-things devices, and other cellular-connected devices, etc.) in a broad region, for example, over an entire cell of a cellular network (e.g., a cellular voice network, cellular data network, etc.). The base station 120 can wirelessly transmit communication signals to the UE 105 in the downlink direction, and the multiple UEs 105 can transmit communication signals to the base station 120 in the uplink direction. The communication signals can be formatted according to a particular communication standard or protocol, for example, 2G standards such as Global System for Mobile (GSM) and Enhanced Data rates for GSM Evolution (EDGE) or EGPRS; 3G standards such as Code division multiple access (CDMA), Universal Mobile Telecommunications System (UMTS), and Time Division Synchronous Code Division Multiple Access (TD-SCDMA); 4G standards such as Long-Term Evolution (LTE) and LTE-Advanced (LTE-A); wireless local area network (WLAN) or WiFi standards such as IEEE 802.11, Bluetooth, near-field communications (NFC), millimeter communications; or multiple of these or other types of wireless communication standards. In some implementations, other types of communication (e.g., non-standardized signals and communication protocols) are used.
In some implementations, to distinguish the multiple UEs 105 served by the same base station 120, the uplink communication signals transmitted by each UE can be scrambled with a scrambling code. The scrambling code can be selected from a large set of orthogonal binary codes. Once the base station 120 receives the scrambled wireless signal, the base station 120 can de-scramble the received signal by searching over the entire set of scrambling codes to identify the particular scrambling code used by the UE 105 for decoding the received signal. In some cases, de-scrambling processes of the type shown in
In some implementations, a UE 105 can receive wireless signals transmitted from more than one base station 120. Similarly, to distinguish the multiple base stations, the signals transmitted by each base station 120 can be scrambled with a particular scrambling code. The UE can perform the example techniques to identify the particular scrambling code used by respective base stations for decoding the received downlink signals from the base stations.
Also shown in
The example wireless sensor devices 110 can monitor and analyze the RF spectrum at the respective locations, detect RF signals transmitted by the UE 105, and perform analyses of wireless communication services available at the associated geographic location. For instance, the wireless sensor device 110 can detect a wireless signal and decode the wireless signal formatted according to a wireless communication standard, such as, for example, any of the communication standards mentioned above. The example wireless sensor devices 110 can identify data packets and frames, and extract control information and traffic data of the detected wireless signal. For example, the wireless sensor device 110 can extract synchronization information, cells and services identifiers, and quality measurements of RF channels (e.g., channel quality indicator (CQI)), and derive spectral-usage parameters and other information based on these and other control information and traffic data of the wireless signal detected by the wireless sensor device 110.
In some implementations, in order to decode and analyze the detected wireless signal transmitted by a UE 105 or a base station, the wireless sensor device 110 can perform a decoding process to identify a particular scrambling code used by the particular UE 105 or the base station 120. For instance, the wireless sensor devices 110 may include processors or other computing hardware configured to perform on or more of the operations shown in
At 210, a wireless signal is received, for example, wirelessly by operation of a radio interface of a UE, a base station, a wireless sensor device, or other component of a communication system. The wireless signal can be a signal that has been encrypted, orthogonalized, or otherwise manipulated with a binary code. The binary code can be an individual code (e.g., a scrambling code, a spreading code, or another other type of code that is selected from a set of orthogonal codes) applied to the wireless signal before transmission. The binary code can be selected from a set or a pool of binary codes, for example, from the allowable code space of a wireless communication system. The binary code can be a series of binary values, where each value in the series is one of two possible values (e.g., selected from the set (0,1), the set (−1,1), or another binary set). In the example shown in
At 220, for the current iteration, a current set of binary codes is identified. For example, for the first iteration, the current set of binary codes can be the full or complete set of binary codes that the target binary code was selected from (e.g., the allowable code space of a wireless communication system. In some implementations, the number of binary codes included in the current set can decrease upon each iteration.
At 230, the current set is divided into a number of (e.g., N) inspection subsets (or groups) of binary codes for the current iteration. The number of binary codes in each inspection subset can be the same or different. In some implementations, the number of inspection subsets (i.e., the value of N) can vary or remain the same from iteration to iteration. For example, the number of inspection subsets can be larger in the first few iterations while becoming smaller in the later iterations. As an example, for the first iteration, the full set can be evenly divided into N=8000 subsets (e.g., as in the WCDMA example described above). In the remaining iterations, N can remain as 2, and each subsequent set can be evenly divided into 2 inspection subsets, where each subset has half of the number of binary codes of that of the previous subset.
At 240, a superposition code corresponding to each of the N inspection subsets can is computed. In some implementations, computing the superposition codes can include manipulation of a phase, amplitude, or both phase and amplitude of each binary code within the subset. For example, computing the superposition code corresponding to a subset can include generating phased codes by applying a distinct phase to each binary code in the subset, and summing the phased codes. The phased codes can be generated by applying a distinct phase and distinct amplitude to each binary code in the subset. Example processes for computing the superposition code are described below with respect to
I′=A(I*cos(a)−Q*sin(a)); and (1)
Q′=B(I*cos(a)+Q*sin(a)). (2)
In the example shown in Equations (1) and (2), I′ and Q′ represent the in-phase and quadrature components of the phased Code 0, respectively; and I and Q represent the in-phase and quadrature components of Code 0 (unphased), respectively. As shown in Equations (1) and (2), the phased Code 0 is obtained by shifting Code 0 by α in phase, scaling the in-phase component of Code 0 by A in amplitude, and scaling the quadrature component of Code 0 by B in amplitude. Similarly, for Code 1, as shown at 344,
I′=C(I*cos(b)−Q*sin(b)) (3)
Q′=D(I*cos(b)+Q*sin(b)) (4)
In Equations (3) and (4), I′ and Q′ represent the in-phase and quadrature components of phased Code 1, respectively; and I and Q represent the in-phase and quadrature components of Code 1 (unphased), respectively. As shown in Equations (3) and (4), phased Code 1 is obtained by shifting the Code 1 by b in phase, scaling the in-phase component of Code 1 by C in amplitude and scaling the quadrature component of Code 1 by D in amplitude.
Similarly, amplitude and phase manipulation are applied to Code 2 at 346, Code m at 348, etc. After the phase and amplitude manipulation, the multiple individual binary codes are summed together at 360a and result in a superposition code 370a for Group 1 (320a). Similar or different amplitude and phase manipulations can be applied to codes in other groups.
In some implementations, the values of phase shift (e.g., a, b, r) and amplitude change (e.g., A, B, C, D, . . . , X and Y) can be selected randomly or in various different ways. For example, the amplitudes can be random values while the phases can be equally spaced from 0 to 2*pi. In some implementations, such amplitude and phase manipulation can reduce or eliminate correlations that may exist that can cause the wireless signal to be limited. Additional or different functions can be applied to the phase and amplitude of each binary code in the inspection subset.
At 250, superposition code correlations between the wireless signal and the superposition codes are computed. The superposition code correlations can include the respective correlations between the wireless signal and the respective superposition codes of the inspection subsets. The correlation can be obtained, for example, based on a dot product or an inner product between the received signal and the superposition code. In some implementations, the correlation can be the normalized dot product (e.g., normalized by the magnitudes of the received signal and the superposition code). In some implementations, the superposition code correlation can be computed based on the covariance, correlation coefficient, or other indicators of dependence or other statistical relationships between the wireless signal and the superposition code.
For example, as shown in
At 260, a first subset can be selected based on a peak in the correlation between the wireless signal and the first superposition code of the first subset. In some implementations, among the N superposition code correlations, only one correlation has a peak in the correlation values. For example, as shown in
At 270, whether a first binary code is selected from the first subset as the target binary code can be determined. For instance, the first subset at the current iteration may contain only one individual binary code, and the only binary code in the first subset can be identified as the target binary code. As another example, the first subset at the current iteration may contain a small number of individual binary codes (e.g., less than 10, 100, etc.). Selecting the first binary code from the first subset can include computing individual code correlations between the wireless signal and each of the binary codes in the first subset and selecting the first binary code based on a peak in the correlation between the wireless signal and the first binary code. The example process 200 can then proceed to 280.
In some implementations, the first subset at the current iteration may contain a large number of individual binary codes (e.g., more than 10, 100, etc.). For instance, selecting an individual binary code from the large number of codes in the first subset may be computationally expensive. In such cases, the example process 200 can return to 220. The first subset (or another subset) can then be identified as the current set for the next iteration. The example process 200 can then proceed to 230 and repeat the iterative process until the target binary code is identified.
At 280, the wireless signal is decoded by operation of a data processor based on the first binary code. For example, the wireless signal can be de-scrambled or decrypted based on the first binary code and the transmitter of the wireless signal can be identified. In some implementations, additional or different operations, such as channel decoding and source decoding, can be performed on the wireless signal after applying the first binary code, for example, to recover the data information contained in the wireless signal.
A superposition code and a superposition correlation Ti (i=1, 2, . . . , G) can be computed for each of the G groups, for example, according to the example operations described with respect to 240 and 250 of the example process 200 or in another manner. When the superposition correlation contains peak values (denoted as “pos” in
Similar operations can be performed on Group G, where a binary search tree starts with root node 450 that includes the binary codes CNn+1, CNn+2, . . . , CNf. The binary search tree can include different levels of inspection subsets or vectors such as 460a and 460b, and 470a and 470b. The binary search tree can end, for instance, when the last level of inspection subset includes a single binary code.
In some implementations, only a single binary code among the G groups is identified as having a correlation including peak correlation values. In this case, the single binary code can be identified as the target binary code (or the first binary code at 270 of the example process 200). In some implementations, more than one binary code among the G groups can be identified as having correlations including peak correlation values. In this case, the correlations of these binary codes can be compared. In some implementations, the binary code with the maximum correlation values can be identified as the target binary code (or the first binary code at 270 of the example process 200). In some implementations, the target binary code can be selected from these binary codes based on other criteria.
Some of the operations described in this specification can be implemented as operations performed by a computer system, such as, for example, a computer system that includes one or more data processing apparatus that operates on data stored on one or more computer-readable storage devices or received from other sources. The term “data processing apparatus” encompasses all kinds of apparatus, devices, and machines for processing data, including by way of example a programmable processor, a computer, a system on a chip, or multiple ones, or combinations, of the foregoing. The apparatus can include special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit). The apparatus can also include, in addition to hardware, code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, a cross-platform runtime environment, a virtual machine, or a combination of one or more of them. The apparatus and execution environment can realize various different computing model infrastructures, such as web services, distributed computing and grid computing infrastructures.
A computer program (also known as a program, software, software application, script, or code) can be written in any form of programming language, including compiled or interpreted languages, declarative or procedural languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, object, or other unit suitable for use in a computing environment. A computer program may, but need not, correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code). A computer program can be deployed to be executed on one computing device or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a communication network.
Some of the processes and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform actions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computing device. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. A computing device typically includes a processor for performing actions in accordance with instructions and one or more memory devices for storing instructions and data. Generally, a computing device will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more storage devices for storing data. However, a computing device need not have such devices. Moreover, a computer can be embedded in another device, e.g., a mobile telephone, a personal digital assistant (PDA), a mobile audio or video player, a game console, a Global Positioning System (GPS) receiver, or a portable storage device (e.g., a universal serial bus (USB) flash drive), to name just a few. Devices suitable for storing computer program instructions and data include all forms of non-volatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
To provide for interaction with a user, subject matter described in this specification can be implemented on a computer having a display device, e.g., an LCD (liquid crystal display) screen for displaying information to the user and a keyboard and a pointing device, e.g., touch screen, stylus, mouse, etc., by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input. In addition, a computing device can interact with a user by sending documents to and receiving documents from a device that is used by the user; for example, by sending web pages to a web browser on a user's client device in response to requests received from the web browser.
Some of the subject matter described in this specification can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computing device having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described in this specification, or any combination of one or more such back-end, middleware, or front-end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a data network.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a data network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other. In some implementations, a server transmits data to a client device. Data generated at the client device can be received from the client device at the server.
While this specification contains many details, these should not be construed as limitations on the scope of what may be claimed, but rather as descriptions of features specific to particular examples. Certain features that are described in this specification in the context of separate implementations can also be combined. Conversely, various features that are described in the context of a single implementation can also be implemented in multiple embodiments separately or in any suitable sub-combination.
A number of examples have been described. Nevertheless, it will be understood that various modifications can be made. Accordingly, other embodiments are within the scope of the following claims.
Omer, Mohammad, Devison, Stephen A.
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
6507602, | Jan 07 1999 | Ericsson, Inc. | Smoothing receiver channel estimates using spectral estimation |
7440489, | Aug 07 2001 | Ericsson Inc. | Method and apparatus for selective demodulation and decoding of communications signals |
7965761, | Feb 12 1998 | Genghiscomm Holdings, LLC | Multicarrier sub-layer for direct sequence channel and multiple-access coding |
8175068, | Mar 26 2008 | Advanced Receiver Technologies, LLC | Active spread code detection |
8488578, | Sep 27 2010 | Rockwell Collins, Inc; Rockwell Collins, Inc. | Identifying a CDMA scrambling code |
8761127, | Apr 24 2006 | Qualcomm Incorporated | Superposition coding in a wireless communication system |
8873605, | Mar 15 2012 | Commissariat à l'énergie atomique et aux énergies alternatives | Method of blind estimation of a scrambling code of a WCDMA uplink |
8913686, | May 07 2010 | Yale University | Sparse superposition encoder and decoder for communications system |
20110310935, | |||
20120320730, | |||
20140308972, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Aug 18 2015 | OMER, MOHAMMAD | COGNITIVE SYSTEMS CORP | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 036478 | /0527 | |
Sep 01 2015 | DEVISON, STEPHEN A | COGNITIVE SYSTEMS CORP | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 036478 | /0527 | |
Sep 02 2015 | Cognitive Systems Corp. | (assignment on the face of the patent) | / | |||
Dec 21 2017 | COGNITIVE SYSTEMS CORP | 2606440 ONTARIO LIMITED | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 044997 | /0763 | |
Dec 31 2017 | 2606440 ONTARIO LIMITED | COGNITIVE SYSTEMS CORP | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 045405 | /0209 |
Date | Maintenance Fee Events |
Dec 20 2018 | BIG: Entity status set to Undiscounted (note the period is included in the code). |
Aug 08 2019 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Aug 09 2023 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Feb 23 2019 | 4 years fee payment window open |
Aug 23 2019 | 6 months grace period start (w surcharge) |
Feb 23 2020 | patent expiry (for year 4) |
Feb 23 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
Feb 23 2023 | 8 years fee payment window open |
Aug 23 2023 | 6 months grace period start (w surcharge) |
Feb 23 2024 | patent expiry (for year 8) |
Feb 23 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
Feb 23 2027 | 12 years fee payment window open |
Aug 23 2027 | 6 months grace period start (w surcharge) |
Feb 23 2028 | patent expiry (for year 12) |
Feb 23 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |