Sparse convolutional neural network accelerator
US-10891538-B2 · Jan 12, 2021 · US
US11257182B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-11257182-B2 |
| Application number | US-202016943984-A |
| Country | US |
| Kind code | B2 |
| Filing date | Jul 30, 2020 |
| Priority date | May 17, 2018 |
| Publication date | Feb 22, 2022 |
| Grant date | Feb 22, 2022 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
Official abstract text for this publication.
Embodiments are generally directed to GPU mixed primitive topology type processing. An embodiment of an apparatus includes one or more processor cores; and a memory to store data for graphics processing, wherein the one or more processing cores are to generate in the memory a vertex buffer to store vertex data for a mesh to be rendered and an index buffer to index the vertex data stored in the vertex buffer, the index buffer being structured to include index data for multiple primitive topology types. The one or more processor cores are to process the index data for the plurality of primitive topology types from the index buffer and fetch vertex data from the vertex buffer; and are to set up each primitive topology type of the plurality of primitive topology types for processing in a single draw operation.
Opening claim text (preview).
What is claimed is: 1. An apparatus comprising: one or more processor cores; and a memory to store data for graphics processing, wherein the one or more processor cores are to generate in the memory a vertex buffer to store vertex data for a mesh to be rendered and an index buffer to index the vertex data stored in the vertex buffer, the index buffer being structured to include index data for a plurality of primitive topology types, and the index data for each primitive topology type of the plurality of primitive topology types being offset in the index buffer by an offset value for the primitive topology type; wherein the one or more processor cores are to process the index data for the plurality of primitive topology types from the index buffer at least in part according to a topology type, index count, and offset value for each of the plurality of primitive topology types; and wherein the one or more processor cores are to set up each primitive topology type of the plurality of primitive topology types for processing in a single draw operation. 2. The apparatus of claim 1 , wherein the index buffer is to further include index data for one or more non-indexed primitive topology types. 3. The apparatus of claim 1 , wherein the plurality of primitive topology types includes one or more of points, lines, triangles, and quads. 4. The apparatus of claim 1 , further comprising a geometry shader to support output of the plurality of primitive topology types in each of one or more output streams. 5. The apparatus of claim 4 , wherein the geometry shader is to filter primitive topology types and to convert one or more primitive topology types to one or more other primitive topology types. 6. The apparatus of claim 5 , wherein converting one or more primitive topology types to one or more other primitive topology types includes one or more of converting a small triangle to a point or converting two triangles into a quad. 7. A non-transitory computer-readable storage medium having stored thereon data representing sequences of instructions that, when executed by one or more processors, cause the one or more processors to perform operations comprising: loading a mesh for computer graphics, the mesh including a plurality of primitive topology types; generating a single vertex buffer in a computer memory for storage of vertex data for the mesh; generating a single index buffer in the computer memory for storage of index data to index the vertex data stored in the vertex buffer, the index buffer being structured to include index data for each of the plurality of primitive topology types, wherein the index data for each primitive topology type of the plurality of primitive topology types is offset in the index buffer by an offset value for the primitive topology type; and executing a draw operation utilizing the index data for the plurality of primitive topology types from the index buffer at least in part according to a topology type, index count, and offset value for each of the plurality of primitive topology types, the draw operation including each of the plurality of primitive topology types. 8. The medium of claim 7 , wherein generating the index buffer in the computer memory further includes the index buffer being structured to include index data for one or more non-indexed primitive topology types. 9. The medium of claim 7 , further comprising instructions that, when executed by the one or more processors, cause the one or more processors to perform operations comprising: generating an output of the plurality of primitive topology types in each of one or more output streams. 10. The medium of claim 9 , further comprising instructions that, when executed by the one or more processors, cause the one or more processors to perform operations comprising: filtering primitive topology types; and converting one or more primitive topology types to one or more other primitive topology types. 11. The medium of claim 10 , wherein converting one or more primitive topology types to one or more other primitive topology types includes one or more of converting a small triangle to a point or converting two triangles into a quad. 12. A processing system comprising: one or more processor cores; an input assembler; a vertex fetch unit; a rasterizer; and memory to store data for graphics processing, wherein the one or more processor cores are to generate in the memory a vertex buffer to store vertex data for a mesh to be rendered and an index buffer to index the vertex data stored in the vertex buffer, the index buffer being structured to include index data for a plurality of primitive topology types, and the index data for each primitive topology type of the plurality of primitive topology types being offset in the index buffer by an offset value for the primitive topology type; wherein the input assembler is to process the index data for the plurality of primitive topology types from the index buffer at least in part according to a topology type, index count, and offset value for each of the plurality of primitive topology types; and wherein the input assembler is to communicate a message to the rasterizer to set up each primitive topology type of the plurality of primitive topology types for processing by the rasterizer in a single draw operation. 13. The processing system of claim 12 , wherein the index buffer is further to include index data for one or more non-indexed primitive topology types. 14. The processing system of claim 12 , further comprising a geometry shader to support output of the plurality of primitive topology types in each of one or more output streams. 15. The processing system of claim 14 , wherein the geometry shader is to filter primitive topology types and to convert one or more primitive topology types to one or more other primitive topology types. 16. The processing system of claim 15 , wherein converting one or more primitive topology types to one or more other primitive topology types includes one or more of converting a small triangle to a point or converting two triangles into a quad.
Processor architectures; Processor configuration, e.g. pipelining · CPC title
Constructive solid geometry [CSG] using solid primitives, e.g. cylinders, cubes · CPC title
General purpose rendering architectures · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.