Skip to main content

Neuronic - AI-powered data transformation library

Project description

Neuronic 🧪

Neuronic Logo

Imagine writing Python functions that think, reason, and create - but with predictable, type-safe outputs. Functions that don't just process data, but understand it, while always returning exactly the format you need. Welcome to Neuronic - where we turn ordinary Python code into intelligent, AI-powered modules with built-in validation, caching, and error handling.

🌟 What is Neuronic?

Neuronic makes it simple to create AI-powered Python functions. Write clean, predictable code that leverages GPT models for complex tasks, while maintaining the reliability of traditional programming. Each function comes with built-in validation, type checking, and caching - making AI as dependable as any other Python module.

🚀 Features

  • Data Transformation: Convert between formats (CSV ↔ JSON ↔ XML)
  • Smart Analysis: Get insights and answers about your data
  • Data Generation: Create realistic test data on demand
  • Multiple Output Types: Support for strings, numbers, JSON, lists, booleans, and Python structures
  • Context-Aware: Use additional context for more accurate transformations
  • Flexible Input: Accept virtually any data type as input

📦 Installation

Install using pip:

pip install neuronic

🔑 Configuration

Create a .env file in your project root:

OPENAI_API_KEY=your-openai-api-key-here

Or pass your API key directly:

neuronic = Neuronic(api_key="your-api-key-here")

💡 Usage Examples

1. Data Transformation

Convert CSV data to JSON format:

from neuronic import Neuronic

neuronic = Neuronic()

customer_data = "John Doe, john@example.com, New York"
contact_card = neuronic.transform(
    data=customer_data,
    instruction="Convert this CSV data into a contact card format",
    output_type="json",
    example='{"name": "Jane Doe", "email": "jane@example.com", "location": "Los Angeles"}'
)

2. Data Analysis

Analyze sales data and get insights:

sales_data = [
    {"month": "Jan", "revenue": 1000},
    {"month": "Feb", "revenue": 1200},
    {"month": "Mar", "revenue": 900}
]
analysis = neuronic.analyze(
    data=sales_data,
    question="What's the trend in revenue and which month performed best?"
)

3. Data Generation

Generate test data with specific requirements:

test_data = neuronic.generate(
    spec="Create realistic user profiles with name, age, occupation, and favorite color",
    n=3
)

4. Context-Aware Transformation

Generate documentation with specific context:

code_snippet = "print('hello world')"
documentation = neuronic.transform(
    data=code_snippet,
    instruction="Generate detailed documentation for this code",
    output_type="json",
    context={
        "language": "Python",
        "audience": "beginners",
        "include_examples": True
    }
)

5. Boolean Decision Making

Make simple yes/no decisions:

sentiment = neuronic.transform(
    data="This product exceeded my expectations! Highly recommended!",
    instruction="Is this review positive?",
    output_type="bool"
)

6. Python Data Structures

Generate complex Python data structures:

data_structure = neuronic.transform(
    data="Create a nested data structure representing a family tree",
    instruction="Generate a Python dictionary with at least 3 generations",
    output_type="python"
)

🎯 Use Cases

Data Processing

  • Format conversion (CSV ↔ JSON ↔ XML)
  • Data cleaning and normalization
  • Schema transformation

Content Generation

  • Test data creation
  • Sample content generation
  • Documentation automation

Analysis

  • Data summarization
  • Trend analysis
  • Pattern recognition
  • Sentiment analysis

Development Support

  • Code documentation
  • API response transformation
  • Test data generation
  • Data validation

🔧 API Reference

Neuronic Class

Initialize the Neuronic class:

neuronic = Neuronic(api_key: str = None, model: str = "gpt-3.5-turbo")

Methods

transform()

Transform data according to instructions:

result = neuronic.transform(
    data: Any,                    # Input data
    instruction: str,             # What to do with the data
    output_type: str = "string",  # Desired output format
    example: str = None,          # Optional example
    context: dict = None          # Optional context
)

analyze()

Analyze data and get insights:

result = neuronic.analyze(
    data: Any,        # Data to analyze
    question: str     # Question about the data
)

generate()

Generate new data based on specifications:

result = neuronic.generate(
    spec: str,    # What to generate
    n: int = 1    # Number of items
)

🔒 Best Practices

  1. API Key Security

    • Use environment variables for API keys
    • Never commit .env files to version control
  2. Performance

    • Cache frequently used transformations
    • Batch similar operations when possible
  3. Error Handling

    • Always handle potential exceptions
    • Validate output types match expected formats

📝 License

MIT License - feel free to use in your own projects!

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Project details


Download files

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

Source Distribution

neuronic-0.2.0.tar.gz (1.6 MB view details)

Uploaded Source

Built Distribution

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

neuronic-0.2.0-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file neuronic-0.2.0.tar.gz.

File metadata

  • Download URL: neuronic-0.2.0.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.0

File hashes

Hashes for neuronic-0.2.0.tar.gz
Algorithm Hash digest
SHA256 463bf7a75a065157c7f39956ff4acbdae8c0836f4ae5ed07b44b149df65ba9f3
MD5 06d213d5507c9b154369142bf8ce48f2
BLAKE2b-256 ef6b96fa2c42218ae123d07610ab509aa1f757124d001fe10ad6063ef9c55b03

See more details on using hashes here.

File details

Details for the file neuronic-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: neuronic-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.0

File hashes

Hashes for neuronic-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a42c145fc2f575d9e2b3f1250c60301d50f76276af3fa75cb18b6a4cec622303
MD5 798b1149a7cf6cec95df535768ba174f
BLAKE2b-256 1aa54a85f4cd819ac60b0f6be22761a9d5e90ace3aab9fe64b9d0b30710610ef

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