-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmodel.py
More file actions
72 lines (54 loc) · 1.79 KB
/
model.py
File metadata and controls
72 lines (54 loc) · 1.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import nltk
nltk.download('punkt')
from nltk.stem.lancaster import LancasterStemmer
import numpy
import tflearn
import tensorflow
import json
import random
import pickle
with open('intents.json') as intents_file:
data = json.load(intents_file)
stemmer = LancasterStemmer()
words = []
labels = []
docs_x = []
docs_y = []
for intent in data['intents']:
for pattern in intent['patterns']:
tokenized_words = nltk.word_tokenize(pattern)
words.extend(tokenized_words)
docs_x.append(tokenized_words)
docs_y.append(intent['tag'])
if intent['tag'] not in labels:
labels.append(intent['tag'])
words = [stemmer.stem(word.lower()) for word in words if word not in "[$&+,:;=?@#|'<>.^*()%!]0123456789"]
words = sorted(list(set(words)))
labels = sorted(labels)
training = []
output = []
for x, doc in enumerate(docs_x):
bag = []
tokenized_words = [stemmer.stem(word) for word in doc]
for w in words:
if w in tokenized_words:
bag.append(1)
else:
bag.append(0)
output_row = [0 for _ in range(len(labels))]
output_row[labels.index(docs_y[x])] = 1
training.append(bag)
output.append(output_row)
training = numpy.array(training)
output = numpy.array(output)
with open('data.pickle', 'wb') as data_file:
pickle.dump((words, labels, training, output), data_file)
tensorflow.compat.v1.reset_default_graph()
network = tflearn.input_data(shape=[None, len(training[0])])
network = tflearn.fully_connected(network, 8)
network = tflearn.fully_connected(network, 8)
network = tflearn.fully_connected(network, len(output[0]), activation='softmax')
network = tflearn.regression(network)
model = tflearn.DNN(network)
model.fit(training, output, n_epoch=1000, batch_size=8, show_metric=True)
model.save('model.tflearn')