Skip to main content

A package to simplify chatbot creation using NLP.

Project description

nlpchat

nlpchat is a Python package that simplifies the creation of chatbots using natural language processing (NLP) for intent identification. The package uses Sentence Transformers for embedding input text and supports easy management of intents with customizable responses. It provides functionality for training, saving, and loading models, allowing you to avoid retraining the chatbot each time.

Features

  • Simple intent management: Easily add intents, patterns, and responses.
  • NLP-powered: Uses Sentence Transformers to embed and understand user inputs.
  • Train and Save: Train the model once and save it for later use.
  • Load saved models: Quickly load previously trained models for immediate use.
  • Intent prediction: Predicts the user's intent based on input text.
  • Custom responses: Generate responses based on detected intents.
  • Intent-only prediction: Retrieve just the predicted intent without generating a response.

Installation

You can install the package from the repository:

pip install nlpchat

Usage

Here’s a simple example showing how to create a chatbot, train it, save the model, and make predictions.

1. Import and Initialize the Chatbot

from nlpchat import EasyChatbot

# Create an instance of EasyChatbot
chatbot = EasyChatbot()

2. Add Intents

You can add intents using the add_intent() function by providing a tag (intent name), patterns (user inputs), and responses.

# Add a greeting intent
chatbot.add_intent(
    tag="greeting",
    patterns=["Hi", "Hello", "Good morning", "How are you?"],
    responses=["Hello!", "Hi there!", "Good to see you!"]
)

# Add a goodbye intent
chatbot.add_intent(
    tag="goodbye",
    patterns=["Bye", "See you later", "Goodbye"],
    responses=["Goodbye!", "See you later!", "Take care!"]
)

3. Train the Model

Train the chatbot on the added intents.

chatbot.train()

4. Save the Model

Once the model is trained, you can save it to a file for future use.

# Save the trained model to a file
chatbot.save_model("chatbot_model.pkl")

5. Load a Saved Model

To avoid retraining every time, load the saved model.

# Load the saved model
chatbot.load_model("chatbot_model.pkl")

6. Predict Intent and Get Response

After the model is loaded, you can use it to predict user intents and get a response.

user_input = "Hello"
response = chatbot.get_response(user_input)
print(response)  # Outputs: "Hello!" or another greeting response

7. Predict Intent Only

If you only need to predict the user's intent without generating a response, you can use the get_intent() method:

# Get only the predicted intent (without response)
user_input = "Hello"
intent = chatbot.get_intent(user_input)
print(f"Predicted intent: {intent}")  # Outputs: "greeting"

How It Works

  • Intent Management: Users define intents using add_intent(). Each intent has a tag (such as "greeting"), a set of patterns (user inputs), and a set of responses.
  • Training: The chatbot uses the Sentence Transformer model to encode input patterns and trains a Logistic Regression model to map patterns to intents.
  • Prediction: When user input is given, the chatbot encodes the input using the Sentence Transformer model, predicts the intent using the Logistic Regression model, and returns a random response from the associated intent (or just the intent if requested).

Dependencies

The following dependencies are required:

  • sentence-transformers
  • scikit-learn
  • numpy
  • pickle-mixin

License

This project is licensed under the MIT License. See the LICENSE file for details.

Contributing

Contributions are welcome! If you’d like to contribute to the project, please fork the repository and submit a pull request.

Contact

For any issues or suggestions, please open an issue on the GitHub repository.


### Key Updates:
- Added a section on "Predict Intent Only" to clarify how users can retrieve just the intent.
- Made minor adjustments for clarity and flow.

Feel free to customize any sections, such as the contact link or author information! Let me know if you need any more changes.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nlpchat-1.0-py3-none-any.whl (5.0 kB view details)

Uploaded Python 3

File details

Details for the file nlpchat-1.0-py3-none-any.whl.

File metadata

  • Download URL: nlpchat-1.0-py3-none-any.whl
  • Upload date:
  • Size: 5.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.9

File hashes

Hashes for nlpchat-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 22096973c2c1786c82e98e18b06ce155e65da87d32d1606e8b6e500c11d92861
MD5 e38dbd12d31b91e20f68a3b2241a2b34
BLAKE2b-256 89ad0be608845c54c7116697033c9bada4cd44cdf202766dc190dc5cb2b4f031

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page