Skip to content

Commit

Permalink
Move some symbols to the root, fix docs
Browse files Browse the repository at this point in the history
  • Loading branch information
inducer committed Nov 4, 2024
1 parent faf7085 commit eeba23e
Show file tree
Hide file tree
Showing 6 changed files with 55 additions and 26 deletions.
11 changes: 11 additions & 0 deletions doc/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -60,4 +60,15 @@
# As of 2022-06-22, it doesn't look like there's sphinx documentation
# available.
["py:class", r"immutables\.(.+)"],

# Reference not found from "<unknown>"? I'm not even sure where to look.
["py:class", r"Expression"],
]

autodoc_type_aliases = {
"ToLoopyTypeConvertible": "ToLoopyTypeConvertible",
"ExpressionT": "ExpressionT",
"InameStr": "InameStr",
"ShapeType": "ShapeType",
"StridesType": "StridesType",
}
5 changes: 4 additions & 1 deletion loopy/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -205,7 +205,7 @@
)
from loopy.translation_unit import TranslationUnit, for_each_kernel, make_program
from loopy.type_inference import infer_unknown_types
from loopy.types import to_loopy_type
from loopy.types import LoopyType, NumpyType, ToLoopyTypeConvertible, to_loopy_type
from loopy.typing import auto
from loopy.version import MOST_RECENT_LANGUAGE_VERSION, VERSION

Expand Down Expand Up @@ -248,12 +248,14 @@
"LinearSubscript",
"LoopKernel",
"LoopyError",
"LoopyType",
"LoopyWarning",
"MemAccess",
"MemoryOrdering",
"MemoryScope",
"MultiAssignmentBase",
"NoOpInstruction",
"NumpyType",
"Op",
"OpenCLTarget",
"Optional",
Expand All @@ -270,6 +272,7 @@
"TemporaryVariable",
"ToCountMap",
"ToCountPolynomialMap",
"ToLoopyTypeConvertible",
"TranslationUnit",
"TypeCast",
"UniqueName",
Expand Down
6 changes: 6 additions & 0 deletions loopy/codegen/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,12 @@
.. automodule:: loopy.codegen.result
.. automodule:: loopy.codegen.tools
References
^^^^^^^^^^
.. class:: Expression
See :class:`pymbolic.Expression`.
"""


Expand Down
7 changes: 7 additions & 0 deletions loopy/kernel/data.py
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,13 @@
.. autoclass:: UnrollTag
.. autoclass:: Iname
References
^^^^^^^^^^
.. class:: ToLoopyTypeConvertible
See :class:`loopy.ToLoopyTypeConvertible`.
"""

# This docstring is included in ref_internals. Do not include parts of the public
Expand Down
43 changes: 20 additions & 23 deletions loopy/symbolic.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@
import pymbolic.primitives as p
import pytools.lex
from islpy import dim_type
from pymbolic import ArithmeticExpressionT
from pymbolic import ArithmeticExpressionT, Variable
from pymbolic.mapper import (
CachedCombineMapper as CombineMapperBase,
CachedIdentityMapper as IdentityMapperBase,
Expand Down Expand Up @@ -92,40 +92,37 @@
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
.. autoclass:: Literal
.. autoclass:: ArrayLiteral
.. autoclass:: FunctionIdentifier
.. autoclass:: TypedCSE
.. currentmodule:: loopy
.. autoclass:: TypeCast
.. autoclass:: TaggedVariable
.. autoclass:: Reduction
.. autoclass:: LinearSubscript
.. currentmodule:: loopy.symbolic
.. autoclass:: RuleArgument
.. autoclass:: ExpansionState
.. autoclass:: RuleAwareIdentityMapper
.. autoclass:: ResolvedFunction
.. autoclass:: SubArrayRef
Expression Manipulation Helpers
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
.. autofunction:: simplify_using_aff
References
^^^^^^^^^^
.. class:: Variable
See :class:`pymbolic.Variable`.
"""


Expand Down Expand Up @@ -154,7 +151,7 @@ def map_reduction(self, expr, *args, **kwargs):

new_inames = []
for iname, new_sym_iname in zip(expr.inames, mapped_inames):
if not isinstance(new_sym_iname, p.Variable):
if not isinstance(new_sym_iname, Variable):
from loopy.diagnostic import LoopyError
raise LoopyError("%s did not map iname '%s' to a variable"
% (type(self).__name__, iname))
Expand Down Expand Up @@ -436,7 +433,7 @@ def map_call(self, expr, *args, **kwargs):

def map_reduction(self, expr, *args, **kwargs):
deps = self.rec(expr.expr, *args, **kwargs)
return deps - {p.Variable(iname) for iname in expr.inames}
return deps - {Variable(iname) for iname in expr.inames}

def map_tagged_variable(self, expr, *args, **kwargs):
return {expr}
Expand Down Expand Up @@ -649,7 +646,7 @@ def type(self) -> NumpyType:


@p.expr_dataclass(init=False)
class TaggedVariable(LoopyExpressionBase, p.Variable, Taggable):
class TaggedVariable(LoopyExpressionBase, Variable, Taggable):
"""This is an identifier with tags, such as ``matrix$one``, where
'one' identifies this specific use of the identifier. This mechanism
may then be used to address these uses--such as by prefetching only
Expand All @@ -670,7 +667,7 @@ class TaggedVariable(LoopyExpressionBase, p.Variable, Taggable):
"""

def __init__(self, name: str, tags: ToTagSetConvertible) -> None:
p.Variable.__init__(self, name)
Variable.__init__(self, name)
if isinstance(tags, str):
from loopy.kernel.creation import _normalize_string_tag
tags = frozenset({_normalize_string_tag(tags)})
Expand Down Expand Up @@ -730,13 +727,13 @@ def __init__(self,
if isinstance(inames, str):
inames = tuple(iname.strip() for iname in inames.split(","))

elif isinstance(inames, p.Variable):
elif isinstance(inames, Variable):
inames = (inames,)

assert isinstance(inames, tuple)

def strip_var(iname: Any) -> str:
if isinstance(iname, p.Variable):
if isinstance(iname, Variable):
iname = iname.name

assert isinstance(iname, str)
Expand Down Expand Up @@ -811,19 +808,19 @@ class ResolvedFunction(LoopyExpressionBase):
.. autoattribute:: function
.. autoattribute:: name
"""
function: p.Variable | ReductionOpFunction
function: Variable | ReductionOpFunction

def __init__(self, function: Variable | ReductionOpFunction) -> None:
if isinstance(function, str):
function = p.Variable(function)
function = Variable(function)
from loopy.library.reduction import ReductionOpFunction
assert isinstance(function, (p.Variable, ReductionOpFunction))
assert isinstance(function, (Variable, ReductionOpFunction))
object.__setattr__(self, "function", function)

@property
def name(self) -> str | ReductionOpFunction:
from loopy.library.reduction import ReductionOpFunction
if isinstance(self.function, p.Variable):
if isinstance(self.function, Variable):
return self.function.name
elif isinstance(self.function, ReductionOpFunction):
return self.function
Expand Down Expand Up @@ -851,7 +848,7 @@ def map_variable(self, expr):

class VariableInAnExpression(CombineMapper):
def __init__(self, variables_to_search):
assert all(isinstance(variable, p.Variable) for variable in
assert all(isinstance(variable, Variable) for variable in
variables_to_search)
self.variables_to_search = variables_to_search

Expand Down Expand Up @@ -919,7 +916,7 @@ class SubArrayRef(LoopyExpressionBase):
.. automethod:: is_equal
"""
swept_inames: tuple[p.Variable, ...]
swept_inames: tuple[Variable, ...]
subscript: p.Subscript

def __post_init__(self):
Expand Down
9 changes: 7 additions & 2 deletions loopy/types.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,18 +26,23 @@
from typing import Any, Mapping, Type, Union

import numpy as np
from typing_extensions import TypeAlias

from loopy.diagnostic import LoopyError
from loopy.typing import auto


__doc__ = """
.. currentmodule:: loopy.types
.. currentmodule:: loopy
.. autoclass:: LoopyType
.. autoclass:: ToLoopyTypeConvertible
.. autoclass:: NumpyType
.. currentmodule:: loopy.types
.. autoclass:: AtomicType
.. autoclass:: AtomicNumpyType
Expand Down Expand Up @@ -197,7 +202,7 @@ def __eq__(self, other: object) -> bool:
# }}}


ToLoopyTypeConvertible = Union[Type[auto], None, np.dtype, LoopyType]
ToLoopyTypeConvertible: TypeAlias = Union[Type[auto], None, np.dtype, LoopyType]


def to_loopy_type(dtype: ToLoopyTypeConvertible,
Expand Down

0 comments on commit eeba23e

Please sign in to comment.