Skip to content

tattle-made/feluda

Feluda

DPG Badge

A configurable engine for analysing multi-lingual and multi-modal content.

While flexible, we built it to analyse data collected from social media - images, text, and video. This forms the core of our search, clustering, and analysis services. Since different use cases might require different search capabilities with different trade-offs, Feluda lets you specify which building blocks you want to use for the purpose and spins an engine with a corresponding configuration.

Example Uses

Understanding Operators in Feluda

When we built Feluda, we were focusing on the unique challenges of social media data in India. We needed to process data in various modalities (text, audio, video, images, hybrid) and various languages. There would often be very different technologies that needed to be evaluated for each. So we built Feluda around a concept of operators. You can think of operators as plugins that you can mix and match to perform different analyses on your data (see Features section below). When you start feluda, you configure which operators you want to use and then feluda loads it. While in its current iteration Feluda comes with certain operators in its source code, the operators are defined in a way that anyone can create their own operators and use it with Feluda. Operators are easy to swap in and out. Not only does this allow you to try out various analysis techniques, it also means you aren't tied to any one implementation for an operation. Some use cases for operators that we've tried out are following :

  1. If someone wants to run image data aggregation on a budget, instead of using an operator that uses a heavy machine learning model, they can use an operator that uses hashing instead.
  2. If someone wants to extract text from images and don't want to use a google product, they could use an operator that uses OpenCV instead of the Google Cloud Vision API.

Features Enabled

  • Support for Vector-based embeddings using ResNet models and Sentence Transformers.
  • Support for hash-based search using pHash.
  • Text extraction from images and indexing into the engine.
  • Entity extraction from text and images and indexing into the engine.

Basic Usage

Feluda can be used as a Python library to process and analyze data using its modular operators. Below is a quick overview of how to install Feluda, configure it, and use it in your Python projects.

Prerequisites

Before you begin, ensure that the following system dependencies are installed:

  • Python version 3.10 or higher
  • optionally we recommend to use uv for python pacakges and project managment. Install uv by following its official installation guide.

Installation

You can install feluda using

pip install feluda

Each operator also has to be installed seperately. Link to a list of published feluda operators. For instance, you can install the feluda-vid-vec-rep-clip operator like

pip install feluda-vid-vec-rep-clip

Configuration

Feluda uses a configuration file (.yml) to define the operators and their parameters. This allows you to customize your workflow without modifying the code. You will have to create this .yml file manually.

Here’s an example configuration file (config.yml):

operators :
  label : "Operators"
  parameters :
    - name : "Video Vector Representation"
      type : "vid_vec_rep_clip"
      parameters: {}
    - name : "Image Vector Representation"
      type : "image_vec_rep_resnet"
      parameters: {}
  • operators: A list of operators to be used.
  • name: The name of the operator.
  • parameters: Any other Operator specific parameters.

Code Example

Here’s a simple example to demonstrate how to use Feluda:

from feluda import Feluda

config_path = "/path/to/config.yml"

# Initialize Feluda with the configuration file
feluda = Feluda(config_path)
# Set up Feluda and its operators
feluda.setup()

# Access an operator and run a task
operator = feluda.operators.get()["vid_vec_rep_clip"]
result = operator.run("path/to/example.mp4")
print(result)

For more details, refer to the Feluda Wiki.

Contributing

You can find instructions on contributing on the Wiki

Documentation for Setting up Feluda for Local Development - Link to the Wiki