/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF 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 org.apache.commons.math3.ml.neuralnet.twod.util;
import java.util.Map;
import java.util.HashMap;
import org.apache.commons.math3.ml.neuralnet.Neuron;
import org.apache.commons.math3.ml.neuralnet.twod.NeuronSquareMesh2D;
import org.apache.commons.math3.exception.MathIllegalStateException;
Helper class to find the grid coordinates of a neuron.
Since: 3.6
/**
* Helper class to find the grid coordinates of a neuron.
* @since 3.6
*/
public class LocationFinder {
Identifier to location mapping. /** Identifier to location mapping. */
private final Map<Long, Location> locations = new HashMap<Long, Location>();
Container holding a (row, column) pair.
/**
* Container holding a (row, column) pair.
*/
public static class Location {
Row index. /** Row index. */
private final int row;
Column index. /** Column index. */
private final int column;
Params: - row – Row index.
- column – Column index.
/**
* @param row Row index.
* @param column Column index.
*/
public Location(int row,
int column) {
this.row = row;
this.column = column;
}
Returns: the row index.
/**
* @return the row index.
*/
public int getRow() {
return row;
}
Returns: the column index.
/**
* @return the column index.
*/
public int getColumn() {
return column;
}
}
Builds a finder to retrieve the locations of neurons that belong to the given map
. Params: - map – Map.
Throws: - MathIllegalStateException – if the network contains non-unique identifiers. This indicates an inconsistent state due to a bug in the construction code of the underlying
network
.
/**
* Builds a finder to retrieve the locations of neurons that
* belong to the given {@code map}.
*
* @param map Map.
*
* @throws MathIllegalStateException if the network contains non-unique
* identifiers. This indicates an inconsistent state due to a bug in
* the construction code of the underlying
* {@link org.apache.commons.math3.ml.neuralnet.Network network}.
*/
public LocationFinder(NeuronSquareMesh2D map) {
final int nR = map.getNumberOfRows();
final int nC = map.getNumberOfColumns();
for (int r = 0; r < nR; r++) {
for (int c = 0; c < nC; c++) {
final Long id = map.getNeuron(r, c).getIdentifier();
if (locations.get(id) != null) {
throw new MathIllegalStateException();
}
locations.put(id, new Location(r, c));
}
}
}
Retrieves a neuron's grid coordinates.
Params: - n – Neuron.
Returns: the (row, column) coordinates of n
, or null
if no such neuron belongs to the
map used to build this instance
.
/**
* Retrieves a neuron's grid coordinates.
*
* @param n Neuron.
* @return the (row, column) coordinates of {@code n}, or {@code null}
* if no such neuron belongs to the {@link #LocationFinder(NeuronSquareMesh2D)
* map used to build this instance}.
*/
public Location getLocation(Neuron n) {
return locations.get(n.getIdentifier());
}
}