⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 matrixpersistor.java

📁 VHDL制作的ann的code
💻 JAVA
字号:
/* * Encog Neural Network and Bot Library for Java v1.x * http://www.heatonresearch.com/encog/ * http://code.google.com/p/encog-java/ *  * Copyright 2008, Heaton Research Inc., and individual contributors. * See the copyright.txt in the distribution for a full listing of  * individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */package org.encog.neural.persist.persistors;import javax.xml.transform.sax.TransformerHandler;import org.encog.matrix.Matrix;import org.encog.neural.NeuralNetworkError;import org.encog.neural.persist.EncogPersistedCollection;import org.encog.neural.persist.EncogPersistedObject;import org.encog.neural.persist.Persistor;import org.w3c.dom.Element;import org.w3c.dom.Node;import org.xml.sax.SAXException;import org.xml.sax.helpers.AttributesImpl;/** * Persist a matrix. *  * @author jheaton *  */public class MatrixPersistor implements Persistor {	/**	 * Load from the specified node.	 * 	 * @param matrixElement	 *            The node to load from.	 * @return The EncogPersistedObject that was loaded.	 */	public EncogPersistedObject load(final Element matrixElement) {		final String name = matrixElement.getAttribute("name");		final String description = matrixElement.getAttribute("description");		final int rows = Integer.parseInt(matrixElement.getAttribute("rows"));		final int cols = Integer.parseInt(matrixElement.getAttribute("cols"));		final Matrix result = new Matrix(rows, cols);		result.setName(name);		result.setDescription(description);		int row = 0;		for (Node child = matrixElement.getFirstChild(); child != null; 			child = child.getNextSibling()) {			if (!(child instanceof Element)) {				continue;			}			final Element node = (Element) child;			if (node.getNodeName().equals("row")) {				for (int col = 0; col < cols; col++) {					final double value = Double.parseDouble(node							.getAttribute("col" + col));					result.set(row, col, value);				}				row++;			}		}		return result;	}	/**	 * Save the specified object.	 * 	 * @param object	 *            The object to save.	 * @param hd	 *            The XML object.	 */	public void save(final EncogPersistedObject object,			final TransformerHandler hd) {		try {			final Matrix matrix = (Matrix) object;			final AttributesImpl atts = EncogPersistedCollection					.createAttributes(object);			EncogPersistedCollection.addAttribute(atts, "rows", ""					+ matrix.getRows());			EncogPersistedCollection.addAttribute(atts, "cols", ""					+ matrix.getCols());			hd.startElement("", "", "Matrix", atts);			for (int row = 0; row < matrix.getRows(); row++) {				atts.clear();				for (int col = 0; col < matrix.getCols(); col++) {					atts.addAttribute("", "", "col" + col, "CDATA", ""							+ matrix.get(row, col));				}				hd.startElement("", "", "row", atts);				hd.endElement("", "", "row");			}			hd.endElement("", "", "Matrix");		} catch (final SAXException e) {			throw new NeuralNetworkError(e);		}	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -