All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.simiacryptus.mindseye.network.InnerNode Maven / Gradle / Ivy

There is a newer version: 2.1.0
Show newest version
/*
 * Copyright (c) 2019 by Andrew Charneski.
 *
 * The author licenses this file to you under the
 * Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance
 * with the License.  You may obtain a copy
 * of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */

package com.simiacryptus.mindseye.network;

import com.simiacryptus.mindseye.lang.CoreSettings;
import com.simiacryptus.mindseye.lang.Layer;
import com.simiacryptus.mindseye.lang.Result;
import com.simiacryptus.ref.lang.RefUtil;
import com.simiacryptus.ref.wrappers.RefArrays;
import com.simiacryptus.ref.wrappers.RefStream;

import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.UUID;

@SuppressWarnings("serial")
public final class InnerNode extends LazyResult {
  @SuppressWarnings("unused")
  //public final CharSequence[] createdBy = Util.currentStack();
  @Nonnull
  private final DAGNode[] inputNodes;
  @Nullable
  private volatile Layer layer;
  private boolean parallel = true;

  @SafeVarargs
  InnerNode(@Nonnull final Layer layer, final DAGNode... inputNodes) {
    this(layer, UUID.randomUUID(), inputNodes);
  }

  @SafeVarargs
  InnerNode(@Nonnull final Layer layer, final UUID key,
            @Nonnull final DAGNode... inputNodes) {
    super(key);
    setLayer(layer);
    if (0 == inputNodes.length) {
      this.inputNodes = new DAGNode[]{};
      RefUtil.freeRef(inputNodes);
    } else {
      assert RefUtil.assertAlive(inputNodes);
      this.inputNodes = RefArrays.copyOf(inputNodes, inputNodes.length);
    }
  }

  @Nonnull
  @Override
  public DAGNode[] getInputs() {
    return RefUtil.addRef(inputNodes);
  }

  @Nonnull
  @SuppressWarnings("unchecked")
  @Override
  public  T getLayer() {
    assertAlive();
    return (T) layer.addRef();
  }

  @Override
  public synchronized void setLayer(@Nonnull final Layer newLayer) {
    assertAlive();
    newLayer.assertAlive();
    if (newLayer != this.layer) {
      if (null != this.layer)
        this.layer.freeRef();
      this.layer = newLayer;
    } else {
      newLayer.freeRef();
    }
  }

  public boolean isParallel() {
    return parallel;
  }

  public void setParallel(boolean parallel) {
    this.parallel = parallel;
  }


  public void _free() {
    if (null != layer) {
      layer.freeRef();
      layer = null;
    }
    RefUtil.freeRef(inputNodes);
    super._free();
  }

  @Nonnull
  public @Override
  @SuppressWarnings("unused")
  InnerNode addRef() {
    return (InnerNode) super.addRef();
  }

  @Nullable
  @Override
  protected Result eval(@Nullable final GraphEvaluationContext ctx) {
    assertAlive();
    @Nonnull final Layer innerLayer = getLayer();
    try {
      @Nonnull
      RefStream stream = RefArrays.stream(RefUtil.addRef(inputNodes));
      if (!CoreSettings.INSTANCE().singleThreaded && parallel)
        stream = stream.parallel();
      return innerLayer.eval(stream.map(node -> {
        try {
          assert node != null;
          return node.get(ctx.addRef(), innerLayer.addRef());
        } finally {
          node.freeRef();
        }
      }).toArray(Result[]::new));
    } finally {
      ctx.freeRef();
      innerLayer.freeRef();
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy