cgen – C-Generation Reference Documentation

cgen.dtype_to_ctype(dtype: Any) str[source]
class cgen.Generable[source]

Bases: ABC

__str__() str[source]
Returns:

a single string (possibly containing newlines) representing this code construct.

abstract generate(with_semicolon: bool = True) Iterator[str][source]

Generate (i.e. yield) the lines making up this code construct.

class cgen.Block(contents: Sequence[Generable] | None = None)[source]

Bases: Generable

class cgen.Collection(contents: Sequence[Generable] | None = None)[source]

Bases: Block

cgen.Module[source]

alias of Collection

class cgen.Line(text: str = '')[source]

Bases: Generable

Data and Functions

class cgen.FunctionBody(fdecl: NestedDeclarator, body: Block)[source]

Bases: Generable

class cgen.Initializer(vdecl: Declarator, data: str)[source]

Bases: Generable

Preprocessor Code

class cgen.Define(symbol: str, value: str)[source]

Bases: Generable

class cgen.Comment(text: str, skip_space: bool = False)[source]

Bases: Generable

class cgen.Include(filename: str, system: bool = True)[source]

Bases: Generable

class cgen.Pragma(value: str)[source]

Bases: Generable

Declarators

class cgen.Declarator[source]

Bases: Generable, ABC

generate(with_semicolon: bool = True) Iterator[str][source]

Generate (i.e. yield) the lines making up this code construct.

abstract get_decl_pair() tuple[list[str], str | None][source]
Returns:

a tuple (type_lines, rhs). type_lines is a non-empty list of lines (most often just a single one) describing the type of this declarator. rhs is the right-hand side that actually contains the function/array/constness notation making up the bulk of the declarator syntax.

inline(with_semicolon: bool = False) str[source]
Returns:

the declarator as a single line.

class cgen.Value(typename: str, name: str)[source]

Bases: Declarator

A simple declarator: typename and name are given as strings.

class cgen.POD(dtype: Any, name: str)[source]

Bases: Declarator

A simple declarator: The type is given as a numpy.dtype and the name is given as a string.

class cgen.Struct(tpname: str, fields: Sequence[Declarator], declname: str | None = None, pad_bytes: int = 0)[source]

Bases: Declarator

A structure declarator.

class cgen.GenerableStruct(tpname: str, fields: Sequence[Declarator], declname: str | None = None, align_bytes: int | None = None, aligned_prime_to: Sequence[int] | None = None)[source]

Bases: Struct

__init__(tpname: str, fields: Sequence[Declarator], declname: str | None = None, align_bytes: int | None = None, aligned_prime_to: Sequence[int] | None = None) None[source]

Initialize a structure declarator.

Parameters:
  • tpname – the name of the structure.

  • declname – the name used for the declarator.

  • pad_bytes – the number of padding bytes added at the end of the structure.

  • fields – a list of Declarator instances.

  • align_bytes – an integer that causes the structure to be padded to an integer multiple of itself.

  • aligned_prime_to – a sequence of integers. If the resulting structure’s size is s, then s//align_bytes will be made prime to all numbers in aligned_prime_to. (Sounds obscure? It’s needed for avoiding bank conflicts in CUDA programming.)

__len__() int[source]

Return the number of bytes occupied by this struct.

make(**kwargs: Any) str[source]

Build a binary, packed representation of self in a str instance with members set to the values specified in kwargs.

make_with_defaults(**kwargs: Any) str[source]

Build a binary, packed representation of self in a str instance with members set to the values specified in kwargs.

Unlike make(), not all members have to occur in kwargs.

struct_format() str[source]

Return the format of the struct as digested by the struct module.

class cgen.Enum[source]

Bases: Generable

An enum-like class for Python that can generate an equivalent C-level declaration. Does not work within the usual “declarator” framework because it uses macros to define values, and a separate typedef to define the value type.

Added in version 2013.2.

To use, derive from this class, and define the following things:

c_name: ClassVar[str]
dtype: ClassVar[dtype[Any]]
c_value_prefix: ClassVar[str]

A (usually upper-case) prefix to be used as a prefix to the names defined on the Python side.

VALUE

Any class attribute with an all-upper-case name is taken to be as an enum value.

classmethod get_c_defines() str[source]

Return a string with C defines corresponding to these constants.

classmethod stringify_value(val: Any) str[source]

Return a string description of the flags set in val.

Nested Declarators

class cgen.NestedDeclarator(subdecl: Declarator)[source]

Bases: Declarator

class cgen.ArrayOf(subdecl: Declarator, count: int | None = None)[source]

Bases: NestedDeclarator

class cgen.Const(subdecl: Declarator)[source]

Bases: NestedDeclarator

class cgen.FunctionDeclaration(subdecl: Declarator, arg_decls: Sequence[Declarator])[source]

Bases: NestedDeclarator

class cgen.MaybeUnused(subdecl: Declarator)[source]

Bases: NestedDeclarator

class cgen.Pointer(subdecl: Declarator)[source]

Bases: NestedDeclarator

class cgen.Reference(subdecl: Declarator)[source]

Bases: Pointer

class cgen.Template(template_spec: str, subdecl: Declarator)[source]

Bases: NestedDeclarator

class cgen.AlignedAttribute(align_bytes: int, subdecl: Declarator)[source]

Bases: NestedDeclarator

Assigns an alignment for a definition of a type or an array.

class cgen.AlignValueAttribute(align_bytes: int, subdecl: Declarator)[source]

Bases: NestedDeclarator

Assigns an alignment for value of a pointer.

This is used for pointers where the user guarantees to the compiler that the value of the pointer has the alignment stated. AlignedAttribute on the other hand tells the compiler to declare the type or the array with the given alignment and cannot be used for telling the compiler that an existing pointer has a certain alignment guarantee.

This attribute is currently supported by clang [1] and Intel [2] and is ignored by gcc.

Declaration Specifiers

class cgen.DeclSpecifier(subdecl: Declarator, spec: str, sep: str = ' ')[source]

Bases: NestedDeclarator

class cgen.Static(subdecl: Declarator)[source]

Bases: DeclSpecifier

class cgen.Typedef(subdecl: Declarator)[source]

Bases: DeclSpecifier

Statements

class cgen.Statement(text: str)[source]

Bases: Generable

class cgen.Assign(lvalue: str, rvalue: str)[source]

Bases: Generable

class cgen.If(condition: str, then_: Generable, else_: Generable | None = None)[source]

Bases: Generable

cgen.make_multiple_ifs(conditions_and_blocks: Sequence[tuple[str, Generable]], base: str | Generable | None = None) Generable | None[source]
class cgen.Loop(body: Generable)[source]

Bases: Generable

class cgen.DoWhile(condition: str, body: Generable)[source]

Bases: Loop

class cgen.For(start: str, condition: str, update: str, body: Generable)[source]

Bases: Loop

class cgen.While(condition: str, body: Generable)[source]

Bases: Loop

cgen.cuda – Extensions to generate CUDA-compatible C Sources

This module adds a few Nvidia CUDA features to cgen’s repertoire. This makes cgen a perfect complement to PyCuda: cgen generates the code, PyCuda compiles it, uploads it to the GPU and executes it.

The PyCuda manual has a tutorial on using the two together.

class cgen.cuda.CudaGlobal(subdecl: Declarator)[source]

Bases: DeclSpecifier

class cgen.cuda.CudaDevice(subdecl: Declarator)[source]

Bases: DeclSpecifier

class cgen.cuda.CudaShared(subdecl: Declarator)[source]

Bases: DeclSpecifier

class cgen.cuda.CudaConstant(subdecl: Declarator)[source]

Bases: DeclSpecifier

cgen.opencl – Extensions to generate OpenCL-compatible C Sources

cgen.opencl.dtype_to_cltype(dtype: Any) str[source]

Kernels and Kernel Arguments

class cgen.opencl.CLKernel(subdecl: Declarator)[source]

Bases: DeclSpecifier

class cgen.opencl.CLConstant(subdecl: Declarator)[source]

Bases: DeclSpecifier

class cgen.opencl.CLLocal(subdecl: Declarator)[source]

Bases: DeclSpecifier

class cgen.opencl.CLGlobal(subdecl: Declarator)[source]

Bases: DeclSpecifier

class cgen.opencl.CLImage(dims: int, mode: Literal['r', 'w'], name: str)[source]

Bases: Value

Function Attributes

class cgen.opencl.CLVecTypeHint(subdecl: Declarator, dtype: Any = None, count: int | None = None, type_str: str | None = None)[source]

Bases: NestedDeclarator

class cgen.opencl.CLWorkGroupSizeHint(dim: tuple[int, ...], subdecl: Declarator)[source]

See Sec 6.7.2 of OpenCL 2.0 spec, Version V2.2-11.

class cgen.opencl.CLRequiredWorkGroupSize(dim: tuple[int, ...], subdecl: Declarator)[source]

See Sec 6.7.2 of OpenCL 2.0 spec, Version V2.2-11.

Vector PODs

class cgen.opencl.CLVectorPOD(dtype: Any, count: int, name: str)[source]

Bases: Declarator