Ejemplo n.º 1
0
def _hide_module_model_and_layer_methods():
  """Hide methods and properties defined in the base classes of Keras layers.

  We hide all methods and properties of the base classes, except:
  - `__init__` is always documented.
  - `call` is always documented, as it can carry important information for
    complex layers.
  """
  module_contents = list(tf.Module.__dict__.items())
  model_contents = list(tf.keras.Model.__dict__.items())
  layer_contents = list(tf.keras.layers.Layer.__dict__.items())

  for name, obj in module_contents + layer_contents + model_contents:
    if name == '__init__':
      # Always document __init__.
      continue

    if name == 'call':
      # Always document `call`.
      if hasattr(obj, doc_controls._FOR_SUBCLASS_IMPLEMENTERS):  # pylint: disable=protected-access
        delattr(obj, doc_controls._FOR_SUBCLASS_IMPLEMENTERS)  # pylint: disable=protected-access
      continue

    # Otherwise, exclude from documentation.
    if isinstance(obj, property):
      obj = obj.fget

    if isinstance(obj, (staticmethod, classmethod)):
      obj = obj.__func__

    try:
      doc_controls.do_not_doc_in_subclasses(obj)
    except AttributeError:
      pass
Ejemplo n.º 2
0
def _hide_layer_and_module_methods():
    """Hide methods and properties defined in the base classes of keras layers."""
    # __dict__ only sees attributes defined in *this* class, not on parent classes
    module_contents = list(tf.Module.__dict__.items())
    layer_contents = list(tf.keras.layers.Layer.__dict__.items())

    for name, obj in module_contents + layer_contents:
        if name == "__init__":
            continue

        if isinstance(obj, property):
            obj = obj.fget

        if isinstance(obj, (staticmethod, classmethod)):
            obj = obj.__func__

        try:
            doc_controls.do_not_doc_in_subclasses(obj)
        except AttributeError:
            pass
Ejemplo n.º 3
0
def _hide_layer_and_module_methods():
    """Hide methods and properties defined in the base classes of keras layers."""
    # __dict__ only sees attributes defined in *this* class, not on parent classes
    # Needed to ignore redudant subclass documentation
    layer_contents = list(tf.keras.layers.Layer.__dict__.items())
    model_contents = list(tf.keras.Model.__dict__.items())
    module_contents = list(tf.Module.__dict__.items())
    optimizer_contents = list(tf.compat.v1.train.Optimizer.__dict__.items())

    for name, obj in model_contents + layer_contents + module_contents + optimizer_contents:

        if name == '__init__':
            continue

        if isinstance(obj, property):
            obj = obj.fget

        if isinstance(obj, (staticmethod, classmethod)):
            obj = obj.__func__

        try:
            doc_controls.do_not_doc_in_subclasses(obj)
        except AttributeError:
            pass