From 4f3ef0864f6c6c4e453f332a1d2cdf97a34c3488 Mon Sep 17 00:00:00 2001 From: Eric Wieser Date: Fri, 27 Mar 2020 13:15:49 +0000 Subject: [PATCH 1/2] Revert "Make sure `__module__` is set correctly on public types" This reverts commit d3258b2c38d24931ee60584f2bd35df736bc91a1. This broke `inspect.getsource(MultiVector)`, which in turn breaks `:member-order: by-source` in sphinx --- clifford/_blademap.py | 4 ---- clifford/_conformal_layout.py | 2 -- clifford/_frame.py | 3 --- clifford/_layout.py | 2 -- clifford/_layout_helpers.py | 3 --- clifford/_multivector.py | 2 -- clifford/_mvarray.py | 2 -- clifford/_utils.py | 13 ------------- 8 files changed, 31 deletions(-) delete mode 100644 clifford/_utils.py diff --git a/clifford/_blademap.py b/clifford/_blademap.py index 726750d6..72c1e4b1 100644 --- a/clifford/_blademap.py +++ b/clifford/_blademap.py @@ -1,7 +1,3 @@ -from . import _utils - - -@_utils.set_module('clifford') class BladeMap(object): ''' A Map Relating Blades in two different algebras diff --git a/clifford/_conformal_layout.py b/clifford/_conformal_layout.py index ee95a427..82a53a84 100644 --- a/clifford/_conformal_layout.py +++ b/clifford/_conformal_layout.py @@ -2,10 +2,8 @@ from ._layout import Layout from ._multivector import MultiVector -from . import _utils -@_utils.set_module('clifford') class ConformalLayout(Layout): r""" A layout for a conformal algebra, which adds extra constants and helpers. diff --git a/clifford/_frame.py b/clifford/_frame.py index e86e2857..1ac1ff42 100644 --- a/clifford/_frame.py +++ b/clifford/_frame.py @@ -6,11 +6,8 @@ from ._mvarray import MVArray from .operator import op from . import _settings -from . import _utils -from ._multivector import MultiVector -@_utils.set_module('clifford') class Frame(MVArray): ''' A frame of vectors diff --git a/clifford/_layout.py b/clifford/_layout.py index e3dae328..c578a152 100644 --- a/clifford/_layout.py +++ b/clifford/_layout.py @@ -18,7 +18,6 @@ from . import _numba_utils from .io import read_ga_file from . import _settings -from . import _utils from ._multivector import MultiVector from ._layout_helpers import ( BasisBladeOrder, BasisVectorIds, canonical_reordering_sign_euclidean @@ -160,7 +159,6 @@ def construct_tables( ) -@_utils.set_module('clifford') class Layout(object): r""" Layout stores information regarding the geometric algebra itself and the internal representation of multivectors. diff --git a/clifford/_layout_helpers.py b/clifford/_layout_helpers.py index 7722bae8..310c3d93 100644 --- a/clifford/_layout_helpers.py +++ b/clifford/_layout_helpers.py @@ -14,7 +14,6 @@ import operator from . import _numba_utils -from . import _utils import numba import numba.extending import numba.types @@ -73,7 +72,6 @@ def _is_unique(x) -> bool: return len(x) == len(set(x)) -@_utils.set_module('clifford') class BasisBladeOrder: """ Represents the storage order in memory of basis blade coefficients. @@ -172,7 +170,6 @@ def __reduce__(self): IdT = TypeVar('IdT') -@_utils.set_module('clifford') class BasisVectorIds(Generic[IdT]): """ Stores ids for the ordered set of basis vectors, typically integers. diff --git a/clifford/_multivector.py b/clifford/_multivector.py index b657732b..983a3788 100644 --- a/clifford/_multivector.py +++ b/clifford/_multivector.py @@ -7,10 +7,8 @@ import clifford as cf from . import general_exp from . import _settings -from . import _utils -@_utils.set_module('clifford') class MultiVector(object): """An element of the algebra diff --git a/clifford/_mvarray.py b/clifford/_mvarray.py index 70b9f732..6c021e78 100644 --- a/clifford/_mvarray.py +++ b/clifford/_mvarray.py @@ -3,14 +3,12 @@ from clifford.io import write_ga_file, read_ga_file # noqa: F401 from ._multivector import MultiVector -from . import _utils dual_array = np.vectorize(MultiVector.dual) normal_array = np.vectorize(MultiVector.normal) call_array = np.vectorize(MultiVector.__call__) -@_utils.set_module('clifford') class MVArray(np.ndarray): ''' MultiVector Array diff --git a/clifford/_utils.py b/clifford/_utils.py deleted file mode 100644 index dc737d99..00000000 --- a/clifford/_utils.py +++ /dev/null @@ -1,13 +0,0 @@ -def set_module(module_name): - """ - Helper to override the `__module__` of a definition. - - This is useful for moving class and function definitions to subfiles - without affecting: - * :mod:`pickle`, which will saves the module name - * Sphinx, which uses the module name in link targets - """ - def decorator(obj): - obj.__module__ = module_name - return obj - return decorator From 8ae7ec76e3f4ca323475df91dd5ae506f888511f Mon Sep 17 00:00:00 2001 From: Eric Wieser Date: Thu, 26 Mar 2020 13:51:42 +0000 Subject: [PATCH 2/2] Manually tailor the class documentation pages Notably, this: * Puts all the member docs in a single page, since there aren't that many of them * Fixes `Frame` to not show numpy documentation * Add `MVArray` to the docs * Makes the documentation for the operator overloads visible. --- .gitignore | 2 ++ clifford/__init__.py | 22 ++++++++++++---------- clifford/_frame.py | 1 + docs/{ => api}/cga.rst | 0 docs/api/clifford.BasisBladeOrder.rst | 9 +++++++++ docs/api/clifford.BasisVectorIds.rst | 9 +++++++++ docs/api/clifford.BladeMap.rst | 9 +++++++++ docs/api/clifford.Cl.rst | 6 ++++++ docs/api/clifford.ConformalLayout.rst | 10 ++++++++++ docs/api/clifford.Frame.rst | 11 +++++++++++ docs/api/clifford.Layout.rst | 9 +++++++++ docs/api/clifford.MVarray.rst | 11 +++++++++++ docs/api/clifford.MultiVector.rst | 11 +++++++++++ docs/api/clifford.conformalize.rst | 6 ++++++ docs/api/clifford.grade_obj.rst | 6 ++++++ docs/api/clifford.randomMV.rst | 6 ++++++ docs/{ => api}/clifford.rst | 0 docs/{api.rst => api/index.rst} | 0 docs/{ => api}/operator.rst | 0 docs/{ => api}/tools.rst | 0 docs/conf.py | 3 ++- docs/index.rst | 2 +- 22 files changed, 121 insertions(+), 12 deletions(-) rename docs/{ => api}/cga.rst (100%) create mode 100644 docs/api/clifford.BasisBladeOrder.rst create mode 100644 docs/api/clifford.BasisVectorIds.rst create mode 100644 docs/api/clifford.BladeMap.rst create mode 100644 docs/api/clifford.Cl.rst create mode 100644 docs/api/clifford.ConformalLayout.rst create mode 100644 docs/api/clifford.Frame.rst create mode 100644 docs/api/clifford.Layout.rst create mode 100644 docs/api/clifford.MVarray.rst create mode 100644 docs/api/clifford.MultiVector.rst create mode 100644 docs/api/clifford.conformalize.rst create mode 100644 docs/api/clifford.grade_obj.rst create mode 100644 docs/api/clifford.randomMV.rst rename docs/{ => api}/clifford.rst (100%) rename docs/{api.rst => api/index.rst} (100%) rename docs/{ => api}/operator.rst (100%) rename docs/{ => api}/tools.rst (100%) diff --git a/.gitignore b/.gitignore index 21c01fcd..75f415b5 100644 --- a/.gitignore +++ b/.gitignore @@ -60,3 +60,5 @@ target/ .mypy_cache .ipynb_checkpoints + +/docs/api/generated/* diff --git a/clifford/__init__.py b/clifford/__init__.py index f56821cb..8e360349 100644 --- a/clifford/__init__.py +++ b/clifford/__init__.py @@ -14,7 +14,7 @@ Note that typically the :doc:`predefined-algebras` are sufficient, and there is no need to build an algebra from scratch. .. autosummary:: - :toctree: generated/ + :toctree: Cl conformalize @@ -22,7 +22,7 @@ Whether you construct your algebras from scratch, or use the predefined ones, you'll end up working with the following types: .. autosummary:: - :toctree: generated/ + :toctree: MultiVector Layout @@ -43,20 +43,22 @@ ============================== These functions are used to change the global behavior of ``clifford``. -.. autosummary:: - :toctree: generated/ +.. autofunction:: eps + +.. autofunction:: pretty + +.. autofunction:: ugly + +.. autofunction:: print_precision - eps - pretty - ugly - print_precision Miscellaneous classes ======================= .. autosummary:: - :toctree: generated/ + :toctree: + MVArray Frame BladeMap @@ -64,7 +66,7 @@ ======================= .. autosummary:: - :toctree: generated/ + :toctree: grade_obj randomMV diff --git a/clifford/_frame.py b/clifford/_frame.py index 1ac1ff42..fadff1a7 100644 --- a/clifford/_frame.py +++ b/clifford/_frame.py @@ -4,6 +4,7 @@ import numpy as np from ._mvarray import MVArray +from ._multivector import MultiVector from .operator import op from . import _settings diff --git a/docs/cga.rst b/docs/api/cga.rst similarity index 100% rename from docs/cga.rst rename to docs/api/cga.rst diff --git a/docs/api/clifford.BasisBladeOrder.rst b/docs/api/clifford.BasisBladeOrder.rst new file mode 100644 index 00000000..1ae24bb1 --- /dev/null +++ b/docs/api/clifford.BasisBladeOrder.rst @@ -0,0 +1,9 @@ +clifford.BasisBladeOrder +======================== + +.. currentmodule:: clifford + +.. autoclass:: BasisBladeOrder + :members: + :undoc-members: + :member-order: bysource diff --git a/docs/api/clifford.BasisVectorIds.rst b/docs/api/clifford.BasisVectorIds.rst new file mode 100644 index 00000000..b4c3fbdc --- /dev/null +++ b/docs/api/clifford.BasisVectorIds.rst @@ -0,0 +1,9 @@ +clifford.BasisVectorIds +======================== + +.. currentmodule:: clifford + +.. autoclass:: BasisVectorIds + :members: + :undoc-members: + :member-order: bysource diff --git a/docs/api/clifford.BladeMap.rst b/docs/api/clifford.BladeMap.rst new file mode 100644 index 00000000..4e6fcc68 --- /dev/null +++ b/docs/api/clifford.BladeMap.rst @@ -0,0 +1,9 @@ +clifford.BladeMap +================= + +.. currentmodule:: clifford + +.. autoclass:: BladeMap + :members: + :undoc-members: + :member-order: bysource diff --git a/docs/api/clifford.Cl.rst b/docs/api/clifford.Cl.rst new file mode 100644 index 00000000..cbd6e295 --- /dev/null +++ b/docs/api/clifford.Cl.rst @@ -0,0 +1,6 @@ +clifford.Cl +=========== + +.. currentmodule:: clifford + +.. autofunction:: Cl diff --git a/docs/api/clifford.ConformalLayout.rst b/docs/api/clifford.ConformalLayout.rst new file mode 100644 index 00000000..54be76fb --- /dev/null +++ b/docs/api/clifford.ConformalLayout.rst @@ -0,0 +1,10 @@ +clifford.ConformalLayout +======================== + +.. currentmodule:: clifford + +.. autoclass:: ConformalLayout + :members: + :undoc-members: + :show-inheritance: + :member-order: bysource diff --git a/docs/api/clifford.Frame.rst b/docs/api/clifford.Frame.rst new file mode 100644 index 00000000..65197eff --- /dev/null +++ b/docs/api/clifford.Frame.rst @@ -0,0 +1,11 @@ +clifford.Frame +============== + +.. currentmodule:: clifford + +.. autoclass:: Frame + :members: + :undoc-members: + :no-inherited-members: + :show-inheritance: + :member-order: bysource diff --git a/docs/api/clifford.Layout.rst b/docs/api/clifford.Layout.rst new file mode 100644 index 00000000..ecd6cc78 --- /dev/null +++ b/docs/api/clifford.Layout.rst @@ -0,0 +1,9 @@ +clifford.Layout +=============== + +.. currentmodule:: clifford + +.. autoclass:: Layout + :members: + :member-order: bysource + :undoc-members: diff --git a/docs/api/clifford.MVarray.rst b/docs/api/clifford.MVarray.rst new file mode 100644 index 00000000..63c39786 --- /dev/null +++ b/docs/api/clifford.MVarray.rst @@ -0,0 +1,11 @@ +clifford.MVArray +================ + +.. currentmodule:: clifford + +.. autoclass:: MVArray + :members: + :undoc-members: + :special-members: __call__ + :no-inherited-members: + :show-inheritance: diff --git a/docs/api/clifford.MultiVector.rst b/docs/api/clifford.MultiVector.rst new file mode 100644 index 00000000..a4698580 --- /dev/null +++ b/docs/api/clifford.MultiVector.rst @@ -0,0 +1,11 @@ +clifford.MultiVector +==================== + +.. currentmodule:: clifford + +.. autoclass:: MultiVector + :no-inherited-members: + :members: + :undoc-members: + :special-members: __add__, __sub__, __mul__, __xor__, __or__, __invert__, __and__, __getitem__, __call__ + :member-order: bysource diff --git a/docs/api/clifford.conformalize.rst b/docs/api/clifford.conformalize.rst new file mode 100644 index 00000000..758d72f6 --- /dev/null +++ b/docs/api/clifford.conformalize.rst @@ -0,0 +1,6 @@ +clifford.conformalize +===================== + +.. currentmodule:: clifford + +.. autofunction:: conformalize diff --git a/docs/api/clifford.grade_obj.rst b/docs/api/clifford.grade_obj.rst new file mode 100644 index 00000000..29cf722d --- /dev/null +++ b/docs/api/clifford.grade_obj.rst @@ -0,0 +1,6 @@ +clifford.grade\_obj +=================== + +.. currentmodule:: clifford + +.. autofunction:: grade_obj diff --git a/docs/api/clifford.randomMV.rst b/docs/api/clifford.randomMV.rst new file mode 100644 index 00000000..590ccdc4 --- /dev/null +++ b/docs/api/clifford.randomMV.rst @@ -0,0 +1,6 @@ +clifford.randomMV +================= + +.. currentmodule:: clifford + +.. autofunction:: randomMV diff --git a/docs/clifford.rst b/docs/api/clifford.rst similarity index 100% rename from docs/clifford.rst rename to docs/api/clifford.rst diff --git a/docs/api.rst b/docs/api/index.rst similarity index 100% rename from docs/api.rst rename to docs/api/index.rst diff --git a/docs/operator.rst b/docs/api/operator.rst similarity index 100% rename from docs/operator.rst rename to docs/api/operator.rst diff --git a/docs/tools.rst b/docs/api/tools.rst similarity index 100% rename from docs/tools.rst rename to docs/api/tools.rst diff --git a/docs/conf.py b/docs/conf.py index 4b270136..ca00936e 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -117,7 +117,8 @@ #autodoc_default_flags='members' # you have to list all files with automodule here due to bug in sphinx and nbsphinx # https://github.com/spatialaudio/nbsphinx/issues/14 -autosummary_generate=['clifford','tools','cga'] +autosummary_generate=['api/tools', 'api/cga'] +autodoc_member_order = 'bysource' numpydoc_show_class_members = True # Add any paths that contain templates here, relative to this directory. templates_path = ['_templates'] diff --git a/docs/index.rst b/docs/index.rst index e35fd52d..2086d5f7 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -34,7 +34,7 @@ Scalars, vectors, and higher-grade entities can be mixed freely and consistently :hidden: Installation - api + api/index predefined-algebras changelog issues