mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
143 lines
5.2 KiB
143 lines
5.2 KiB
/* *************************************************************************** */
|
|
/* * NN ws programs * */
|
|
/* *************************************************************************** */
|
|
#ifndef SNN_HEADER_INCLUDED
|
|
#define SNN_HEADER_INCLUDED
|
|
|
|
#include "ams_mg.h"
|
|
|
|
// ------------------- Defines -----------------------------------------------
|
|
|
|
//#define PEGASUS
|
|
|
|
#define MLP_LEARN_MODE 0
|
|
#define MLP_EMULATE_INT 0
|
|
#define MLP_BYTE_NET 0
|
|
|
|
#ifdef SNN_FAT_NET_ON
|
|
#define MLP_FAT_NET 1
|
|
#else
|
|
#define MLP_FAT_NET 0
|
|
#endif
|
|
|
|
#ifdef PEGASUS
|
|
#ifndef MLP_PRELOAD_MODE
|
|
#define MLP_PRELOAD_MODE 1
|
|
#endif
|
|
#define MLP_UPSCALE 1
|
|
#define MLP_INT_MODE 1
|
|
#else
|
|
#ifndef MLP_PRELOAD_MODE
|
|
#define MLP_PRELOAD_MODE 1
|
|
#endif
|
|
#define MLP_UPSCALE 1
|
|
#define MLP_INT_MODE 1
|
|
#endif
|
|
|
|
#if MLP_FAT_NET
|
|
#define NET_TYPE_ID ".fat"
|
|
#else
|
|
#define NET_TYPE_ID ".slim"
|
|
#endif
|
|
|
|
// ------------------- Defines -----------------------------------------------
|
|
|
|
#ifdef FOR_FRENCH
|
|
#define MLP_ID_STR "MLP.Network.V.4.12.f" NET_TYPE_ID
|
|
#define MLP_NET_NUMOUTPUTS (92+24)
|
|
#define MLP_NET_SYMCO "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" \
|
|
"0123456789@#$%&!?*/+=-(){}[];:~\\<>^|" \
|
|
"£¥ " /*"£¥©®" until next net, which will do better on these*/ \
|
|
"àâèéêëîïôùûç" \
|
|
"ÀÂÈÉÊËÎÏÔÙÛÇ"
|
|
#elif defined (FOR_GERMAN)
|
|
#define MLP_ID_STR "MLP.Network.V.4.12.g" NET_TYPE_ID
|
|
#define MLP_NET_NUMOUTPUTS (92+8)
|
|
#define MLP_NET_SYMCO "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" \
|
|
"0123456789@#$%&!?*/+=-(){}[];:~\\<>^|" \
|
|
"£¥ " /*"£¥©®" until next net, which will do better on these*/ \
|
|
"äöüß" \
|
|
"ÄÖÜ\""
|
|
#elif defined (FOR_INTERNATIONAL)
|
|
#define MLP_ID_STR "MLP.Network.V.4.12.i" NET_TYPE_ID
|
|
#define MLP_NET_NUMOUTPUTS (92+60)
|
|
#define MLP_NET_SYMCO "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" \
|
|
"0123456789@#$%&!?*/+=-(){}[];:~\\<>^|" \
|
|
"£¥ " /*"£¥©®" until next net, which will do better on these*/ \
|
|
"àáâãäåçèéêëìíîïñòóôõöøùúûüýÿšœ" \
|
|
"ÀÁÂÃÄÅÇÈÉÊËÌÍÎÏÑÒÓÔÕÖØÙÚÛÜÝŸŠŒ"
|
|
#else
|
|
#define MLP_ID_STR "MLP.Network.V.4.12.e" NET_TYPE_ID
|
|
#define MLP_NET_NUMOUTPUTS 92
|
|
#define MLP_NET_SYMCO "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" \
|
|
"0123456789@#$%&!?*/+=-(){}[];:~\\<>^|" \
|
|
"£¥ " /*"£¥©®" until next net, which will do better on these*/
|
|
#endif
|
|
|
|
#define MLP_COEF_SHARE 96
|
|
#define MLP_BMP_SHARE 32
|
|
#define MLP_NUM_CFF 32
|
|
#define MLP_NUM_BMP (16*16)
|
|
|
|
#define MLP_NET_NUMLAYERS 4
|
|
#define MLP_NET_NUMINPUTS 288
|
|
|
|
#define MLP_CELL_MAXINPUTS 32
|
|
#define MLP_LAYER_MAXCELLS (MLP_NET_NUMOUTPUTS*MLP_CELL_MAXINPUTS)
|
|
|
|
#if MLP_FAT_NET
|
|
#define MLP_PREOUT_STEP 4
|
|
#else
|
|
#define MLP_PREOUT_STEP 2
|
|
#endif
|
|
|
|
#define MLP_NET_0L_NUMCELLS (MLP_NET_NUMINPUTS)
|
|
#define MLP_NET_1L_NUMCELLS (MLP_COEF_SHARE+MLP_BMP_SHARE)
|
|
#define MLP_NET_2L_NUMCELLS (MLP_NET_NUMOUTPUTS*MLP_PREOUT_STEP + (MLP_CELL_MAXINPUTS-MLP_PREOUT_STEP))
|
|
#define MLP_NET_3L_NUMCELLS (MLP_NET_NUMOUTPUTS)
|
|
#define MLP_NET_4L_NUMCELLS 0
|
|
#define MLP_NET_NUMCELLS (MLP_NET_1L_NUMCELLS+MLP_NET_2L_NUMCELLS+MLP_NET_3L_NUMCELLS+MLP_NET_4L_NUMCELLS)
|
|
#define MLP_NET_NUMSIGNALS (MLP_NET_0L_NUMCELLS+MLP_NET_1L_NUMCELLS+MLP_NET_2L_NUMCELLS+MLP_NET_3L_NUMCELLS+MLP_NET_4L_NUMCELLS)
|
|
|
|
//#define MLP_NET_SYMCO_LONG "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789@#$%&*{}"
|
|
|
|
// ------------------- Structures --------------------------------------------
|
|
|
|
#if MLP_INT_MODE
|
|
#if MLP_BYTE_NET
|
|
typedef _SCHAR fint_c;
|
|
typedef _UCHAR fint_s;
|
|
#else
|
|
typedef _SHORT fint_c;
|
|
typedef _SHORT fint_s;
|
|
#endif
|
|
typedef _LONG flong;
|
|
typedef fint_c * p_fint_c;
|
|
typedef fint_s * p_fint_s;
|
|
#else
|
|
typedef float fint_c;
|
|
typedef float fint_s;
|
|
typedef float flong;
|
|
typedef fint_c * p_fint_c;
|
|
typedef fint_s * p_fint_s;
|
|
#endif
|
|
|
|
typedef struct {
|
|
p_VOID net;
|
|
fint_s signals[MLP_NET_NUMSIGNALS];
|
|
} mlp_data_type, * p_mlp_data_type;
|
|
|
|
// ------------------- Prototypes --------------------------------------------
|
|
|
|
_INT InitSnnData(p_UCHAR name, p_mlp_data_type mlpd);
|
|
_INT GetSnnResults(p_UCHAR pCoeff, p_UCHAR answs, p_mlp_data_type mlpd);
|
|
|
|
int LoadNetData(p_mlp_data_type mlpd, p_CHAR net_name);
|
|
int SaveNetData(p_mlp_data_type mlpd, p_CHAR net_name, float e);
|
|
int DumpNetData(p_mlp_data_type mlpd, p_CHAR dmp_name, float e);
|
|
|
|
#endif // SNN_HEADER_INCLUDED
|
|
/* *************************************************************************** */
|
|
/* * End of alll * */
|
|
/* *************************************************************************** */
|
|
//
|