【deep learning学习笔记】注释yusugomori的SDA代码 -- Sda.cpp -- 模型准备

一些准备工作,包括辅助函数,构造/析构函数等。

#include <iostream>
#include <math.h>
#include "HiddenLayer.h"
#include "dA.h"
#include "LogisticRegression.h"
#include "SdA.h"
using namespace std;

// To generate a value between min and max in a uniform distribution
double uniform(double min, double max) 
{
  return rand() / (RAND_MAX + 1.0) * (max - min) + min;
}

// To get the result of n-binomial test by the p probability
int binomial(int n, double p) 
{
  if(p < 0 || p > 1) return 0;
  
  int c = 0;
  double r;
  
  for(int i=0; i<n; i++) {
    r = rand() / (RAND_MAX + 1.0);
    if (r < p) c++;
  }

  return c;
}

// To get the result of sigmoid function
double sigmoid(double x) 
{
  return 1.0 / (1.0 + exp(-x));
}

// SdA
SdA::SdA (
	int size, 
	int n_i, 
	int *hls, 
	int n_o, 
	int n_l
		) 
{
	// the global information
  	N = size;
  	n_ins = n_i;
  	hidden_layer_sizes = hls;
  	n_outs = n_o;
  	n_layers = n_l;

  	sigmoid_layers = new HiddenLayer* [n_layers];
  	dA_layers = new dA* [n_layers];

  	// construct multi-layer
  	int input_size;
  	for(int i=0; i<n_layers; i++) 
  	{
    	if(i == 0) 
		{
      		input_size = n_ins;
    	} 
		else 
		{
      		input_size = hidden_layer_sizes[i-1];
    	}

    	// construct sigmoid_layer
    	sigmoid_layers[i] = 
			new HiddenLayer	(N, input_size, hidden_layer_sizes[i], NULL, NULL);

    	// construct dA_layer
    	dA_layers[i] = 
			new dA(N, input_size, hidden_layer_sizes[i],\
                          sigmoid_layers[i]->W, sigmoid_layers[i]->b, NULL);
  	}

  	// layer for output using LogisticRegression
  	log_layer = 
	  new LogisticRegression(N, hidden_layer_sizes[n_layers-1], n_outs);
}

SdA::~SdA() 
{
  	delete log_layer;		// call destructor of LogisticRegression

  	for(int i=0; i<n_layers; i++) 
  	{
    	delete sigmoid_layers[i];	// call destructor of HiddenLayer
    	delete dA_layers[i];		// call destructor of dA
  	}
  	delete[] sigmoid_layers;
  	delete[] dA_layers;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值