addpath util
addpath data
addpath NN

data1 = zeros(22469,4714);
data_y = zeros(22469,4);
 
fileID = fopen('musae_facebook_features.json', 'r');

jsonStr = fread(fileID, '*char')';
jsonData = jsondecode(jsonStr);

fclose(fileID);

fieldNames = fieldnames(jsonData);
for i = 0:22469
    pre = 'x';
    key = strcat(pre,num2str(i));

    jsonStruct = jsonData.(key);

    [s1,s2] = size(jsonStruct);

    if i == 1
        disp(jsonStruct);
    end
    for j = 1:s1

        disp(jsonStruct(j,1));

        data1(i+1,jsonStruct(j,1)+1) = 1;
        
    end
    
end

k='x20000';
disp(jsonData.(k));

disp('here');


data2 = readtable('musae_facebook_target.csv');


strList = data2.page_type;

categoricalArray = categorical(strList);

idxArray = grp2idx(categoricalArray);

disp(idxArray);

for i = 1:22470
    j = idxArray(i,1);
    data_y(i,j) = 1;
end

disp('here');


[s1,s2] = size(data1);
tr_x = zeros(1,s2);
tr_y = zeros(1,4);

te_x = zeros(1,s2);
te_y = zeros(1,4);


clear
load('memer6.mat');

%train_x = double(train_x) / 255;
train_x = double(tr_x);
test_x = double(te_x);
 
%train_y = double(train_y);
train_y = double(tr_y);
test_y  = double(te_y);

% normalizenodesnum
[train_x, mu, sigma] = zscore(train_x);
test_x = normalize(test_x, mu, sigma);
%% ex1 vanilla neural net

rand('state',0)

nn = nnsetup([4714 100 100 4]);
opts.numepochs =  1;   %  Number of full sw` ['eeps through data
opts.batchsize = 1;  %  Take a mean gradient step over this many samples
tic;


%n1 = 6000;
%train_indices = randperm(size(train_x, 1), n1);
%train_x1 = train_x(train_indices, :);
%train_y1 = train_y(train_indices, :);

%[nn, L] = nntrain(nn, train_x1, train_y1, opts);
[nn, L] = nntrain(nn, train_x, train_y, opts);

%n2 = 600; 
%test_indices = randperm(size(test_x, 1), n2);
%test_x1 = test_x(test_indices, :);
%test_y1 = test_y(test_indices, :);

%[er, bad] = nntest(nn, test_x1, test_y1);
[er, bad] = nntest(nn, test_x, test_y);
tend = toc;

disp('error:');
disp(er);

disp('running time:');
disp(tend);
%assert(er < 0.08, 'Too big error');
