pl-nk v0.4.5
Plonk|Plink|Plank are a set of cross-platform C/C++ frameworks for audio software development
plank_NeuralNode.h
00001 /*
00002  -------------------------------------------------------------------------------
00003  This file is part of the Plink, Plonk, Plank libraries
00004  by Martin Robinson
00005  
00006  http://code.google.com/p/pl-nk/
00007  
00008  Copyright University of the West of England, Bristol 2011-14
00009  All rights reserved.
00010  
00011  Redistribution and use in source and binary forms, with or without
00012  modification, are permitted provided that the following conditions are met:
00013  
00014  * Redistributions of source code must retain the above copyright
00015  notice, this list of conditions and the following disclaimer.
00016  * Redistributions in binary form must reproduce the above copyright
00017  notice, this list of conditions and the following disclaimer in the
00018  documentation and/or other materials provided with the distribution.
00019  * Neither the name of University of the West of England, Bristol nor
00020  the names of its contributors may be used to endorse or promote products
00021  derived from this software without specific prior written permission.
00022  
00023  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
00024  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00025  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00026  DISCLAIMED. IN NO EVENT SHALL UNIVERSITY OF THE WEST OF ENGLAND, BRISTOL BE
00027  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00028  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
00029  GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00030  HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00031  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
00032  OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00033  
00034  This software makes use of third party libraries. For more information see:
00035  doc/license.txt included in the distribution.
00036  
00037  -------------------------------------------------------------------------------
00038  
00039  */
00040 
00041 #ifndef PLANK_NEURALNODE_H
00042 #define PLANK_NEURALNODE_H
00043 
00044 #include "../json/plank_JSON.h"
00045 #include "../../containers/plank_DynamicArray.h"
00046 #include "plank_NeuralCommon.h"
00047 #include "plank_NeuralLayer.h"
00048 #include "plank_NeuralNetwork.h"
00049 
00050 #define PLANK_NEURALNODEF_JSON_TYPE          "plank::NeuralNodeF"
00051 #define PLANK_NEURALNODEF_JSON_VERSION       0, 1, 1, 0
00052 #define PLANK_NEURALNODEF_JSON_WEIGHTS       "weights"
00053 #define PLANK_NEURALNODEF_JSON_THRESHOLD     "threshold"
00054 
00055 
00056 PLANK_BEGIN_C_LINKAGE
00057 
00065 #if DOXYGEN
00066 
00067 typedef struct PlankNeuralNodeF* PlankNeuralNodeFRef;
00068 #endif
00069 
00074 PlankResult pl_NeuralNodeF_Init (PlankNeuralNodeFRef p, PlankNeuralNetworkFRef network);
00075 
00080 PlankResult pl_NeuralNodeF_InitWithNumWeights (PlankNeuralNodeFRef p, PlankNeuralNetworkFRef network, const int numWeights);
00081 PlankResult pl_NeuralNodeF_InitWithNumWeightsAndRange (PlankNeuralNodeFRef p, PlankNeuralNetworkFRef network, const int numWeights, const float range);
00082 
00086 PlankResult pl_NeuralNodeF_DeInit (PlankNeuralNodeFRef p);
00087 
00088 
00089 int pl_NeuralNodeF_GetNumWeights (PlankNeuralNodeFRef p);
00090 PlankResult pl_NeuralNodeF_Set (PlankNeuralNodeFRef p, const float* weights, const float threshold);
00091 PlankResult pl_NeuralNodeF_SetThreshold (PlankNeuralNodeFRef p, const float threshold);
00092 PlankResult pl_NeuralNodeF_SetWeights (PlankNeuralNodeFRef p, const float* weights);
00093 PlankResult pl_NeuralNodeF_SetWeight (PlankNeuralNodeFRef p, const int index, const float weight);
00094 PlankResult pl_NeuralNodeF_Get (PlankNeuralNodeFRef p, float* weights, float* threshold);
00095 float pl_NeuralNodeF_GetThreshold (PlankNeuralNodeFRef p);
00096 PlankResult pl_NeuralNodeF_GetWeights (PlankNeuralNodeFRef p, float* weights);
00097 const float* pl_NeuralNodeF_GetWeightsPtr (PlankNeuralNodeFRef p);
00098 PlankResult pl_NeuralNodeF_Reset (PlankNeuralNodeFRef p, const float amount);
00099 PlankResult pl_NeuralNodeF_Randomise (PlankNeuralNodeFRef p, const float amount);
00100 float pl_NeuralNodeF_Propogate (PlankNeuralNodeFRef p, const float* inputVector);
00101 PlankResult pl_NeuralNodeF_BackProp (PlankNeuralNodeFRef p, const float* inputVector, const float error, const float actFuncOffset, const float learnRate, float* adjustVector);
00102 float pl_NeuralNodeF_GetOutput (PlankNeuralNodeFRef p);
00103 
00104 PlankResult pl_NeuralNodeF_ToJSON (PlankNeuralNodeFRef p, PlankJSONRef j, const PlankB useBinary);
00105 PlankResult pl_NeuralNodeF_InitFromJSON (PlankNeuralNodeFRef p, PlankNeuralNetworkFRef network, PlankJSONRef j);
00106 
00107 
00108 PLANK_END_C_LINKAGE
00109 
00110 #if !DOXYGEN
00111 
00112 typedef PlankResult (*PlankNeuralNodeFBackPropFunction)(PlankNeuralNodeFRef, const float*, const float, const float, const float, float*);
00113 typedef float (*PlankNeuralNodeFPropogateFunction)(PlankNeuralNodeFRef, const float*);
00114 
00115 typedef struct PlankNeuralNodeF
00116 {
00117     PlankNeuralNetworkFRef network;
00118     PlankF threshold, output;
00119     PlankDynamicArray weightVector;
00120     PlankNeuralNodeFPropogateFunction propogate;
00121     PlankNeuralNodeFBackPropFunction backProp;
00122 } PlankNeuralNodeF;
00123 #endif
00124 
00125 
00126 #endif // PLANK_NEURALNODE_H
00127 
 All Classes Functions Typedefs Enumerations Enumerator Properties