Intelligent AI Chatbot in Python

Поділитися
Вставка
  • Опубліковано 3 лют 2025

КОМЕНТАРІ • 1 тис.

  • @joeljohn2679
    @joeljohn2679 3 роки тому +19

    Man, you are THE ONLY ONE explaining this intent type of neural net-based chatbot. Thanks a lot

  • @fuwad5705
    @fuwad5705 10 місяців тому +2

    🎯 Key Takeaways for quick navigation:
    00:04 *🤖 Setting up the intense.json file for the chatbot*
    - Creating an intense.json file to categorize user inputs for the chatbot.
    - Defining categories such as greetings, questions about prices, and goodbyes.
    - Specifying patterns and static responses for each category to train the chatbot.
    06:12 *💻 Coding the chatbot in Python*
    - Importing necessary libraries including random, json, pickle, numpy, and nltk.
    - Lemmatizing words to reduce them to their base form for better performance.
    - Processing the intense.json file to prepare training data for the chatbot.
    19:08 *🧠 Building the neural network model*
    - Shuffling and converting training data into numpy arrays for features and labels.
    - Creating a sequential model and adding layers including input, dense, and dropout layers.
    - Using rectified linear unit (ReLU) activation function and stochastic gradient descent (SGD) optimizer for training.
    20:46 *🧠 Building the Neural Network Model*
    - Building a neural network model for the chatbot.
    - Adding dense layers with specified neurons and activation functions.
    - Defining optimizer parameters and compiling the model.
    24:12 *💬 Setting up Chatbot Application*
    - Setting up the chatbot application to use the trained model.
    - Importing necessary libraries and loading the trained model.
    - Defining functions for processing user input and generating responses.
    27:05 *🧹 Cleaning and Preparing Input Data*
    - Defining functions for cleaning up sentences and converting them into bags of words.
    - Preprocessing input data to prepare it for prediction by the neural network.
    - Ensuring that the input data format aligns with the model's requirements.
    29:38 *🤖 Predicting Classes and Generating Responses*
    - Implementing a function to predict classes based on input sentences using the model.
    - Establishing a threshold for accepting predictions to manage uncertainty.
    - Generating responses based on predicted classes and probabilities.
    Made with HARPA AI

  • @JosephElliott-kx9yj
    @JosephElliott-kx9yj 2 роки тому +284

    A bit old now, here is some updated code for anyone watching.
    import random
    import json
    import pickle
    import numpy as np
    import tensorflow as tf
    import nltk
    from nltk.stem import WordNetLemmatizer
    lemmatizer = WordNetLemmatizer()
    intents = json.loads(open('intents.json').read())
    words = []
    classes = []
    documents = []
    ignoreLetters = ['?', '!', '.', ',']
    for intent in intents['intents']:
    for pattern in intent['patterns']:
    wordList = nltk.word_tokenize(pattern)
    words.extend(wordList)
    documents.append((wordList, intent['tag']))
    if intent['tag'] not in classes:
    classes.append(intent['tag'])
    words = [lemmatizer.lemmatize(word) for word in words if word not in ignoreLetters]
    words = sorted(set(words))
    classes = sorted(set(classes))
    pickle.dump(words, open('words.pkl', 'wb'))
    pickle.dump(classes, open('classes.pkl', 'wb'))
    training = []
    outputEmpty = [0] * len(classes)
    for document in documents:
    bag = []
    wordPatterns = document[0]
    wordPatterns = [lemmatizer.lemmatize(word.lower()) for word in wordPatterns]
    for word in words:
    bag.append(1) if word in wordPatterns else bag.append(0)
    outputRow = list(outputEmpty)
    outputRow[classes.index(document[1])] = 1
    training.append(bag + outputRow)
    random.shuffle(training)
    training = np.array(training)
    trainX = training[:, :len(words)]
    trainY = training[:, len(words):]
    model = tf.keras.Sequential()
    model.add(tf.keras.layers.Dense(128, input_shape=(len(trainX[0]),), activation = 'relu'))
    model.add(tf.keras.layers.Dropout(0.5))
    model.add(tf.keras.layers.Dense(64, activation = 'relu'))
    model.add(tf.keras.layers.Dropout(0.5))
    model.add(tf.keras.layers.Dense(len(trainY[0]), activation='softmax'))
    sgd = tf.keras.optimizers.SGD(learning_rate=0.01, momentum=0.9, nesterov=True)
    model.compile(loss='categorical_crossentropy', optimizer=sgd, metrics=['accuracy'])
    model.fit(trainX, trainY, epochs=200, batch_size=5, verbose=1)
    model.save('chatbot_model.h5')
    print('Done')

    • @ericlacerda8949
      @ericlacerda8949 2 роки тому +22

      man you just saved my code by changing words.append to words.extend
      tyvm bro

    • @mr.hatem_
      @mr.hatem_ 2 роки тому +1

      Thank you

    • @swagatrout3075
      @swagatrout3075 Рік тому +5

      thaks bro
      trainX = training[:, :len(words)]
      trainY = training[:, len(words):]

    • @jihyeonku
      @jihyeonku Рік тому +2

      oh my god thank you so much now it works

    • @shravanthj1447
      @shravanthj1447 Рік тому +1

      sike bro

  • @tomas5970
    @tomas5970 4 роки тому +485

    Awesome content! when are we getting the biceps tutorial tho?

  • @alex_mahone
    @alex_mahone 4 роки тому +117

    Videos on neural network theory would be fantastic! Thanks again for another great video!

    • @tomcat9761
      @tomcat9761 3 роки тому +1

      question, what kind of neural network architecture used here? Is it RNN?

    • @w花b
      @w花b Рік тому +1

      ​@@tomcat9761 i don't know

    • @krishsharvesh8082
      @krishsharvesh8082 Рік тому

      @@tomcat9761 its ANN

  • @ChannelName991
    @ChannelName991 4 роки тому +60

    Man, you are so underrated. I always search for simple examples of complex topics. After looking at your videos I am able to implement the basics in my projects easily

    • @vipulkumar9858
      @vipulkumar9858 4 роки тому

      ua-cam.com/channels/0Bn9e36XqiiNZp9ClkPUww.html

    • @mahnoorhome
      @mahnoorhome Рік тому

      hey. where can i get source code? any idea?

    • @RhinoTimelaps
      @RhinoTimelaps Рік тому

      type it, lmao. @@mahnoorhome

  • @smhaseeb
    @smhaseeb 4 роки тому +230

    Instructions unclear, made Ultron. 😂

    • @jamieharper5665
      @jamieharper5665 Рік тому +5

      😂 this had me laughing way more than I expected lol

    • @wick3nd
      @wick3nd Рік тому +2

      same😅

    • @marcoamir5107
      @marcoamir5107 7 місяців тому +1

      😂😂😂😂

    • @JulyTheCat_24subscribe
      @JulyTheCat_24subscribe 4 місяці тому

      Instructions Unclear for me too, made big piece of unusable crap code taking up space on my computer.

  • @1215cubs
    @1215cubs 3 роки тому +210

    A much-needed updated vision of the chatbot from Tech with Tim. Love this video. From a viewer standpoint and someone who is coding along with you to program this thing. Either don't put a video of yourself on the screen, put it in the upper right-hand corner, or make it smaller. It's hard to code along with you as the camera of yourself blocks some of your code in the video.

    • @godwiniheuwa9917
      @godwiniheuwa9917 3 роки тому +20

      This video is more explanatory and far better than the tech tim video, and the tech tim guy was just rushing,

    • @tomcat9761
      @tomcat9761 3 роки тому +1

      question, what kind of neural network architecture used here? Is it RNN?

    • @shreyjain6447
      @shreyjain6447 3 роки тому +2

      @@tomcat9761 No. It's a simple ANN

    • @mahnoorhome
      @mahnoorhome Рік тому +2

      hey. where can i get source code? any idea?

    • @Krbydav328
      @Krbydav328 Рік тому +1

      try watching the video

  • @BarryGoodall
    @BarryGoodall 10 місяців тому +2

    Thank you. Great commentary and clear explanations. Easy to follow how you built up the application. Perfect.

  • @kifercastillo7876
    @kifercastillo7876 4 роки тому +16

    I would love to see a video about the theory, great video, thank you:)

  • @antoniorivolta
    @antoniorivolta 4 роки тому +83

    I never opened a UA-cam notification so fast

  • @cardosofede
    @cardosofede 4 роки тому +4

    Hey bro, your programming style is sophistecated 🧑‍💻

  • @miyurux
    @miyurux 3 роки тому +9

    Bro You are one of the most Underrated YT channel I've ever seen..... Keep up the good work : - )

  •  3 роки тому +1

    ahhhhhh...BOSS!!! may your days be long
    you've given me hope and reignited my passion

  • @foggers0476
    @foggers0476 4 роки тому +6

    I love your videos! They're so useful :D I've just purchased your 7 in 1 book from amazon

  • @tansimbee11
    @tansimbee11 Рік тому +1

    Well done. As I am new to chatbot() and python. Your video helped to fill in all the gaps in Tim video. Thanks brother.

  • @masthad
    @masthad 3 роки тому +14

    The video got really good but we don’t really clarify what packages to download. I know you said what at the beginning at Imports but it still gives me error messages with Tensorflow.
    For example: '
    To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags. '

  • @dreamsauce8745
    @dreamsauce8745 3 роки тому +3

    For anyone having issues with the model not running. change train_x and train_y into a tensor and adjust the input shape of the model to be 15, 5

    • @akeeme8921
      @akeeme8921 3 роки тому +4

      what do you mean by change them into a tensor

    • @poojashah3131
      @poojashah3131 2 роки тому

      can you share the code?

  • @juliusmakowski7665
    @juliusmakowski7665 4 роки тому +7

    I have to make one for school so this is perfect timing ;^)

    • @shelby255
      @shelby255 3 роки тому +1

      Our school only do pascal bruh

  • @BlueBirdgg
    @BlueBirdgg 2 роки тому +5

    ? - keras in "tensorflow.keras..." is not recognized by 'Pycharm', but it works anyway.
    Changes:
    - from tensorflow.keras.optimizers import SGD
    + from tensorflow.keras.optimizers.legacy import SGD
    - training = np.array(training)
    +training = np.array(training, dtype=object)
    -sgd = SGD(lr=0.01, decay=1e-6, momentum=0.9, nesterov=True)
    +sgd = SGD(learning_rate=0.01, decay=1e-6, momentum=0.9, nesterov=True)

  • @cartf15
    @cartf15 4 роки тому +2

    brother please do not stop! you are awesome

  • @lorenzoricciardi7051
    @lorenzoricciardi7051 4 роки тому +3

    sooo interested to the neural network theory!!! Love this channel so much, i've learned so much, thank you!!

  • @aishikbandyopadhyay8191
    @aishikbandyopadhyay8191 4 роки тому +49

    Ah! Was waiting for this only!🔥

    • @NeuralNine
      @NeuralNine  4 роки тому +7

      enjoy it! :)

    • @AkashSingh-di7vu
      @AkashSingh-di7vu 4 роки тому +1

      Me too🤠

    • @TalesHerman
      @TalesHerman 3 роки тому

      @@NeuralNine Hello, this error is returning: *lemmatize() missing 1 required positional argument: 'word'*

  • @peschebichsu
    @peschebichsu 3 роки тому +8

    20:42 very interested in the theory, I like how you explain and would be cool to hear it from you

  • @SimonTiger
    @SimonTiger 4 роки тому +16

    So...as far as the machine learning goes, it's just a text classification algorithm. I would love to see a version of this with actual text generation as well!

    • @NeuralNine
      @NeuralNine  4 роки тому +7

      I mean it would be possible to combine it with the text generation tutorial I made some time ago ^^

    • @SimonTiger
      @SimonTiger 4 роки тому

      @@NeuralNine Can't seem to find it!

    • @shanereedy8336
      @shanereedy8336 4 роки тому +3

      @@SimonTiger I was hoping to find a comment like yours here. This may be the video he is referring to. ua-cam.com/video/QM5XDc4NQJo/v-deo.html

    • @mahnoorhome
      @mahnoorhome Рік тому

      hey. where can i get source code? any idea?

    • @Hyperdelica-Xander
      @Hyperdelica-Xander Рік тому

      @@NeuralNine YOU should really make that happen as a video!!!

  • @pw5687
    @pw5687 3 роки тому +11

    it would be cool if you made a video where you combined a chatbot like this with/into a discord bot!

    • @owenknowles3796
      @owenknowles3796 3 роки тому +1

      you'd just use discord.py to detect when a message is sent, use that message as the input for the AI, and output the AI's output as the discord message

    • @pw5687
      @pw5687 3 роки тому

      @@owenknowles3796 didn't think about that thanks! Will try when computer switches on

    • @Fuel_The_Fire
      @Fuel_The_Fire Рік тому

      @@pw5687 How'd it go?

  • @stanst2755
    @stanst2755 2 роки тому +1

    Nice tutorial on basic Keras NN setup. The truth is there is no need for a NN here. What it does is a simple input text selector and a random generator to output the response text. You could do the same using regexp/similar text/soundex word matching.

    • @nostravis2770
      @nostravis2770 2 роки тому

      I was hoping i wouldn't be the only one realizing this. Using a NN for this is such overkill.

  • @scholar1234
    @scholar1234 4 роки тому +3

    Never seen this type of content before, really amazing

    • @danielniels22
      @danielniels22 3 роки тому

      yeah, his tutorials are very applicable. i wonder what would happen to my knowledge if i carry one of that out each day for 1 month staright

  • @arthur6999
    @arthur6999 4 роки тому

    man I was just building a hard-coded chatbot, this vid came in the right time for me. thanks bro

    • @arthur6999
      @arthur6999 4 роки тому

      @Hotdog_man2 Minecraft lol yea

  • @audunlarssonkleveland4789
    @audunlarssonkleveland4789 2 роки тому +3

    btw if you struggle with translation to vscode on the importation of tensorflow instead type "from tensorflow.python.keras.layers ...." and so on

    • @albertdecandia2644
      @albertdecandia2644 6 місяців тому

      Thank you so much!! I was going crazy trying to find a solution.

  • @JacobHKent
    @JacobHKent 3 роки тому +34

    when it comes to trading in the various financial markets the relevance of professional guidance should not be undervalued as it could be the key to any traders success in profit making

    • @piricontes2844
      @piricontes2844 3 роки тому

      spot on! but the usual problem is discovering well grounded professionals who can be trusted. have you got any reconmendations?

    • @tamastimea1709
      @tamastimea1709 3 роки тому

      i could not have said it any better.

    • @JacobHKent
      @JacobHKent 3 роки тому

      @@piricontes2844 I will highly recommend Michael Branagh, he helped me secure a passive source of income, made life quiet easier for me as I no longer had to work round the clock. I'd check if he's taking new investors now, and also ask if I can share his contact information to the public.

    • @piricontes2844
      @piricontes2844 3 роки тому

      @@JacobHKent i have stumbled upon a couple of articles by him, never occured to me to look him up. i would sincerely appreciated if you coild help with his contact info.

    • @bensonmccredden7102
      @bensonmccredden7102 3 роки тому

      @@JacobHKent Mr Branagh is one of the most productive traders out there. i would not say hes the best at what he does but one thing is certain, hes a man of integrity and he certaainly gets results

  • @MrJoeflames
    @MrJoeflames 2 роки тому +1

    if you get an error with hist = model.fit(np.array(train_x), np.array(train_y), epochs=200, batch_size =5, verbose=1 ), just delete "accuracy in model.compile

  • @abdulalimbaig3286
    @abdulalimbaig3286 2 роки тому +6

    This is an amazing tutorial brother, thanks for all the knowledge you've shared! You earned a subscriber!

  • @olegsheremeta1628
    @olegsheremeta1628 Рік тому +2

    training = np.array(training) throws an error!
    ValueError: setting an array element with a sequence. The requested array has an inhomogeneous shape after 2 dimensions. The detected shape was (12, 2) + inhomogeneous part.

    • @davidpadillamunoz1140
      @davidpadillamunoz1140 Рік тому +2

      Sorry if it's too late, but I solved this error with the following:
      training_array = []
      for item in training:
      part1 = np.array(item[0])
      part2 = np.array(item[-1])
      list_items = [part1, part2]
      training_array.append(list_items)
      Then you can use 'training_array' np.array(training) like.

  • @ronit.dhingra_
    @ronit.dhingra_ 4 роки тому +12

    NIce video! Can you make an in-depth tutorial on making a friend-like chatbot that uses neural networks and NLP, and adapts it to modern libraries like Keras and TensorFlow? I've been making a project, but I've been having some issues.

  • @AdwaithAbhilash-k5z
    @AdwaithAbhilash-k5z Рік тому

    This helped me learn a lot about neural networks thanks!

  • @justinfranzsevilla2310
    @justinfranzsevilla2310 4 роки тому +39

    Ah yes, now I can make a very own best friend who can understand me :DDDD

  • @rinshinjalal1952
    @rinshinjalal1952 4 роки тому

    i have'nt watched your video before this video but now ican't stop watching your video

  • @chingyee2804
    @chingyee2804 3 роки тому +1

    Yes I’m very interested in neural network theory! 🙋‍♂️🙋‍♂️🙋‍♂️🙋‍♂️🙋‍♂️

  • @Tradebountyy
    @Tradebountyy 3 роки тому +3

    for intent in intents['intents']:
    for pattern in intent['patterns']:
    word_list = nltk.word_tokenize(pattern)
    words.append(word_list)
    documents.append((word_list, intent['tag']))
    if intent['tag'] not in classes:
    classes.append(intent['tag'])
    This showing me error
    " For pattern in intent['patterns']
    KeyError : 'patterns'
    Please help me out!

  • @matheusgirardiscalabrin5651
    @matheusgirardiscalabrin5651 3 роки тому +1

    I was recieving TypeError at 14:30
    This solve for me
    "
    pip install self
    nltk.download('wordnet')
    import self
    words = [lemmatizer.lemmatize(self, word) for word in words if word not in ignore_letters]
    words = sorted(set(words))
    "

  • @ratto751
    @ratto751 4 роки тому +14

    Hi, great content! Although, is it possible for you to upload the code in your videos to a github repo? Thanks

    • @Yankzy
      @Yankzy 3 роки тому

      That will be great!

  • @karl4563
    @karl4563 8 місяців тому

    thank you ! needed this in my school project

  • @odiushealer4759
    @odiushealer4759 3 роки тому +5

    Can you make a series on neural network theory? This video was very helpful.Thanks

  • @TechWithSabri
    @TechWithSabri 4 роки тому

    when i finished this chat i typed in terminal: " hello!"
    the answer was "sad to see you go :( "
    hahahahahahah i'm crying !!!!
    thank you it's working perfectly

    • @fernandobarocio2796
      @fernandobarocio2796 4 роки тому

      I have that exact error... how did you fix it?

    • @TechWithSabri
      @TechWithSabri 4 роки тому

      @@fernandobarocio2796
      He used the intention.py file to answer the users.
      so you can use your own file or just google it you can find a lot of them.
      it's not a big problem.
      good luck.

  • @HacKyNerDz
    @HacKyNerDz 4 роки тому +5

    Your videos are always amazing, always i learn a lot from your videos 🤩🤩

    • @NeuralNine
      @NeuralNine  4 роки тому +4

      appreciate it :D

    • @delvinanthony2798
      @delvinanthony2798 4 роки тому +2

      @@NeuralNine Hey man for some reason whenever I say Hello or one of the greetings it says a goodbye response. Any idea why?

    • @kenzyscope2396
      @kenzyscope2396 Рік тому

      @@NeuralNine can i get the source code please

  • @Joesignals
    @Joesignals 2 роки тому

    I'm trying to create a chatbot for customer care, it is going to be a live support agent for industries like Telecom companies, so after I finish with all the knowledge you have shared maybe I will have some questions and everything else.

  • @Match0Man
    @Match0Man 2 роки тому +14

    Hi NeuralNine, this is a great piece. I would like to ask you if this tutorial would work for another language. Would it be enough to just edit intents, to comply with the language I would like to use? And the second question, do you have some tutorial, on how to implement this bot to streamlabs chatbot for twitch?

    • @knildawild
      @knildawild 2 роки тому +4

      I tried it with german words and all I had to do is define the language in the word_tokenize function:
      nltk.word_tokenize(pattern,language='german')

    • @mahnoorhome
      @mahnoorhome Рік тому

      hey. where can i get source code? any idea?

  • @Lahirushub
    @Lahirushub Рік тому

    thanks, that works(some code mistakes corrects by chatGPT) nice video

  • @melvinfrancis7525
    @melvinfrancis7525 4 роки тому +3

    Man do i love that intro 🔥

  • @artdrawing6682
    @artdrawing6682 2 місяці тому

    men thank you for this totoriol, i download your video , creat ai chat bot ful system you show me many things i don't know her you are amazing thank you

  • @anandhu5082
    @anandhu5082 4 роки тому +3

    22:08 Hi, i'm new to DL.. When we use Softmax, if there are (say)two outputs in the network, it will output probabilities like [.4 ,.6] or [.1, .9] or [.5, .5] etc right? (sum always 1).. so even if we enter some gibberish as input, there will always be some output(s) above error threshold of (say) .25.
    How ill I tweak this so this won't happen? ( i mean if i enter "ahfliehf fsdlihfasdh" to bot, the outputs should be like something like [0.001, 0.00123])

  • @vishvajitviswanathan7970
    @vishvajitviswanathan7970 4 роки тому +1

    Please put more videos like this bro, I needed some sorry more....
    And if you are about to launch a video give a gif for that. That thrill will be enough for me to be happy. Don't get faded bro, we need you...

  • @TISIMTISMTISM
    @TISIMTISMTISM 3 роки тому +4

    This was amazing! Thank you so much I have learned a lot :D

  • @AL_383
    @AL_383 4 роки тому

    a series about NN/ ai in general would be dope

  • @leonardorossoni1177
    @leonardorossoni1177 4 роки тому +15

    When will you open a Discord Server?

  • @morganhudson3185
    @morganhudson3185 2 роки тому

    bro your intro is fire

  • @LamsyTech
    @LamsyTech 4 роки тому +6

    Awesome work bro!
    I like your videos
    Kudos to you
    I suggest you make a tutorial video on show to deploy an AI CHATBOT to back-end server to improve responsiveness and present more details.

  • @majestro4077
    @majestro4077 5 місяців тому

    the thing about this intelligent ai is just that its not context based cuz it don't have access in the conversation history

  • @amantarar9077
    @amantarar9077 3 роки тому +3

    there is correction on line 51 in chatbot.py ."responses" should be replaced with "response"

    • @noorulainnoor8831
      @noorulainnoor8831 2 роки тому

      I code exactly same but couldn't able to to write any msg after "GO! Bot is running". can you help me? how to sort it out

  • @umarhasnain7369
    @umarhasnain7369 4 роки тому +1

    Can you please zoom a bit more on the code? Would be better to understand 🙂.

  • @samsam3215
    @samsam3215 3 роки тому +13

    this tutorial is very useful! can I have the project source code for self-learning?

  • @appvoid
    @appvoid 3 роки тому

    Love this but I think Levenshtain Distance fits better when doing small projects.

  • @rayyanmairaj5330
    @rayyanmairaj5330 4 роки тому +7

    Hey NeuralNine, really like the videos.
    Could you please like zoom in to the code... Or like increase the font. Its kinda difficult to see the code especially when not on full screen.
    Even when youre showing other stuff like how to install mingw for c++... The text looks really small
    But i really love your content and learn a lot. So if you could address that i'd be stoked

  • @m.pavankalyan2650
    @m.pavankalyan2650 Рік тому

    This video is really great and this AI projects series is extraordinary

  • @bloodang6793
    @bloodang6793 2 роки тому +4

    Hello... i have tried to copy your code now in 2023 and apparently there is an issue with training = np.array(training) since the [bag, output_row] columns don't have the same dimensions (maybe I have copied something wrong along the way...).
    I have came up with a solution that bypass the issue, although its quite a caveman style solution and I do not have the knowledge to understand its consequences, but it does not crash the code and allows me to train the chatbot.
    solution:
    when defining the dimensions of:
    output_empty = [0] * len(classes)
    instead do:
    output_empty = [0] * len(words)
    this way the dimensions of "bag" and "output_row" are the same. (It will fill the space with 0, so it shouldn't change the bot training accuracy... but what do I know :D )

    • @Kanishkaran.__
      @Kanishkaran.__ 2 роки тому

      Hey what about importing tensorflow, I tried copying too but mines showing error like 'rebuild tensorflow with appropriate compiler flags'

    • @bloodang6793
      @bloodang6793 2 роки тому

      @@Kanishkaran.__ Not really sure, but as I figured lately its quite a lot about version compatibilities with TF and all these days. Try searching if your versions match.

    • @Kanishkaran.__
      @Kanishkaran.__ 2 роки тому

      @@bloodang6793 What's the version used here?

    • @Kanishkaran.__
      @Kanishkaran.__ 2 роки тому

      @MYSTERIOUS no

  • @SaadAhmed-pu8wp
    @SaadAhmed-pu8wp 9 місяців тому

    Excellent and very helpful.. thanks a lot
    Would you make another one in which we can give command to the chatbot and it takes some action, for e.g. "open google chrome" or "close microsoft word".. TIA.

  • @confused398
    @confused398 3 роки тому +3

    When I added training data to the intents.json file, I got this error, anybody who can help?
    ValueError: Input 0 of layer sequential is incompatible with the layer: expected axis -1 of input shape to have value 38 but received input with shape (None, 84)
    I figured out that the 84 is just the amount of patterns in the intents.json file, but I haven't figured out why the input shape has to have a value of 38.

  • @____________6063
    @____________6063 4 роки тому

    Awesome tutorial, it worked right away! You definitely got me as a subscriber.

    • @ibaadahmed5925
      @ibaadahmed5925 2 роки тому

      hey can u tell what extensions to download pls

  • @DoggoYT
    @DoggoYT 4 роки тому +3

    Works great! Im having this error when adding more than 3 intents though.
    ValueError: Input 0 of layer sequential is incompatible with the layer: expected axis -1 of input shape to have value 27 but received input with shape [None, 30]. :/

    • @netofis
      @netofis 3 роки тому +1

      Me too! did you find the solution??

    • @netofis
      @netofis 3 роки тому

      I found the error. I forgot to change the model name in the chatbot.py , it was .model but the correct is .h5

    • @joelees
      @joelees 3 роки тому +1

      @@netofis omg thank you so much I've been searching for the solution to this error for an hour 😭

    • @poojashah3131
      @poojashah3131 2 роки тому +1

      @@netofis Thank you so much, was struggling for 2 hours

  • @dakshesh-1
    @dakshesh-1 3 роки тому

    UNDERRATED , u deserve a million sub

  • @80sVectorz
    @80sVectorz 4 роки тому +3

    my bot keeps saying the intent is goodbye even if I say "how are you?" it says hey or goodbye or talk to you later

    • @amulyaparitosh660
      @amulyaparitosh660 4 роки тому +1

      I have similar problem.
      my bot keeps saying "hi", ""hello", "what can i do for you", even if i ask "what is your name"

    • @amulyaparitosh660
      @amulyaparitosh660 4 роки тому

      please help

    • @isaacmuscat5082
      @isaacmuscat5082 4 роки тому

      If there’s nothing wrong with the preprocessing you probably have to find a way to properly tune the model with a test set and a training set to prevent under or overfitting.

    • @roopeshk.r3219
      @roopeshk.r3219 4 роки тому

      Hey, I have a Problem after training , type error in last 2 functions, While true, get_response

    • @delvinanthony2798
      @delvinanthony2798 3 роки тому

      If you guys keep getting goodbye messages for other things change the error_threshold to 0.5 and if that doesn't work change the epochs in training.py to 800

  • @BUFHD
    @BUFHD 2 роки тому +1

    training = np.array(training)
    ValueError: setting an array element with a sequence. The requested array has an inhomogeneous shape after 2 dimensions. The detected shape was (17, 2) + inhomogeneous part.
    Any solution to this issue? @24:00

    • @freeze329rus
      @freeze329rus 2 роки тому +2

      Same here. Have you managed to fix it?

    • @malavikaa7533
      @malavikaa7533 2 роки тому +1

      did you solve it?

    • @BUFHD
      @BUFHD 2 роки тому +1

      @@malavikaa7533 I believe the code is outdated.

    • @BUFHD
      @BUFHD 2 роки тому +1

      @@freeze329rus I think the code is outdated.

    • @60-abdulrahman41
      @60-abdulrahman41 2 роки тому

      @@BUFHD hi it is showing -'ValueError: setting an array element with a sequence. The requested array has an inhomogeneous shape after 2 dimensions. The detected shape was (27, 2) + inhomogeneous part"
      any idea how to fix t?

  • @SkynetT-model
    @SkynetT-model 3 роки тому +6

    and this is how my creator came to life.

  • @response4322
    @response4322 3 роки тому +2

    What is the difference between this and using something like the difflib SequenceMatcher library or the Levenshtein method, as in finding the similarity metric between the given input and a list of sentences and then picking the closest match as a response by looping through all the data one by one? Just tried it, and it works exactly the same but with a few lines of code, which brings me to the question why using AI for this is even necessary?

  • @yaranassar1208
    @yaranassar1208 Рік тому +3

    training = np.array(training) is returning an error, can you help?
    ---------------------------------------------------------------------------
    ValueError Traceback (most recent call last)
    Cell In[24], line 26
    24 # shuffle our features and turn into np.array
    25 random.shuffle(training)
    ---> 26 training = np.array(training)
    28 # create train and test lists. X - patterns, Y - intents
    29 train_x = list(training[:, 0])
    ValueError: setting an array element with a sequence. The requested array has an inhomogeneous shape after 2 dimensions. The detected shape was (27, 2) + inhomogeneous part.

  • @mashaklepin3606
    @mashaklepin3606 2 роки тому

    All the people recently saying the code doesn't work... I got it working very quickly. There are a few slight changes and I'm sure if you really want to, you can figure it out.

    • @yazeedmizu3184
      @yazeedmizu3184 Рік тому

      Mind sharing your knowledge with us brother?

  • @27omkarmahindrakar54
    @27omkarmahindrakar54 3 роки тому +3

    Can you please provide the files of the bot
    (because mine didn't worked)

  • @savvidaios
    @savvidaios Рік тому

    I learned a lot through this video. However since we have static replies for this exact project I believe that splitting the string from the user input into a list as you did, finding a key word and thus give the reply could be easily and faster done with if else statements. I get the educational manner for the AI part but because you didn’t exactly analyze the code that you used in the machine learning part because of the purpose of the video I will stick to my opinion having the thought of the purpose of the video being “build a chatbot” and not “use ai to create something”. Great video though❤

  • @magmaslasher7604
    @magmaslasher7604 3 роки тому +2

    Are you ever going to make a tutorial on a chatbot that generates its own responses?

  • @kinjalkg7704
    @kinjalkg7704 4 роки тому +4

    Hello, i am unable to install tensorflow!!please help

    • @Adhithya2003
      @Adhithya2003 4 роки тому

      Use this video its very good and well we ua-cam.com/video/zRY5lx-So-c/v-deo.html

    • @maxmayer3551
      @maxmayer3551 4 роки тому

      tensorflow does not support python versions after 3.6.4, so you'll have to change your version

    • @ratto751
      @ratto751 4 роки тому

      @@maxmayer3551 That's pure BS. It's available till Python 3.8

    • @maxmayer3551
      @maxmayer3551 4 роки тому

      ​@@ratto751 I was using 3.8 and I had the same issue as this guy so I looked it up, read an article that told me tensorflow doesn't work beyond 3.6.4 so I switched versions and it completely fixed my issue. So if you really insist that my experience was purely circumstantial

    • @ratto751
      @ratto751 4 роки тому

      @@maxmayer3551 Would you rather trust an article or the official TensorFlow GitHub and PyPi? I've been able to run TensorFlow on python 3.8. There must be some other problem with your PC since it works with 3.8 on mine.

  • @ok-14907
    @ok-14907 4 роки тому +1

    Thanks 👍 I was actually waiting for this.

  • @narchess
    @narchess 4 роки тому +5

    The code is not working.
    output_row[classes.index(document[1])] = 1
    IndexError: list index out of range

  • @naruto5340
    @naruto5340 Рік тому

    espero que puedas traducir este mensaje, pero solo quiero agradecerte porque me ayudaste mucho al basarme en este bot, saludos desde Mexico :)

  • @MACHINEBUILDER
    @MACHINEBUILDER 3 роки тому +3

    Hey, any idea how you'd get this to run with tflite?
    Edit: Okay, I've gotten the model to run, but I realised nltk stemming is really slow. Is there a faster alternative?
    (actually I'll try figure out exactly what's taking ages)
    Edit #2: Nevermind, it all works, there's just a delay the first time the process is called for some reason (Which I'll try to trace and fix)
    Thanks for the great tutorial, can't wait to setup my own personal assistant!

  • @flavio4923
    @flavio4923 2 роки тому

    Btw Nesterov is to implement an accelerating learning rate ,I think

  • @prathmeshkulkarni2079
    @prathmeshkulkarni2079 Рік тому +7

    #Dec 2023-
    import random
    import json
    import numpy as np
    import pickle
    import tensorflow as tf
    import nltk
    from nltk.stem import WordNetLemmatizer
    from tensorflow.keras.models import Sequential
    from tensorflow.keras.layers import Dense, Activation, Dropout
    from tensorflow.keras.optimizers import SGD
    from tensorflow.keras.preprocessing.sequence import pad_sequences
    # Download NLTK data
    nltk.download('punkt')
    nltk.download('wordnet')
    lemmatizer = WordNetLemmatizer()
    intents = json.loads(open('intents.json').read())
    words = []
    classes = []
    documents = []
    ignore_letters = ['?', ',', '!', '.']
    for intent in intents['intents']:
    for pattern in intent['patterns']:
    word_list = nltk.word_tokenize(pattern)
    documents.append((word_list, intent['tag']))
    words.extend(word_list) # Append words to the 'words' list
    if intent['tag'] not in classes:
    classes.append(intent['tag'])
    words = [lemmatizer.lemmatize(word.lower()) for word in words if word not in ignore_letters]
    words = sorted(set(words))
    classes = sorted(set(classes))
    pickle.dump(words, open('words.pkl', 'wb'))
    pickle.dump(classes, open('classes.pkl', 'wb'))
    training = []
    output_empty = [0] * len(classes)
    for document in documents:
    bag = []
    word_patterns = document[0]
    word_patterns = [lemmatizer.lemmatize(word.lower()) for word in word_patterns]
    # Create a bag of words with 1s and 0s
    bag = [1 if word in word_patterns else 0 for word in words]
    # Create the output row
    output_row = list(output_empty)
    output_row[classes.index(document[1])] = 1
    # Append the bag and output_row as separate lists
    training.append([bag, output_row])
    # Shuffle the training data
    random.shuffle(training)
    # Split the training data into X and Y
    train_x = np.array([item[0] for item in training])
    train_y = np.array([item[1] for item in training])
    model = Sequential()
    model.add(Dense(128, input_shape=(len(train_x[0]),), activation='relu'))
    model.add(Dropout(0.5))
    model.add(Dense(64, activation='relu'))
    model.add(Dropout(0.5))
    model.add(Dense(len(train_y[0]), activation='softmax'))
    sgd = SGD(learning_rate=0.01, momentum=0.9, nesterov=True)
    model.compile(loss='categorical_crossentropy', optimizer=sgd, metrics=['accuracy'])
    hist = model.fit(train_x, train_y, epochs=200, batch_size=5, verbose=1)
    model.save('Chatbot_model.h5', hist)
    print("Done!")

    • @rushabhshah12200
      @rushabhshah12200 10 місяців тому

      What in the world! Thankfully I found you and now I trained my model correctly. I was getting this error:
      78 random.shuffle(training)
      ---> 79 training = np.array(training)
      80
      81 train_x = list(training[:, 0])
      ValueError: setting an array element with a sequence. The requested array has an inhomogeneous shape after 2 dimensions. The detected shape was (392, 2) + inhomogeneous part.
      I don't know what to do with this I asked every gpts even got link of source code in github then also getting same error. I just copied your code and hit run and then thankfully it worked.

  • @raghawpanpaliya7477
    @raghawpanpaliya7477 3 роки тому +3

    Well, I followed along and as I ran it....this guy decided to reply "Hello" with "Talk to you later" LMAOO 😭Even a bot isnt interested in talking with me 😒

  • @parkour8899
    @parkour8899 4 місяці тому

    guy, you help me a lot of with this video, thanks so much!

  • @mihailsoftware8219
    @mihailsoftware8219 4 роки тому +16

    can i have the source code?

  • @BrianFDeVore
    @BrianFDeVore 4 роки тому +1

    This tutorial is fantastic! Thank you for sharing.

    • @vipulkumar9858
      @vipulkumar9858 4 роки тому

      ua-cam.com/channels/0Bn9e36XqiiNZp9ClkPUww.html

  • @nefwaenre
    @nefwaenre 2 роки тому

    Okay, this is the best tutorial on chat bots!! i can follow along! Quick question: Is it possible to show the "questions" as options to the user so that instead of typing, they choose from the options of questions instead?
    i tried following Tech with Tim's but it was kinda hard.

  • @ivailostoyanov8689
    @ivailostoyanov8689 3 роки тому +2

    Hello, just wanted to throw my feedback for you guys! Very good video (you should watch his neural network theory video, it helps a lot)
    While implementing alongside you I would always get no more than 0.75 accuracy, BUT if for the first time we use lemmatize you put this:
    words = [lemmatizer.lemmatize(word.lower()) for word in words if word not in symbols_to_ignore]
    It increases the accurasy to 0.9 - 1. Which makes the AI much more efficient! Also in the cleaning up sentence fuction you might want to make the sentence lower cased :)

    • @Valo_TV
      @Valo_TV 3 роки тому

      i am getting no error it just runs and then stops

    • @jeremyfuchs63
      @jeremyfuchs63 2 роки тому

      It makes it much more efficient. Thanks for the comment :)

    • @tomcat9761
      @tomcat9761 2 роки тому +1

      correct me if i'm wrong but his model overfitted right?

  • @Rocklee46v
    @Rocklee46v 4 роки тому +2

    Can you post a video on how to extract entities from intents and deploy the chatbot on a website or something. thanks

  • @rakshamodi7503
    @rakshamodi7503 2 роки тому +2

    Sir, statement training= np.array(training) is showing error of array being inhomogeneous shape after 2 dimension. What would be the solution?

    • @nostahlga
      @nostahlga 2 роки тому +1

      It's because they optimizer used in 2020 is now considered legacy. I was able to run the pre-processor with the following alterations to my code.
      # Change the SGD import
      from tensorflow.keras.optimizers import SGD -> from tensorflow.keras.optimizers.legacy import SGD
      # Change the numpy training array
      training = np.array(training,) -> training = np.array(training, dtype=object)

    • @avery_person8126
      @avery_person8126 2 роки тому

      @@nostahlga thank you

  • @haokaixuan
    @haokaixuan 4 роки тому +1

    Hey manx nice content, always excited when you post a new video

  • @ProtonAI
    @ProtonAI Рік тому +1

    Hey @NeuralNine why this error happens in your code 👇👇
    'ValueError: setting an array element with a sequence. The requested array has an inhomogeneous shape after 2 dimensions. The detected shape was (20, 2) + inhomogeneous part.'

    • @Tussu17
      @Tussu17 Рік тому

      Same mate :(
      any solution till now?

    • @yazeedmizu3184
      @yazeedmizu3184 Рік тому

      @@Tussu17 Hey man found any solution?

  • @sobhandeepgope
    @sobhandeepgope 3 роки тому +1

    Thank you very much sir, for this awesome tutorial....😍😍😍😍

  • @CritiKylie
    @CritiKylie 2 роки тому +1

    Great video, I learned so much, thank you!

  • @ItsMe-dk6zi
    @ItsMe-dk6zi 2 роки тому

    ValueError: setting an array element with a sequence. The requested array has an inhomogeneous shape after 2 dimensions. The detected shape was (25, 2) + inhomogeneous part.

    • @Freakyloggs
      @Freakyloggs Рік тому

      training = np.array([training], dtype=object)
      paste it there
      but still another error will come