A method and apparatus for selecting a coding mode are described. For example, the method receives at least one block of a signal to be encoded. The method determines a frame vertical pixel difference in the at least one block and determines a field vertical pixel difference in the at least one block. The method then compares the frame vertical pixel difference with the field vertical pixel difference to determine a first coding mode for the at least one block.
|
3. A method for selecting a frame/field coding mode per intra picture, the method comprising:
performing intra prediction for blocks within the intra picture in both frame and field coding modes;
determine a minimum cost for each of the blocks in the frame coding mode;
determining a minimum cost for each of the blocks in the field coding mode;
determining a minimum frame coding cost for the intra picture by summing the minimum frame costs of the blocks within the intra picture;
determining a minimum field coding cost for the intra picture by summing the minimum field costs of the blocks within the intra picture;
selecting a frame coding mode for encoding the intra picture if the minimum frame cost of the picture is less than the minimum field cost of the intra picture, else selecting the field coding mode for the intra picture.
4. A method for selecting a coding mode per inter picture, the method comprising:
performing motion estimation (me) in both frame and field coding modes for blocks within the inter picture;
determining a minimum me cost for each of the macroblocks in the inter picture in both the frame and field coding mode;
determining a minimum me cost for each of the blocks in the field coding mode; and
determining a minimum frame coding cost for the inter picture by summing all of the minimum frame me costs of the blocks over the inter picture;
determining a minimum field coding cost for inter picture by summing all of the minimum field me costs of the blocks over the inter picture;
selecting a frame coding mode for encoding the inter picture if the minimum frame cost is less than the minimum field cost, else selecting the field coding mode for the inter picture.
1. A method for selecting a frame/field coding mode per frame picture, the method comprising:
receiving a frame picture of a signal to be encoded;
determining a sum of an absolute frame vertical pixel difference over the frame picture according to:
line-formulae description="In-line Formulae" end="lead"?>Σabs|Xi,j−Xi,j+1|,line-formulae description="In-line Formulae" end="tail"?> wherein i and j are a pixel horizontal and vertical indices, Xi,j represents a first line, and Xi,j+1 represents a next line of a same frame picture, such that the sum of the absolute frame vertical pixel difference is a sum of differences between lines in the same frame picture;
determining a sum of an absolute field vertical pixel differences over the same frame picture according to:
line-formulae description="In-line Formulae" end="lead"?>Σabs|Xi,2j−Xi,2(j+1)|+Σabs|Xi,2j+1−Xi,2(j+1)+1|,line-formulae description="In-line Formulae" end="tail"?> line-formulae description="In-line Formulae" end="lead"?>whereinline-formulae description="In-line Formulae" end="tail"?> line-formulae description="In-line Formulae" end="lead"?>Σabs|Xi,2−Xi,2(j+1)|line-formulae description="In-line Formulae" end="tail"?> represents a difference between even field lines in the same frame picture and
line-formulae description="In-line Formulae" end="lead"?>Σabs|Xi,2j+1−Xi,2(j+1)+1|line-formulae description="In-line Formulae" end="tail"?> represents a difference between odd field lines in the same frame picture; comparing the sum of the absolute frame vertical pixel differences with the sum of the absolute field vertical pixel difference;
selecting a field coding mode for encoding the frame picture if the sum of the frame vertical pixel difference is greater than the sum of the field vertical pixel differences, else
selecting a frame coding mode for encoding the frame picture.
5. A method for selecting a coding mode per macroblock pair or picture, the method comprising:
identifying either a field coding mode or a frame coding mode for the macroblock pair or picture based on a vertical pixel difference comparison by:
determining a sum of an absolute frame vertical pixel difference (ΔFRM) over the at least one macroblock pair or picture,
determining a sum of an absolute field vertical pixel difference (ΔFLD) over the macroblock pair or picture, and
comparing the sum of the absolute frame vertical pixel difference with the sum of the absolute field vertical pixel difference;
identifying a field coding mode for encoding the at least one macroblock pair or picture pair if the frame vertical pixel difference is greater than the field vertical pixel difference, else identifying a frame coding mode for encoding the at least one macroblock pair or picture pair;
identifying either a field coding mode or a frame coding mode for the macroblock pair or picture based on a me cost by:
for a macroblock pair, determining a minimum cost for each of the macroblocks in the macroblock pair in both the frame coding mode (Jmin
for a picture, determining a minimum frame coding cost for all of the macroblocks in each of the macroblock pairs over the entire I picture by summing all of the minimum frame me costs over the I picture and determining a minimum field coding cost for all of the macroblocks in each of the macroblock pairs over the entire I picture by summing all of the minimum field me costs over the I picture; and
identifying a frame coding mode for encoding the macroblock pair if the minimum frame cost of the macroblock pair is less than the minimum field cost of the macroblock pair, else identifying the field coding mode for the macroblock pair;
selecting the identified coding mode for encoding the macroblock pair or picture if the same coding mode is identified based on both the vertical pixel difference comparison and the me cost, else if
select the coding mode identified based on the me cost, or if
select the coding mode identified based on the vertical pixel difference comparison.
2. The method of
|
This application is a continuation of U.S. patent application Ser. No. 11/957,750 filed on Dec. 17, 2007, entitled “METHOD AND APPARATUS FOR SELECTING A CODING MODE,” the contents of both which is incorporated herein by reference in its entirety.
1. Field of the Invention
The present invention relates to video encoders and, more particularly, to a method and apparatus for selecting a coding mode (e.g., a frame coding mode or a field coding mode).
2. Description of the Background Art
The International Telecommunication Union (ITU) H.264 video coding standard is able to compress video much more efficiently than earlier video coding standards, such as ITU H.263, MPEG-2 (Moving Picture Experts Group), and MPEG-4. H.264 is also known as MPEG-4 Part 10 and Advanced Video Coding (AVC). H.264 exhibits a combination of new techniques and increased degrees of freedom in using existing techniques. Among the new techniques defined in H.264 are 4×4 and 8×8 integer transform (e.g., DCT-like integer transform), multi-frame prediction, context adaptive variable length coding (CAVLC), SI/SP frames, context-adaptive binary arithmetic coding (CABAC), and adaptive frame/field coding. The increased degrees of freedom come about by allowing multiple reference frames for prediction and many more tessellations of a 16×16 pixel macroblock (MB). These new tools and methods add to the coding efficiency at the cost of increased encoding and decoding complexity in terms of logic, memory, and number of operations. This complexity far surpasses those of H.263 and MPEG-4 and begs the need for efficient implementations.
The H.264 standard belongs to the hybrid motion-compensated DCT (MC-DCT) family of codecs. H.264 is able to generate an efficient representation of the source video by reducing temporal and spatial redundancies. Temporal redundancies are removed by a combination of motion estimation (ME) and motion compensation (MC). ME is the process of estimating the motion of a current frame in the source video from previously coded frame(s). This motion information is used to motion compensate the previously coded frame(s) to form a prediction for the current frame. The prediction is then subtracted from the original current frame to form a displaced frame difference (DFD). The motion information is present for each block of pixel data. In H.264, there are seven possible block sizes within a macroblock, e.g., 16×16, 16×8, 8×16, 8×8, 8×4, 4×8, and 4×4 (also referred to as tessellations or partitions). Thus, a 16×16 pixel macroblock (MB) can be tessellated into the following partitions: (A) one 16×16 macroblock region; (B) two 16×8 tessellations; (C) two 8×16 tessellations; and (D) four 8×8 tessellations. Furthermore, each of the 8×8 tessellations can be decomposed into: (a) one 8×8 region; (b) two 8×4 regions; (c) two 4×8 regions; and (d) four 4×4 regions.
Furthermore, the motion vector for each block is unique and can point to different reference frames. The job of the encoder is to find the optimal way of breaking down a 16×16 macroblock into smaller blocks (along with the corresponding motion vectors) in order to maximize compression efficiency. This breaking down of the macroblock into a specific pattern is commonly referred to as “mode selection” or “mode decision.”
In addition, the H.264 standard allows for the adaptive switching between frame coding and field coding modes. Notably, this type of switching can occur at both the picture and the macroblock (MB) pair levels. However, present day processes are typically exhaustive in the sense that H.264 encoders encode a picture by completely executing both frame coding and field coding techniques and subsequently comparing the two end products to see which one performed better. Namely, each picture is encoded in its entirety twice. This approach is computationally expensive.
Accordingly, there exists a need in the art for a method and apparatus for an improved adaptive frame/field mode selection encoding method.
In one embodiment, a method and apparatus for selecting a coding mode are described. For example, the method receives at least one block of a signal to be encoded. The method determines a frame vertical pixel difference in the at least one block and determines a field vertical pixel difference in the at least one block. The method then compares the frame vertical pixel difference with the field vertical pixel difference to determine a first coding mode for the at least one block.
In an alternate embodiment, a method and apparatus for selecting a coding mode are described. For example, the method receives at least one block of a signal to be encoded. The method then determines a field coding cost of the at least one block in accordance with a field coding mode and determines a frame coding cost of the at least one block in accordance with a frame coding mode. The method then compares the frame coding cost with the field coding cost to determine a coding mode for the at least one block.
So that the manner in which the above recited features of the present invention can be understood in detail, a more particular description of the invention, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.
To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures.
Method and apparatus for mode selection in a video encoder is described. One or more aspects of the invention relate to predictive frame (i.e., INTER) mode selection in an H.264 video encoder or H.264-like encoder. Although the present invention is disclosed in the context of an H.264-like encoder, the present invention is not so limited. Namely, the present invention can be adapted to other motion compensation (MC) encoding standards. The INTER mode selection is independent of the motion estimation algorithm. In one embodiment, the INTER mode selection is a one-pass decision algorithm aiming to approximate the multi-pass R-D optimization based on encoder parameters and statistical data. The algorithm uses a bits model in which some of the components are measured exactly, and the residual block bits are estimated through a statistical model. The statistical model can be adapted based on the actual encoded bits.
Embodiments of the invention use the following definitions:
The DCT module 104 transforms the difference signal from the pixel domain to the frequency domain using a DCT-like algorithm to produce a set of coefficients. The quantizer 106 quantizes the DCT coefficients. The entropy coder 108 codes the quantized DCT coefficients to produce a coded frame.
The inverse quantizer 110 performs the inverse operation of the quantizer 106 to recover the DCT coefficients. The inverse DCT module 112 performs the inverse operation of the DCT-like module 104 to produce a reconstructed difference signal. The reconstructed difference signal is added to the predicted frame by the adder 114 to produce a reconstructed frame, which is coupled to the deblocking filter 116. The deblocking filter smoothes the reconstructed frame and stores the reconstructed frame in the frame memory 118. The motion compensated predictor 120 and the motion estimator 124 are coupled to the frame memory 118 and are configured to obtain one or more previously reconstructed frames (previously coded frames).
The motion estimator 124 also receives the source frame. The motion estimator 124 performs a motion estimation algorithm using the source frames and previous reconstructed frames (i.e., reference frames) to produce motion estimation data. The motion estimation data includes motion vectors and associated references. The motion estimation data is provided to the entropy coder 108 and the motion compensated predictor 120. The entropy coder 108 codes the motion estimation data to produce coded motion data. The motion compensated predictor 120 performs a motion compensation algorithm using a previous reconstructed frame and the motion estimation data to produce the predicted frame, which is coupled to the intra/inter switch 122. Motion estimation and motion compensation algorithms are well known in the art. In one embodiment, the motion estimator 124 includes mode decision logic 126. The mode decision logic 126 is configured to select a mode for each macroblock, or pair of macroblocks, in a predictive (INTER) frame. The “mode” of a macroblock is the partitioning scheme. That is, in one embodiment, the mode decision logic 126 selects MODE for each macroblock in a predictive frame.
The present invention sets forth at least one solution for selecting either a frame coding mode or a field coding mode on both a per picture basis or a per macroblock (MB) pair basis. In one embodiment, one solution may include two separate yet related methods. Notably, the first method utilizes frame and field vertical pixel difference comparisons, while the second method entails the use of a coding cost procedure.
The reasoning for using the frame and field vertical pixel difference comparison method is two-fold. First, for stationary areas of a picture comprising two fields, the difference between the consecutive pixels of the picture in the vertical direction tends to be smaller than the difference between the consecutive pixels of each of two fields of the picture in the vertical direction. Secondly, for moving areas of a picture comprising two fields, the difference between the consecutive pixels of the picture in the vertical direction tends to be larger than the difference between the consecutive pixels of each of two fields of the picture in the vertical direction.
Similarly, the coding costs (e.g., the motion estimation costs) of a MB pair in frame and field modes may also be used to determine whether a frame or a field coding mode is more suitable for a particular MB pair. In one embodiment, the coding cost (J) is defined as:
J=SAD+λ×f(MV,refldx,mbType) Eq. 1
where SAD is a difference measurement between the pixels and their (temporal or spatial) predictions for every MB or sub-MB partition. Namely, pixel predictions come from either a temporal prediction or a spatial prediction. In one embodiment, SAD may also represent the distortion present in an MB pair. Similarly, the MV variable represents motion vectors, refldx is the reference picture index, and mbType is the type of macroblocks or MB partitions. An MB partition may include any sub-macroblock configuration derived from a 16×16 MB, such as a 4×4 block, an 8×8 block, or the like. The function portion of the equation, which attempts to serve as a representation of the number of coding bits, varies in accordance with the type of coding process that is conducted. For example, if the coding cost for intra prediction coding is needed, then the function does not consider the motion vectors or the refld variables. The variable λ represents a constant depending upon the quantization parameter and other coding parameters. In one embodiment, the variable λ may be utilized to nullify the units resulting from the function portion of the equation so that J results in a unitless value. The coding cost can be measured in either frame or field mode. As demonstrated below, a frame/field mode selection of an MB pair or picture can be based upon the frame and field coding costs.
At step 206, a frame vertical pixel difference in the at least one block is determined.
At step 208, a field vertical pixel difference in the at least one block is determined.
At step 210, the frame vertical pixel difference is compared with the field vertical pixel difference to determine a first coding mode for the at least one block.
At step 211, method 200 performs the optional step of computing the motion estimation (ME) cost for both the frame coding mode and the filed coding mode, where the two ME costs are then compared to further assist in the determining of a proper coding mode for the at least one block. A detailed description of this step is further described below. The method 200 ends at step 212.
It should be noted that although
The method 300 begins at step 302 and proceeds to step 304 where the sum of the differences between the absolute frame and field pixels differences in the vertical direction is calculated. In one embodiment, the vertical frame pixel difference is determined to be:
where i and j are the pixel horizontal and vertical indices, and (i, j) are over the MB pair. This formula essentially involves the determination of the difference between two lines in the same frame picture (i.e. Xi,j represents a first line and Xi,j+1 represents the next line of the same MB). Similarly, in one embodiment, the vertical field pixel difference is determined to be:
This formula pertains to the sum of differences between lines within each field of a MB. More specifically, the first component of the equation deals with the difference between two lines in a first field in a MB (e.g., a top field of a MB) and the second component of the equation deals with the difference between two lines in a second field of the same MB (e.g., the bottom field of same MB).
At step 306, the frame and field pixel differences in the vertical direction are compared. Namely, in one embodiment, if the frame pixel difference is greater than the field pixel difference (i.e., ΔFRM>ΔFLD), then the method 300 continues to step 310. At step 310, field coding mode is selected for the MB pair. Conversely, if the frame pixel difference is not greater than the field pixel difference, then the method 300 continues to step 308. At step 308, frame coding mode is selected for the MB pair. The method 300 ends at step 312.
The present invention also employs an optional procedure for utilizing a coding cost to determine the use of frame or field mode for an I-picture. An exemplary method 400 depicts one embodiment of such a process for an I-picture. Namely,
The method 400 begins at step 402 and proceeds to step 404 where at least one intra frame prediction is performed. In one embodiment, an intra frame prediction is performed for all of the possible prediction directions for an intra 4×4 sub-MB partition, an intra 8×8 sub-MB partition, and an intra 16×16 macroblock for each MB of a given MB pair. For example, both the intra 4×4 MB and the 8×8 MB have nine directions to be considered. Similarly, the 16×16 MB has four directions to be considered. Because this step is conducted in both the frame and field coding modes for both the top and bottom MB of the MB pair, a total of 736 direction calculations (i.e., (9 directions for 16 of 4×4 block+9 directions for 4 of 8×8 block+4 directions for one of 16×16 block)*2 MBs in a MB pair*2 coding modes=736), may take place per MB pair in at least one embodiment.
At step 406, in one embodiment, a minimum cost for each MB of a MB pair is determined. In one embodiment, the minimum costs of each MB in the MB pair are added together for both the frame mode and the field mode. More specifically, each of the directions calculated in step 404 (along with the respective block type information) is applied to the coding cost formula (see Eq. 1). Since method 400 pertains to I-pictures only, the coding cost formula does not consider temporal predictions or motion estimation. Afterwards, a minimum cost is selected for each MB of the MB pair. For example, a first minimum cost (regardless of the block type used to determine that minimum cost) is selected for the top MB and a second minimum cost (regardless of the block type used to determine that minimum cost) is selected for the bottom MB of the MB pair. A final minimum cost is then calculated by summing the minimum cost for the top MB to the minimum cost of the bottom MB. Notably, this calculation is conducted for both the frame coding mode and the field coding mode so that two separate final minimum costs, i.e., the minimum field cost (JFLDmin) and the minimum frame cost (JFRMmin), are respectively determined.
At step 408, the calculated JFLDmin and the JFRMmin are compared. If JFRMmin is not found to be greater than JFLDmin, then the method 400 proceeds to step 410 where the frame coding mode is selected for the MB pair. Alternatively, if JFRMmin is found to be greater than JFLDmin, then the method 400 proceeds to step 412 where the field coding mode is selected for the MB pair. The method 400 ends at step 414.
In an alternative embodiment, the method 400 may also be used to determine a minimum coding cost on the picture level (as opposed to MB pair level). Notably, the alternative method is identical to method 400 with the exception that after step 406, all of the minimum frame coding costs and the minimum field coding costs per MB pair are summed over the entire picture in a separate manner. For example,
Similarly, step 408 of method 400 would be replaced with the comparison of Jsum
The present invention also employs a procedure for utilizing a coding cost to determine the use of frame or field mode for P-pictures or B-pictures. An exemplary method 500 depicts one embodiment of such a process. Namely,
In one embodiment, the method 500 begins at step 502 and proceeds to step 504 where motion estimations (MEs) are performed for all possible MBs or sub-MB partitions for each of the MB of a MB pair for both frame mode and field mode. In one embodiment, an inter frame prediction is performed for all of the possible prediction directions for a 4×4 sub-MB partition, a 4×8 sub-MB partition, an 8×4 sub-MB partition, an 8×8 sub-MB partition, an 8×16 sub-MB partition, a 16×8 sub-MB partition, and a 16×16 macroblock for each of the two MBs of a MB pair.
At step 506, the MB/sub-MB partition type with the minimum coding cost is found for each MB of a MB pair in both the frame coding mode and the field coding mode. In one embodiment, the present invention calculates a motion estimation cost using the cost coding formula (i.e., Eq. 1). Notably, the formula is applied to each of the seven different types of MB/sub-MB partitions twice, once in the frame mode and then in the field mode, so that a minimum ME cost for both frame coding and field coding is calculated for each MB/sub-MB partition.
Afterwards, a minimum ME cost is selected for each MB of the MB pair. For example, a first minimum cost (regardless of the block type used to determine that minimum cost) is selected for the top MB and a second minimum ME cost (regardless of the block type used to determine that minimum cost) is selected for the bottom MB of the MB pair. A final minimum ME cost is then calculated by summing the minimum cost for the top MB to the minimum cost of the bottom MB. Notably, this calculation is conducted for both the frame coding mode and the field coding mode so that two separate final minimum costs, i.e., the minimum field cost (JFLDmin) and the minimum frame cost (JFRMmin), are respectively determined.
At step 508, the calculated JFLDmin and the JFRMmin are compared. If JFRMmin is found to be greater than JFLDmin, then the method 500 proceeds to step 510 where the field mode is selected for the MB pair. Alternatively, if JFRMmin is not found to be greater than JFLDmin, then the method 500 proceeds to step 512 where the frame mode is selected for the MB pair. The method 500 ends at step 514.
In an alternative embodiment, the method 500 may also be used to determining a minimum coding cost for a P-picture or B-picture on the picture level (as opposed to MB pair level). Notably, the alternative method is identical to method 500 with the exception that after step 506, all of the minimum frame coding costs and minimum field coding costs are summed over the entire picture in a separate manner. For example,
Similarly, step 508 of method 500 would be replaced with the comparison of Jsum
In one embodiment, on the MB pair level, the present invention determines if the outcomes of the frame/field mode selection process based on vertical pixel difference (e.g., method 300) and the coding cost process (e.g., method 400 for I pictures and method 500 for P and B pictures) are the same. If the results are indeed the same, then the result is considered final. If the results are different or there is some type of discrepancy, then additional criteria or calculations may be required. For instance, the following formula could be used to determine whether frame or field coding should be implemented:
where α is a constant ranging from 0 to 1.0. If the above formula holds true, then the result from the coding cost formula should be used. Otherwise, the result from the frame/field vertical pixel difference comparison should be used.
In an alternative embodiment, the present invention determines if the outcomes of the frame/field mode selection process and the coding cost process, as processed on the picture level, are the same. If the results are indeed are the same, then the result is considered final. If the results are different or there is some type of discrepancy, then additional criteria may be required. For example, the final decision on the frame and field mode per picture may be determined using Table 1 below. The final decision is based on the decision from the above comparisons of the aforementioned alternative embodiments.
TABLE 1
Decision of Approach 1
Decision of Approach 2
Final Decision
Frame
Frame
Frame
Frame
Field
Frame
Field
Frame
Frame
Field
Field
Field
In this particular embodiment, Table 1 is biased towards a frame coding mode because in a frame picture, MBAFF can be turned on, which may further compensate an incorrect decision made at the picture level (if any).
In one embodiment, the memory 603 stores processor-executable instructions and/or data that may be executed by and/or used by the processor 601 as described further below. These processor-executable instructions may comprise hardware, firmware, software, and the like, or some combination thereof. Modules having processor-executable instructions that are stored in the memory 603 may include a mode selection module 612. For example, the mode selection module 612 is configured to perform the methods 200, 300, 400, and 500 of
An aspect of the invention is implemented as a program product for execution by a processor. Program(s) of the program product defines functions of embodiments and can be contained on a variety of signal-bearing media (computer readable media), which include, but are not limited to: (i) information permanently stored on non-writable storage media (e.g., read-only memory devices within a computer such as CD-ROM or DVD-ROM disks readable by a CD-ROM drive or a DVD drive); (ii) alterable information stored on writable storage media (e.g., floppy disks within a diskette drive or hard-disk drive or read/writable CD or read/writable DVD); or (iii) information conveyed to a computer by a communications medium, such as through a computer or telephone network, including wireless communications. The latter embodiment specifically includes information downloaded from the Internet and other networks. Such signal-bearing media, when carrying computer-readable instructions that direct functions of the invention, represent embodiments of the invention.
While the foregoing is directed to illustrative embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
5737020, | Mar 27 1995 | International Business Machines Corporation | Adaptive field/frame encoding of discrete cosine transform |
5742346, | Aug 09 1994 | Polycom, Inc | Spatially adaptive blur filter |
5878166, | Dec 26 1995 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | Field frame macroblock encoding decision |
8670484, | Dec 17 2007 | ARRIS ENTERPRISES LLC | Method and apparatus for selecting a coding mode |
20040120397, | |||
20060050786, | |||
20060198439, | |||
20080260022, | |||
20090086820, | |||
EP1494483, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jan 27 2014 | ARRIS Enterprises, Inc. | (assignment on the face of the patent) | / | |||
Jan 01 2015 | ARRIS TECHNOLOGY, INC | ARRIS TECHNOLOGY, INC | MERGER AND CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 035133 | /0286 | |
Jan 01 2015 | General Instrument Corporation | ARRIS TECHNOLOGY, INC | MERGER AND CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 035133 | /0286 | |
Jun 18 2015 | ARRIS TECHNOLOGY, INC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | ARCHIE U S MERGER LLC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | ARCHIE U S HOLDINGS LLC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | ARRIS GLOBAL SERVICES, INC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | ARRIS HOLDINGS CORP OF ILLINOIS, INC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | ARRIS SOLUTIONS, INC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | BIG BAND NETWORKS, INC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | Texscan Corporation | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | POWER GUARD, INC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | JERROLD DC RADIO, INC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | GIC INTERNATIONAL HOLDCO LLC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | GIC INTERNATIONAL CAPITAL LLC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | ARRIS INTERNATIONAL LIMITED | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | ARRIS Enterprises, Inc | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | ARRIS Group, Inc | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Jun 18 2015 | NEXTLEVEL SYSTEMS PUERTO RICO , INC | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 036020 | /0789 | |
Dec 14 2015 | ARRIS TECHNOLOGY, INC | ARRIS Enterprises, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037328 | /0341 | |
Dec 31 2015 | ARRIS ENTERPRISES INC | ARRIS | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 049669 | /0652 | |
Dec 31 2015 | ARRIS Enterprises, Inc | ARRIS ENTERPRISES LLC | CORRECTIVE ASSIGNMENT TO CORRECT THE ASSIGNEE S NAME PREVIOUSLY RECORDED AT REEL: 049820 FRAME: 0495 ASSIGNOR S HEREBY CONFIRMS THE CHANGE OF NAME | 049858 | /0161 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | POWER GUARD, INC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARRIS Enterprises, Inc | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARRIS INTERNATIONAL LIMITED | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARRIS TECHNOLOGY, INC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARRIS HOLDINGS CORP OF ILLINOIS, INC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARCHIE U S HOLDINGS LLC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARCHIE U S MERGER LLC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARRIS SOLUTIONS, INC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARRIS GLOBAL SERVICES, INC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | BIG BAND NETWORKS, INC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | GIC INTERNATIONAL HOLDCO LLC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | Texscan Corporation | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | NEXTLEVEL SYSTEMS PUERTO RICO , INC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | JERROLD DC RADIO, INC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | GIC INTERNATIONAL CAPITAL LLC | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | BANK OF AMERICA, N A , AS ADMINISTRATIVE AGENT | ARRIS Group, Inc | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 050721 | /0401 | |
Apr 04 2019 | COMMSCOPE, INC OF NORTH CAROLINA | JPMORGAN CHASE BANK, N A | TERM LOAN SECURITY AGREEMENT | 049905 | /0504 | |
Apr 04 2019 | CommScope Technologies LLC | JPMORGAN CHASE BANK, N A | TERM LOAN SECURITY AGREEMENT | 049905 | /0504 | |
Apr 04 2019 | ARRIS ENTERPRISES LLC | JPMORGAN CHASE BANK, N A | TERM LOAN SECURITY AGREEMENT | 049905 | /0504 | |
Apr 04 2019 | ARRIS TECHNOLOGY, INC | JPMORGAN CHASE BANK, N A | TERM LOAN SECURITY AGREEMENT | 049905 | /0504 | |
Apr 04 2019 | RUCKUS WIRELESS, INC | JPMORGAN CHASE BANK, N A | TERM LOAN SECURITY AGREEMENT | 049905 | /0504 | |
Apr 04 2019 | COMMSCOPE, INC OF NORTH CAROLINA | JPMORGAN CHASE BANK, N A | ABL SECURITY AGREEMENT | 049892 | /0396 | |
Apr 04 2019 | CommScope Technologies LLC | JPMORGAN CHASE BANK, N A | ABL SECURITY AGREEMENT | 049892 | /0396 | |
Apr 04 2019 | ARRIS ENTERPRISES LLC | JPMORGAN CHASE BANK, N A | ABL SECURITY AGREEMENT | 049892 | /0396 | |
Apr 04 2019 | ARRIS TECHNOLOGY, INC | JPMORGAN CHASE BANK, N A | ABL SECURITY AGREEMENT | 049892 | /0396 | |
Apr 04 2019 | RUCKUS WIRELESS, INC | JPMORGAN CHASE BANK, N A | ABL SECURITY AGREEMENT | 049892 | /0396 | |
Apr 04 2019 | ARRIS SOLUTIONS, INC | JPMORGAN CHASE BANK, N A | ABL SECURITY AGREEMENT | 049892 | /0396 | |
Apr 04 2019 | ARRIS ENTERPRISES LLC | WILMINGTON TRUST, NATIONAL ASSOCIATION, AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 049820 | /0495 | |
Apr 04 2019 | ARRIS SOLUTIONS, INC | JPMORGAN CHASE BANK, N A | TERM LOAN SECURITY AGREEMENT | 049905 | /0504 | |
Nov 15 2021 | ARRIS SOLUTIONS, INC | WILMINGTON TRUST | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 060752 | /0001 | |
Nov 15 2021 | ARRIS ENTERPRISES LLC | WILMINGTON TRUST | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 060752 | /0001 | |
Nov 15 2021 | CommScope Technologies LLC | WILMINGTON TRUST | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 060752 | /0001 | |
Nov 15 2021 | COMMSCOPE, INC OF NORTH CAROLINA | WILMINGTON TRUST | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 060752 | /0001 | |
Nov 15 2021 | RUCKUS WIRELESS, INC | WILMINGTON TRUST | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 060752 | /0001 |
Date | Maintenance Fee Events |
Aug 23 2019 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Aug 23 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) |