This invention relates to a method and apparatus for generating a bitstream representative of a 3D model, and a method and apparatus for decoding the same.
In practical applications, many 3D models consist of a large number of connected components. These multi-component 3D models usually contain many repetitive structures in various transformations, as shown in
Efficient compression algorithms for multi-component 3D models that take advantage of repetitive structures in input models are known. Repetitive structures of a 3D model are discovered in various positions, orientations, and scaling factors. The 3D model is then organized into “pattern-instance” representation. A pattern is used to denote a representative geometry of a corresponding repetitive structure. Components belonging to a repetitive structure are denoted as instances of the corresponding pattern and may be represented by a pattern ID and transformation information, for example, reflection, translation, rotation and possible scaling with respect to the pattern. The instance transformation information may be organized into, for example, reflection part, translation part, rotation part, and possible scaling part. There might be some components of the 3D models that are not repetitive, which are referred to as unique components.
A commonly owned PCT application, entitled “System and method for error controllable repetitive structure discovery based compression” by K. Cai, W. Jiang, and T. Luo (PCT/CN2012/070877, Attorney Docket No. PA120001), the teachings of which are specifically incorporated herein by reference, discloses a method and apparatus for identifying repetitive structures in 3D models to reduce redundancy among instance components, and thus to improve compression efficiency.
The present principles provide a method for generating or decoding a bitstream representing a 3D model, comprising the steps of accessing a first quantization parameter used for encoding a pattern associated with the 3D model; determining a scale of an instance of the pattern and a scale of the pattern, the instance being represented as a transformation of the pattern; determining a second quantization parameter for a rotation part of the transformation for the instance in response to the first quantization parameter, the scale of the instance, and the scale of the pattern; and performing encoding or decoding of the rotation part of the transformation for the instance in response to the second quantization parameter as described below. The present principles also provide an apparatus for performing these steps.
The present principles also provide a computer readable storage medium having stored thereon instructions for generating or decoding a bitstream according to the methods described above.
The present principles also provide a computer readable storage medium having stored thereon a bitstream generated according to the methods described above.
As shown in
When an instance is represented by a pattern ID and a transformation matrix, the pattern ID and the transformation matrix are to be compressed when compressing the instance. Consequently, an instance may be reconstructed through the pattern ID and the decoded transformation matrix, that is, an instance may be reconstructed as transformation (from the decoded transformation matrix) of a decoded pattern indexed by the pattern ID.
In the examples of
The present principles provide a method and apparatus for efficiently quantizing the transformation information for a 3D instance component by considering rate-distortion performance of a 3D encoder. In one exemplary embodiment, considering the maximum allowed distortion, the quantization parameters for the rotation part and translation part of the instance are determined such that rate-distortion performance is improved. In the following, the number of quantization bits is used as an exemplary quantization parameter. The present principles can be applied when other quantization parameters, such as a quantization step size, are used.
As the scaling part of the transformation may be compressed by a lossless floating point codec, scaling part of the transformation is not involved in the following discussion.
Based on the discovered “pattern-instance” representation, a vertex v of an original instance can be represented by:
v=R*p+T, (1)
where p is v's corresponding vertex in the corresponding pattern, R and T are the rotation matrix and translation vector between pattern and instance, respectively.
The decoded position of v, vd, can be calculated as:
v
d
=R
d
*p
d
+T
d, (2)
where pd is the decoded position of p, and Rd and Td are the decoded rotation matrix and decoded translation vector, respectively.
The distortion caused by compression for vertex v can then be calculated as:
Based on mathematical theory, it can be inferred that:
where ∥Δp∥max is the upper bound of the quantization error of vertex p, and ∥ΔT∥max is the upper bound of the quantization error of instance translation.
If we assume that the rotation matrix is represented by Eular angles (α, β, γ), which may be quantized using the same number of quantization bits, then
∥(R−Rd)*p∥≦√{square root over (3)}Δθmax∥p∥, (5)
where Δθmax is the upper bound of quantization error for α, β and γ. Eq. (5) can be adapted when other representations or different quantization parameters are used for angles (α, β, γ). Using Eq. (5), Eq. (4) becomes:
∥v−vd∥≦∥Δp∥max+√{square root over (3)}Δθmax∥p∥max+∥ΔT∥max, (6)
where ∥p∥max is the maximum distance between any vertex of the corresponding pattern and the center of the corresponding pattern.
If we denote the number of quantization bits used for encoding patterns as QB_Pattern, and the number of quantization bits for encoding translation as QB_translation, ∥p∥max may be calculated as:
and ∥ΔT∥max may be calculated as:
where Pattern_Scal and Translation_Scal are the scales of the bounding box of the pattern vertices and translations, respectively. In one example, Translation_Scal can be measured as the difference between the maximum and minimum possible values of all translations of all instances, and Pattern_Scal can be measured as the diagonal distance of a bounding box containing all patterns. In another example, Pattern_Scal can be measured as the maximum values of x, y, and z dimensions.
One of our targets is to allocate bits while controlling the maximum coding error. Suppose the maximum allowed coding error is MaxErr, Eq. (6) should satisfy the following inequality:
∥Δp∥max+√{square root over (3)}Δθmax∥p∥max+∥ΔT∥max≦MaxErr. (7)
In one embodiment, for simplification, we assume that all patterns use the same number of quantization bits and all instance translations use the same number of quantization bits. Thus, the quantization error for patterns may satisfy
∥Δp∥max=MaxErr/3, (8)
and the quantization error for instance translation may satisfy
∥ΔT∥max=MaxErr/3. (9)
After the upper bounds for quantization errors are estimated in Eqs. (8) and (9), we can estimate the number of quantization bits based on the scale of the bounding box of the pattern vertices and instance translation.
In one simplified exemplary embodiment, we may assume both upper bounds are the same, and thus, according to Eqs. (8) and (9), instance translation may use is the same number of quantization bits as patterns.
In another exemplary embodiment, the scale difference between the bounding box of patterns and the bounding box of instances are considered. Suppose ∥Δp∥max=∥ΔT∥max, the number of quantization bits for the translation part can be calculated as:
Parameter_Translation_Scal may be sent in the bitstream and it becomes available at both the encoder and decoder, so that Eq. (10) can be used at both the encoder and decoder. According to Eq. (10), all instance translations use the same quantization parameter, which are related to the ratio between the scale of patterns and instance translations.
As discussed in
The vertex coordinate error caused by rotation quantization error may satisfy
√{square root over (3)}Δθmax
That is, the upper bound of rotation quantization error for the ith instance component may be estimated as:
Δθmax
where HalfScali is the half scale (i.e., half of the diagonal distance of the bounding box of the instance) of the ith instance component. In one embodiment, HalfScali may be estimated from the corresponding reconstructed pattern. By estimating HalfScali using the reconstructed pattern, which can be accessed by both the encoder and decoder, the quantization parameter for the rotation part can be calculated at the decoder, and thus, the encoder need not to explicitly indicate the quantization parameter for the rotation part in the bitstream. Δθmax
Before compression, all the patterns are aligned with the world coordinate system. Then all the patterns may be encoded together using the same quantization parameter. The positions and orientations of the patterns are also encoded and recorded in the bitstream. Using the number of quantization bits for encoding patterns (QB_Pattern), the number of quantization bits for the rotation part of the ith instance (QB_Roti) may be calculated based on the scale of the bounding box of the pattern vertices and rotation angles as follows:
where angle_Scal is the scale of the rotation angle. In one example, angle_Scal can be measured as the difference between the maximum and minimum possible angles of all instance rotations. In another example, we set angle_Scal to 2π.
Assuming Pattern_scal is measured as the size of the bounding box of all patterns and the possible value of each Eular angle is 0˜2π, Eq. (13) becomes:
That is, when an instance is larger (i.e., HalfScali is larger), the number of quantization bits (QP_Roti) for the instance is determined to be larger. Thus, according to the present principles, a larger instance gets finer quantization for its rotation part.
Here we suppose there is no scaling part in the transformation in Eq. (14). Eq. (14) should be adjusted accordingly when the scale of the rotation angle changes, the scaling part of the transformation is considered, or the sizes of patterns and instances are measured differently.
As discussed above, quantization parameters for the translation part and rotation part of the transformation matrix of an instance may be determined based on the quantization parameter used for encoding patterns, so as to improve compression efficiency. In one exemplary embodiment, the number of quantization bits used for encoding patterns (QB_Pattern) may be indicated in the bitstream, the translation part of the transformation matrix of the instance may be calculated using Eq. (10), and the number of quantization bits for the rotation part may be calculated using Eq. (14).
In another exemplary embodiment, we assume that the upper bound of the reconstruction error of pattern vertices, instance translation and instance rotation are the same, i.e.,
∥ΔP∥max=∥ΔE∥max/3,
where ∥ΔE∥max is the upper bound of the quantization error of the entire model, and ∥ΔP∥max is the upper bound of the quantization error for all patterns. Consequently, the number of quantization bits for encoding patterns may be calculated from the number of quantization bits of the entire 3D input model as follows:
where QB_EntireModel is the number of quantization bits for the entire 3D input model, and EntireModel_Scal reflects the size of the entire 3D input model.
In the above, Pattern_Scal can be measured using all patterns in the 3D model. In another embodiment, the patterns are compressed separately and the instances of the same pattern are compressed together. All the patterns may use the same quantization parameter. Further, Pattern_Scal in Eqs. (10) and (13) corresponds to the scale of the bounding box of the corresponding pattern, and Translation_Scal in Eq. (10) and angle_Scal in Eq. (13) correspond to the scales of the translations and rotation angles of the instances of the current pattern, respectively.
At step 360, the quantization parameter for the translation part of the transformation matrix for an instance component may be determined, for example, using Eq. (10). The quantization parameters for the rotation part of the transformation matrix may be determined, for example, using Eq. (14). The transformation matrix for the instance is then encoded at step 370. It checks whether more instances need to be processed at step 380. If more instances are to be processed, the control is returned to step 350. Otherwise, the control is passed to the end step 399.
Patterns are decoded at step 420. At step 435, the scales of patterns, translation, and rotation are determined. At step 440, the quantization parameter for the translation part and/or rotation part of the transformation matrix for an instance component may be determined. The transformation matrix is decoded at step 450. The instance is then reconstructed at step 460, for example, using a corresponding reconstructed pattern and decoded transformation matrix. It checks at step 470 whether more instances need to be processed. If yes, the control is returned to step 435. Otherwise, the control is passed to the end step 499.
Note that to properly decode instances, corresponding methods of determining scales for patterns, translation, and rotation, and of calculating quantization parameters should be used at the encoder and decoder. For example, when the bitstream generated by method 300 is used as an input to method 400, steps 435 and 440 should correspond to steps 350 and 360, respectively.
In
In the above, how to allocate the number of quantization bits are discussed given the maximum allowed error. On the other hand, Eq. (7) can also be used for rate control, that is, for determining the quantization parameters given the number of bits in order to optimize the quality of the decoded 3D model.
The size, measured in the number of bits, of a compressed pattern may be calculated as:
Compr_Pattern=QB_Pattern*Pattern_Ver_Num*Cpv+Pattern_Tri_Num*Cpt, (16)
where Pattern_Ver_Num and Pattern_Tri_Num are the number of vertices and the number of triangles of all patterns, respectively, and Cpv and Cpt are pre-determined values, for example, used to count the compression ratio of entropy encoding. In one implementation, Cpv=0.2 and Cpt=3. The size of compressed instance can be calculated as:
where Cinsta is a pre-determined value. The size for compressed unique component can be calculated as:
Compr_UniComp=QB_UniComp*UniComp_Ver_Num*Cpv+UniComp_Tri_Num*Cpr, (18)
where QB_UniComp is the number of quantization bits for encoding the unique components, UniComp_Ver_Num and UniComp_Tri_Num are the number of vertices and the number of triangles of unique components, respectively. In one exemplary embodiment, ∥ΔU∥max=∥ΔP∥max, QB_UniComp may be calculated as follows:
where UniComp_Scale is the scale of the bounding box of the unique parts. The quantization bits for the translations of unique components may be calculated as follows:
where UniComp_Transl_Scal is the scale of the bounding box of all translations of all unique components.
The total size of the compressed 3D model can then be calculated as:
Compr_EntireModel=Compr_Pattern+Compr_Insta+Compr_UniComp. (20)
Based on Eqs. (10), (14) and (19), QB_Translation, QB_Roti, or QB_UniComp can be obtained as a function of QB_Pattern. Then according to Eqs. (10), (14), and (16-19), Compr_Pattern, Compr_Insta, or Compr_UniComp can be expressed as a function of QB_Pattern. Further using Eq. (20), the relationship between the total size of the compressed 3D model Compr_EntireModel and QB_Pattern can be obtained. Subsequently, given the expected compressed model size Compr_Model, QB_Pattern may be decided. From QB_Pattern, the upper bound of the coding error MaxErr can be calculated using MaxErr=3*Pattern_Scal/2QB
To improve compression efficiency, all components of the original 3D model may be translated such that the centers of components are aligned. The translations of the centers need to be compressed and indicated in the bitstream. The rate-distortion performance may be improved as the bounding box of the components could be much smaller (in most cases) and less quantization bits are required for the same coding error.
In addition, a pattern may be generated by translating the center of a component to the origin, and the original component may be regarded as an instance. To improve compression efficiency, for pattern components (components corresponding to patterns), only translations are indicated the compressed bitstream. If there are no or not enough repetitive structures to guarantee the bitrate saving from the pattern-instance representation, all components of the input 3D model may be regarded as unique components.
If there is no unique part and repetitive structure in the original model (uni_part_bit==0 && repeat_struc_bit==0), the remaining part of the bitstream is the compressed input 3D model (730) using the 3D model compression method indicated in PB3DMC_stream_header. Otherwise, the next part in the bitstream is the compressed result of all unique components (745) if there are some (740). If there is at least one repetitive structure (750), the next data field is the compressed result of all patterns (760). Depending on which instance transformation packing mode is chosen in the bitstream (770), either compr_insta_grouped_data (780) or compr_insta_elementary_data (785) is the next part in the bitstream.
In TABLE 1, exemplary syntax and semantics for the header are illustrated for the present principles. Note that some data fields are taken from the bitstream definition of 3DMC Extension [w11455, Final text of ISO/IEC 14496-16 4th Edition, MPEG-3DGC, 93th MPEG meeting, 2011-02].
ver_num: This 32-bit unsigned integer contains the number of vertices of the entire 3D model. This value can be used to verify the decoded 3D model.
tri_num: This 32-bit unsigned integer contains the number of triangles of the entire 3D model. This value can be used to verify the decoded 3D model.
default_coord_bbox: This 1-bit unsigned integer indicates whether a default bounding box is used for the entire 3D model's geometry. 0 means using another bounding box and 1 means using the default bounding box. The default bounding box is defined as xmin=0.0, ymin=0.0, zmin=0.0, xmax=1.0, ymax=1.0, and zmax=1.0.
coord_bbox: This data field contains the bounding box of the entire 3D model's geometry. The geometry bounding box is defined by (xmin, ymin, zmin, xmax, ymax, zmax)
QP_coord: This 5-bit unsigned integer indicates the quality parameter of the 3D model geometry. The minimum value of QP_coord is 3 and maximum is 31. QP_coord may correspond to QB_Pattern in Eq. (10) or QB_EntireModel in Eq. (15).
normal_binding: This 2-bit unsigned integer indicates the binding of normals to the 3D model. The admissible values are described in the following table.
default_normal_bbox: This 1-bit unsigned integer should always be ‘0’, which indicates that a default bounding box is used for the normal of the entire 3D model. The default bounding box of normal is defined as nxmin=0.0, nymin=0.0, nzmin=0.0, nxmax=1.0, nymax=1.0, and nzmax=1.0.
QP_normal: This 5-bit unsigned integer indicates the quality parameter of the 3D model geometry. The minimum value of QP_normal is 3 and maximum is 31.
color binding: This 2-bit unsigned integer indicates the binding of colors to the 3D model. The following table shows the admissible values.
default_color_bbox: This 1-bit unsigned integer indicates whether a default bounding box is used for the color of the entire 3D model. 0 means using another bounding box and 1 means using the default bounding box. The default bounding box is defined as rmin=0.0, gmin=0.0, bmin=0.0, rmax=1.0, gmax=1.0, and bmax=1.0.
color_bbox: This data field contains the bounding box of the color of the entire 3D model. The color bounding box is defined by (rmin, gmin, bmin, rmax, gmax, bmax)
QP_color: This 5-bit unsigned integer indicates the quality parameter of the color. The minimum value of QP_color is 3 and maximum is 31.
multi_texCoord_num: This 5-bit unsigned integer gives the number of texture coordinates per vertex/corner.
texCoord_binding: This 2-bit unsigned integer indicates the binding of texture coordinates to the 3D model. The following table shows the admissible values.
default_texCoord_bbox: This 1-bit unsigned integer indicates whether a default bounding box is used for the texture coordinates. 0 means using another bounding box and 1 means using the default bounding box. The default bounding box is defined as umin=0.0, vmin=0.0, umax=1.0, and vmax=1.0.
texCoord_bbox: This data field contains the bounding box of the texture coordinate of the entire 3D model. The texture coordinate bounding box is defined by (umin, vmin, umax, vmax).
QP_texCoord: This 5-bit unsigned integer indicates the quality parameter of texture coordinates. The minimum value of QP_texCoord is 3 and maximum is 31.
multi_attribute_num: This 5-bit unsigned integer indicates the number of attributes per vertex/face/corner.
attribute_binding: This 2-bit unsigned integer indicates the binding of attributes to the 3D model. The following table shows the admissible values.
default_attribute_bbox: This 1-bit unsigned integer indicates whether a default bounding box is used for the attributes. 0 means using another bounding box and 1 means using the default bounding box. The default bounding box is defined as attribute_min[1 . . . attribute_dim]=0.0, attribute_max[1 . . . attribute_dim]=1.0.
attribute_bbox: This data field contains the bounding box of the attribute. The texture coordinate bounding box is defined by (attribute_min[1 . . . attribute_dim], attribute_max[1 . . . attribute_dim]).
QP_attribute: This 5-bit unsigned integer indicates the quality parameter of the attribute. The minimum value of QP_attribute is 3 and maximum is 31.
In TABLE 2, exemplary syntax and semantics for unique parts are illustrated for the present principles.
compr_uni_comp_data: This data field contains the compressed geometry, connectivity and properties of all unique components, which is encoded by the compression method indicated by 3d_model_compr_mode. All unqiue components are translated to the origin before compression.
compr_uni_comp_transl: This data field contains the compressed translation vectors for all unique components. The unique component translation vectors are compressed by first quantization and then entropy coding. This data field use the same order of unique component with compr_uni_comp_data.
bit_num_uni_comp_transl( ): This function computes the number of bits used for quantizing each unique component translation vector based on QP_coord.
In TABLE 3, exemplary syntax and semantics for repetitive structures are illustrated for the present principles.
compr_pattern_data: This data field contains the compressed geometry, connectivity and properties of all patterns, which is encoded by the compression method indicated by 3d_model_compr_mode.
compr_pattern_transl: This data field contains the compressed translation vectors for all pattern components. The pattern translation vectors are compressed by first quantization and then entropy coding. This data field uses the same order of patterns with compr_pattern_data.
compr_insta_elementary_data: This data field contains the compressed transformation data for all instances using the “elementary instance transformation mode”. It is compressed in a manner that is byte aligned.
compr_insta_grouped_data: This data field contains the compressed transformation data for all instances using the “grouped instance transformation mode”. It is compressed in a manner that is byte aligned.
bit_num_pattern_transl( ): This function computes the number of bits used for quantizing translation vector of each pattern component based on QP_coord.
In TABLE 4, exemplary syntax and semantics for instances are illustrated for the present principles.
insta_transl_bbox: This data field contains the bounding box of all translation vectors so that quantization can be used when compressing instance translation information. The bounding box is defined by insta_transl_xmin, insta_transl_ymin, insta_transl_zmin, insta_transl_xmax, insta_transl_ymax, insta_transl_zmax.
compr_elem_insta_patternID: This data field contains the compressed pattern ID of ith instance.
elem_insta_flip_flag: This 1-bit unsigned integer indicates whether or not the ith instance is flipped compared with the corresponding pattern. A flipped instance means the instance triangle normals are in the opposite direction of the corresponding pattern triangles. 0 means ith instance is not flipped and 1 ith instance is flipped.
elem_insta_reflection_flag: This 1-bit unsigned integer indicates whether the transformation of ith instance includes reflection. 0 means the transformation of ith instance doesn't include reflection and 1 means the transformation of ith instance includes reflection.
elem_insta_attribute_header: This data field contains the attribute header of ith instance.
compr_elem_insta_transl: This data field contains the compressed translation vector of ith instance.
compr_elem_insta_rotat_spherical: This data field contains the compressed rotation transformation of ith instance in spherical mode.
compr_elem_insta_scaling: This data field contains the compressed scaling factor of ith instance.
compr_elem_insta_error_compen_data: This data field contains the compressed coding error compensation data of ith instance.
compr_elem_insta_attribute_data: This data field contains the compressed attribute data of ith instance.
bit_num_insta_transl( ): This function computes the number of bits used for quantizing instance translation vectors based on QP_coord.
need_error_compensation( ): This function decides whether the coding error of ith instance needs to be compensated.
bit_num_vertex_coding_error( ): This function adaptively computes the number of bits used for quantizing the coding error of each vertex of ith instance based on QP_coord.
In TABLE 5, exemplary syntax and semantics for rotation angles are illustrated for the present principles. The rotation of the ith instance in a spherical mode is represented by three angles: alpha, beta and gamma.
compr_elem_insta_rotat_alpha: This data field contains the compressed alpha of ith instance's rotation.
compr_elem_insta_rotat_beta: This data field contains the compressed beta of ith instance's rotation.
compr_elem_insta_rotat_gamma: This data field contains the compressed gamma of ith instance's rotation.
bit_num_rotat_alpha( ): This function adaptively computes the number of bits for the alpha value of ith instance's rotation based on QP_coord and the scale of the corresponding pattern.
bit_num_rotat_beta( ): This function computes the number of bits for the beta value of ith instance's rotation based on QP_coord and the scale of the corresponding pattern.
bit_num_rotat_gamma( ): This function computes the number of bits for the gamma value of ith instance's rotation based on QP_coord and the scale of the corresponding pattern.
The implementations described herein may be implemented in, for example, a method or a process, an apparatus, a software program, a data stream, or a signal. Even if only discussed in the context of a single form of implementation (for example, discussed only as a method), the implementation of features discussed may also be implemented in other forms (for example, an apparatus or program). An apparatus may be implemented in, for example, appropriate hardware, software, and firmware. The methods may be implemented in, for example, an apparatus such as, for example, a processor, which refers to processing devices in general, including, for example, a computer, a microprocessor, an integrated circuit, or a programmable logic device. Processors also include communication devices, such as, for example, computers, cell phones, portable/personal digital assistants (“PDAs”), and other devices that facilitate communication of information between end-users.
Reference to “one embodiment” or “an embodiment” or “one implementation” or “an implementation” of the present principles, as well as other variations thereof, mean that a particular feature, structure, characteristic, and so forth described in connection with the embodiment is included in at least one embodiment of the present principles. Thus, the appearances of the phrase “in one embodiment” or “in an embodiment” or “in one implementation” or “in an implementation”, as well any other variations, appearing in various places throughout the specification are not necessarily all referring to the same embodiment.
Additionally, this application or its claims may refer to “determining” various pieces of information. Determining the information may include one or more of, for example, estimating the information, calculating the information, predicting the information, or retrieving the information from memory.
Further, this application or its claims may refer to “accessing” various pieces of information. Accessing the information may include one or more of, for example, receiving the information, retrieving the information (for example, from memory), storing the information, processing the information, transmitting the information, moving the information, copying the information, erasing the information, calculating the information, determining the information, predicting the information, or estimating the information.
Additionally, this application or its claims may refer to “receiving” various pieces of information. Receiving is, as with “accessing”, intended to be a broad term. Receiving the information may include one or more of, for example, accessing the information, or retrieving the information (for example, from memory). Further, “receiving” is typically involved, in one way or another, during operations such as, for example, storing the information, processing the information, transmitting the information, moving the information, copying the information, erasing the information, calculating the information, determining the information, predicting the information, or estimating the information.
As will be evident to one of skill in the art, implementations may produce a variety of signals formatted to carry information that may be, for example, stored or transmitted. The information may include, for example, instructions for performing a method, or data produced by one of the described implementations. For example, a signal may be formatted to carry the bitstream of a described embodiment. Such a signal may be formatted, for example, as an electromagnetic wave (for example, using a radio frequency portion of spectrum) or as a baseband signal. The formatting may include, for example, encoding a data stream and modulating a carrier with the encoded data stream. The information that the signal carries may be, for example, analog or digital information. The signal may be transmitted over a variety of different wired or wireless links, as is known. The signal may be stored on a processor-readable medium.
Number | Date | Country | Kind |
---|---|---|---|
PCTCN2012074388 | Apr 2012 | CN | national |
This application claims the benefit of International Patent Application No. PCT/CN2012/074388filed Apr. 19, 2012, which is hereby incorporated by reference.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CN2012/087937 | 12/29/2012 | WO | 00 |