Skip to content
This repository has been archived by the owner on Sep 27, 2019. It is now read-only.

Commit

Permalink
create brain/selectivity; create new test file for augmented_nn.
Browse files Browse the repository at this point in the history
  • Loading branch information
yetiancn committed Sep 7, 2018
1 parent 4c7ae6f commit f54b380
Show file tree
Hide file tree
Showing 14 changed files with 583 additions and 375 deletions.
115 changes: 115 additions & 0 deletions src/brain/modelgen/augmented_nn.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
#===----------------------------------------------------------------------===#
#
# Peloton
#
# AugmentedNN.py
#
# Identification: src/brain/modelgen/AugmentedNN.py
#
# Copyright (c) 2015-2018, Carnegie Mellon University Database Group
#
#===----------------------------------------------------------------------===#

import tensorflow as tf
import functools
import os
import argparse

def lazy_property(function):
attribute = '_cache_' + function.__name__

@property
@functools.wraps(function)
def decorator(self):
if not hasattr(self, attribute):
setattr(self, attribute, function(self))
return getattr(self, attribute)

return decorator

class AugmentedNN:

def __init__(self, column_num, order=1, neuron_num=16, lr=0.1, **kwargs):
tf.reset_default_graph()
self.data = tf.placeholder(tf.float32, [None, column_num*2], name="data_")
self.target = tf.placeholder(tf.float32, [None, 1], name="target_")
self._column_num = column_num
self._order = order
self._neuron_num = neuron_num
self._lr = tf.placeholder_with_default(lr, shape=None,
name="learn_rate_")
self.tf_init = tf.global_variables_initializer
self.prediction
self.loss
self.optimize

@staticmethod
def jump_activation(k):
"""
This is an activation function used to learn discontinuous functions.
Reference: https://dl.acm.org/citation.cfm?id=2326898
"""
def jump_activation_k(x):
return tf.pow(tf.maximum(0.0, 1-tf.exp(-x)), k)
return jump_activation_k

@lazy_property
def prediction(self):
net = self.data
kernel_init = tf.random_normal_initializer(mean=0.0001, stddev=0.0001)
with tf.name_scope("hidden_layer"):
net_shape = tf.shape(net)
bsz = net_shape[0]

h1_layers = []
for i in range(1, self._order+1):
h1 = tf.layers.dense(net, self._neuron_num,
activation=self.jump_activation(i),
kernel_initializer=kernel_init)
h1_layers.append(h1)
h1_layers = tf.concat(h1_layers, 1)
with tf.name_scope("output_layer"):
net = tf.layers.dense(h1_layers, 1,
activation=self.jump_activation(1),
kernel_initializer=kernel_init)
net = tf.reshape(net, [bsz, -1], name="pred_")
return net

@lazy_property
def loss(self):
loss = tf.reduce_mean(tf.squared_difference(self.target, self.prediction), name='lossOp_')
return loss

@lazy_property
def optimize(self):
params = tf.trainable_variables()
gradients = tf.gradients(self.loss, params)
optimizer = tf.train.AdagradOptimizer(learning_rate=self._lr)
return optimizer.apply_gradients(zip(gradients,
params), name="optimizeOp_")

def write_graph(self, dir):
fname = "{}.pb".format(self.__repr__())
abs_path = os.path.join(dir, fname)
if not os.path.exists(abs_path):
tf.train.write_graph(tf.get_default_graph(),
dir, fname, False)

def __repr__(self):
return "augmented_nn"

def main():
parser = argparse.ArgumentParser(description='AugmentedNN Model Generator')

parser.add_argument('--column_num', type=int, default=1, help='Number of augmentedNN Hidden units')
parser.add_argument('--order', type=int, default=3, help='Max order of activation function')
parser.add_argument('--neuron_num', type=int, default=20, help='Number of neurons in hidden layer')
parser.add_argument('--lr', type=float, default=0.001, help='Learning rate')
parser.add_argument('graph_out_path', type=str, help='Path to write graph output', nargs='+')
args = parser.parse_args()
model = AugmentedNN(args.column_num, args.order, args.neuron_num, args.lr)
model.tf_init()
model.write_graph(' '.join(args.graph_out_path))

if __name__ == '__main__':
main()
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,15 @@
//
// Peloton
//
// augmentedNN.cpp
// augmented_nn.cpp
//
// Identification: src/brain/workload/augmentedNN.cpp
// Identification: src/brain/workload/augmented_nn.cpp
//
// Copyright (c) 2015-2018, Carnegie Mellon University Database Group
//
//===----------------------------------------------------------------------===//

#include "brain/workload/augmentedNN.h"
#include "brain/selectivity/augmented_nn.h"
#include "brain/util/model_util.h"
#include "brain/util/tf_session_entity/tf_session_entity.h"
#include "brain/util/tf_session_entity/tf_session_entity_input.h"
Expand All @@ -22,8 +22,8 @@ namespace brain {

AugmentedNN::AugmentedNN(int column_num, int order, int neuron_num,
float learn_rate, int batch_size, int epochs)
: BaseTFModel("src/brain/modelgen", "src/brain/modelgen/AugmentedNN.py",
"src/brain/modelgen/AugmentedNN.pb"),
: BaseTFModel("src/brain/modelgen", "src/brain/modelgen/augmented_nn.py",
"src/brain/modelgen/augmented_nn.pb"),
column_num_(column_num),
order_(order),
neuron_num_(neuron_num),
Expand All @@ -49,7 +49,7 @@ std::string AugmentedNN::ConstructModelArgsString() const {

std::string AugmentedNN::ToString() const {
std::stringstream model_str_builder;
model_str_builder << "AugmentedNN(";
model_str_builder << "augmented_nn(";
model_str_builder << "column_num = " << column_num_;
model_str_builder << ", order = " << order_;
model_str_builder << ", neuron_num = " << neuron_num_;
Expand Down
27 changes: 27 additions & 0 deletions src/brain/selectivity/selectivity_defaults.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
//===----------------------------------------------------------------------===//
//
// Peloton
//
// selectivity_defaults.cpp
//
// Identification: src/brain/workload/selectivity_defaults.cpp
//
// Copyright (c) 2015-2018, Carnegie Mellon University Database Group
//
//===----------------------------------------------------------------------===//

#include "brain/selectivity/selectivity_defaults.h"

namespace peloton {
namespace brain {

const int AugmentedNNDefaults::COLUMN_NUM = 1;
const int AugmentedNNDefaults::ORDER = 1;
const int AugmentedNNDefaults::NEURON_NUM = 16;
const float AugmentedNNDefaults::LR = 0.1f;
const int AugmentedNNDefaults::BATCH_SIZE = 256;
const int AugmentedNNDefaults::EPOCHS = 600;


} // namespace brain
} // namespace peloton
10 changes: 0 additions & 10 deletions src/brain/workload/workload_defaults.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,15 +36,5 @@ const int LinearRegWorkloadDefaults::BPTT = 90;

const int KernelRegWorkloadDefaults::BPTT = 90;


const int AugmentedNNWorkloadDefaults::COLUMN_NUM = 1;
const int AugmentedNNWorkloadDefaults::ORDER = 1;
const int AugmentedNNWorkloadDefaults::NEURON_NUM = 16;
const float AugmentedNNWorkloadDefaults::LR = 0.1f;
const int AugmentedNNWorkloadDefaults::BATCH_SIZE = 256;
const int AugmentedNNWorkloadDefaults::EPOCHS = 600;



} // namespace brain
} // namespace peloton
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@
//
// Peloton
//
// augmentedNN.h
// augmented_nn.h
//
// Identification: src/include/brain/workload/augmentedNN.h
// Identification: src/include/brain/workload/augmented_nn.h
//
// Copyright (c) 2015-2018, Carnegie Mellon University Database Group
//
Expand Down
33 changes: 33 additions & 0 deletions src/include/brain/selectivity/selectivity_defaults.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
//===----------------------------------------------------------------------===//
//
// Peloton
//
// selectivity_defaults.h
//
// Identification: src/include/brain/workload/selectivity_defaults.h
//
// Copyright (c) 2015-2018, Carnegie Mellon University Database Group
//
//===----------------------------------------------------------------------===//

#pragma once

/**
* This header file contains default attributes
* associated with the selectivity prediction task
**/

namespace peloton {
namespace brain {

struct AugmentedNNDefaults {
static const int COLUMN_NUM;
static const int ORDER;
static const int NEURON_NUM;
static const float LR;
static const int BATCH_SIZE;
static const int EPOCHS;
};

} // namespace brain
} // namespace peloton
9 changes: 0 additions & 9 deletions src/include/brain/workload/workload_defaults.h
Original file line number Diff line number Diff line change
Expand Up @@ -65,14 +65,5 @@ struct KernelRegWorkloadDefaults {
static const int BPTT;
};

struct AugmentedNNWorkloadDefaults {
static const int COLUMN_NUM;
static const int ORDER;
static const int NEURON_NUM;
static const float LR;
static const int BATCH_SIZE;
static const int EPOCHS;
};

} // namespace brain
} // namespace peloton
2 changes: 2 additions & 0 deletions test/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ set(TESTING_UTIL_SQL ${PROJECT_SOURCE_DIR}/test/sql/testing_sql_util.cpp)
set(TESTING_UTIL_INDEX ${PROJECT_SOURCE_DIR}/test/index/testing_index_util.cpp)
set(TESTING_UTIL_CODEGEN ${PROJECT_SOURCE_DIR}/test/codegen/testing_codegen_util.cpp)
set(TESTING_UTIL_FORECAST ${PROJECT_SOURCE_DIR}/test/brain/testing_forecast_util.cpp)
set(TESTING_UTIL_AUGMENTEDNN ${PROJECT_SOURCE_DIR}/test/brain/testing_augmented_nn_util.cpp)

add_library(peloton-test-common EXCLUDE_FROM_ALL ${gmock_srcs} ${HARNESS}
${TESTING_UTIL_EXECUTOR}
Expand All @@ -60,6 +61,7 @@ add_library(peloton-test-common EXCLUDE_FROM_ALL ${gmock_srcs} ${HARNESS}
${TESTING_UTIL_SQL}
${TESTING_UTIL_CODEGEN}
${TESTING_UTIL_FORECAST}
${TESTING_UTIL_AUGMENTEDNN}
)

# --[ Add "make check" target
Expand Down
71 changes: 71 additions & 0 deletions test/brain/augmented_nn_test.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
//===----------------------------------------------------------------------===//
//
// Peloton
//
// augmented_nn_test.cpp
//
// Identification: test/brain/augmented_nn_test.cpp
//
// Copyright (c) 2015-2018, Carnegie Mellon University Database Group
//
//===----------------------------------------------------------------------===//

#include <algorithm>
#include "brain/selectivity/augmented_nn.h"
#include "brain/selectivity/selectivity_defaults.h"
#include "brain/testing_augmented_nn_util.h"
#include "brain/util/model_util.h"
#include "brain/workload/workload_defaults.h"
#include "common/harness.h"
#include "util/file_util.h"

namespace peloton {
namespace test {
class AugmentedNNTests : public PelotonTest {};

TEST_F(AugmentedNNTests, DISABLED_AugmentedNNUniformTest) {
auto model = std::unique_ptr<brain::AugmentedNN>(new brain::AugmentedNN(
brain::AugmentedNNDefaults::COLUMN_NUM,
brain::AugmentedNNDefaults::ORDER,
brain::AugmentedNNDefaults::NEURON_NUM,
brain::AugmentedNNDefaults::LR,
brain::AugmentedNNDefaults::BATCH_SIZE,
brain::AugmentedNNDefaults::EPOCHS));
EXPECT_TRUE(model->IsTFModel());
size_t LOG_INTERVAL = 20;
size_t NUM_SAMPLES = 10000;
float VAL_SPLIT = 0.5;
bool NORMALIZE = false;
float VAL_THESH = 0.05;

TestingAugmentedNNUtil::Test(*model, DistributionType::UniformDistribution,
LOG_INTERVAL, NUM_SAMPLES,
VAL_SPLIT, NORMALIZE, VAL_THESH,
brain::CommonWorkloadDefaults::ESTOP_PATIENCE,
brain::CommonWorkloadDefaults::ESTOP_DELTA);
}

TEST_F(AugmentedNNTests, DISABLED_AugmentedNNSkewedTest) {
auto model = std::unique_ptr<brain::AugmentedNN>(new brain::AugmentedNN(
brain::AugmentedNNDefaults::COLUMN_NUM,
brain::AugmentedNNDefaults::ORDER,
brain::AugmentedNNDefaults::NEURON_NUM,
brain::AugmentedNNDefaults::LR,
brain::AugmentedNNDefaults::BATCH_SIZE,
brain::AugmentedNNDefaults::EPOCHS));
EXPECT_TRUE(model->IsTFModel());
size_t LOG_INTERVAL = 20;
size_t NUM_SAMPLES = 10000;
float VAL_SPLIT = 0.5;
bool NORMALIZE = false;
float VAL_THESH = 0.05;

TestingAugmentedNNUtil::Test(*model, DistributionType::SkewedDistribution,
LOG_INTERVAL, NUM_SAMPLES,
VAL_SPLIT, NORMALIZE, VAL_THESH,
brain::CommonWorkloadDefaults::ESTOP_PATIENCE,
brain::CommonWorkloadDefaults::ESTOP_DELTA);
}

} // namespace test
} // namespace peloton
Loading

0 comments on commit f54b380

Please sign in to comment.