Metadata-Version: 2.4
Name: plottini
Version: 0.4.0
Summary: A user-friendly graph builder with matplotlib backend for creating publication-quality plots from TSV data
Project-URL: Homepage, https://github.com/lanthoor/plottini
Project-URL: Documentation, https://github.com/lanthoor/plottini#readme
Project-URL: Repository, https://github.com/lanthoor/plottini
Project-URL: Issues, https://github.com/lanthoor/plottini/issues
Author-email: Lallu Anthoor <dev@spendly.co.in>
Maintainer-email: Lallu Anthoor <dev@spendly.co.in>
License: MIT
License-File: LICENSE
Keywords: chart,data,graph,matplotlib,plot,tsv,visualization
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: End Users/Desktop
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Scientific/Engineering :: Information Analysis
Classifier: Topic :: Scientific/Engineering :: Visualization
Requires-Python: >=3.10
Requires-Dist: click>=8.1
Requires-Dist: matplotlib>=3.7
Requires-Dist: nicegui>=1.4
Requires-Dist: numpy>=1.24
Requires-Dist: tomli-w>=1.0
Requires-Dist: tomli>=2.0; python_version < '3.11'
Provides-Extra: dev
Requires-Dist: mypy>=1.0; extra == 'dev'
Requires-Dist: pytest-cov>=4.0; extra == 'dev'
Requires-Dist: pytest>=7.0; extra == 'dev'
Requires-Dist: ruff>=0.1; extra == 'dev'
Requires-Dist: twine>=4.0; extra == 'dev'
Description-Content-Type: text/markdown

# Plottini

**A user-friendly graph builder for creating publication-quality plots from TSV data**

[![PyPI version](https://badge.fury.io/py/plottini.svg)](https://badge.fury.io/py/plottini)
[![Python 3.10+](https://img.shields.io/badge/python-3.10+-blue.svg)](https://www.python.org/downloads/)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

---

## Overview

Plottini is designed for researchers, scientists, and anyone who needs to create high-quality graphs from tabular data without writing code. With an intuitive web-based UI powered by NiceGUI and matplotlib as the rendering backend, Plottini makes it easy to:

- Load TSV data files with automatic validation
- Create various chart types (line, bar, scatter, histogram, and more)
- Apply mathematical transformations to your data
- Overlay multiple datasets on the same plot
- Export publication-ready figures in PNG, SVG, PDF, or EPS formats

---

## Features

### Core Capabilities
- **Multiple data sources**: Load one or more TSV files with configurable headers and comment delimiters
- **Rich chart types**: Line, Bar, Pie, Scatter, Histogram, Polar, Box, Violin, Area, and more
- **Data transformations**: Apply preset functions (log, sqrt, power, trig functions) to your data
- **Derived columns**: Create computed columns using safe mathematical expressions
- **Data filtering**: Filter rows by value ranges before plotting
- **Multi-file alignment**: Align multiple datasets by a common column
- **Secondary Y-axis**: Display two different scales on the same plot
- **Live preview**: See your changes in real-time as you configure your plot
- **Publication quality**: Colorblind-safe palettes and professional styling by default

### Export Options
- **Formats**: PNG, SVG, PDF, EPS
- **Configurable DPI**: High-resolution output for publications
- **Vector formats**: Scalable graphics for presentations and papers

### Advanced Features
- **Configuration files**: Expert users can use TOML files for reproducible workflows
- **Headless rendering**: Batch processing without the UI
- **Detailed error messages**: Clear, actionable feedback for data issues

---

## Installation

### From PyPI

```bash
pip install plottini
```

### From Source

```bash
git clone https://github.com/lanthoor/plottini.git
cd plottini
pip install -e .
```

---

## Quick Start

### Start the UI

```bash
plottini
```

This will start the web interface on `http://localhost:8050` and automatically open it in your browser.

### Command-Line Options

```bash
# Start on a specific port
plottini --port 8080

# Don't open browser automatically
plottini --no-open

# Load a configuration file
plottini --config my-graph.toml
```

### Expert Mode: Headless Rendering

For automation and batch processing:

```bash
plottini render --config my-graph.toml --output figure.png
```

---

## Usage

### 1. Load Your Data

- Click **"+ Add Files"** to load one or more TSV files
- Toggle **"Has header row"** if your files have column names
- Set comment characters (default: `#`)

### 2. Preview Your Data

- View a paginated table of your parsed data
- Verify that all values were correctly interpreted as numbers

### 3. Configure Series

- Select which columns to plot on X and Y axes
- Choose colors, line styles, and markers
- Apply transformations (log scale, square root, etc.)
- Use secondary Y-axis for different scales

### 4. Customize Plot Settings

- Select chart type
- Add title and axis labels
- Configure grid, legend, and figure size
- Adjust font sizes for publication

### 5. Advanced Options

- **Derived Columns**: Create new columns from expressions like `col1 / col2`
- **Filters**: Exclude data outside specified ranges
- **Multi-file Alignment**: Merge datasets by a common column
- **Layout**: Overlay series or create separate subplots

### 6. Export

- Choose format: PNG, SVG, PDF, or EPS
- Set DPI for raster formats
- Click **"Export"** to save your figure

---

## Configuration File Format

For reproducible workflows, you can create a TOML configuration file:

```toml
# my-graph.toml

[[files]]
path = "data/experiment1.tsv"
has_header = true
comment_chars = ["#"]

[[series]]
x = "time"
y = "velocity"
label = "Experiment 1"
color = "#0072B2"
transform_y = "log10"

[plot]
type = "line"
title = "Velocity over Time"
x_label = "Time (s)"
y_label = "Velocity (m/s)"
figure_width = 10.0
figure_height = 6.0

[export]
format = "png"
dpi = 300
```

Load it with:

```bash
plottini --config my-graph.toml
```

Or render directly:

```bash
plottini render --config my-graph.toml --output velocity.png
```

See [PLAN.md](PLAN.md) for the complete configuration specification.

---

## Supported Chart Types

| Category | Chart Types |
|----------|-------------|
| **Basic** | Line, Scatter, Bar (vertical/horizontal) |
| **Statistical** | Histogram, Box plot, Violin plot |
| **Area** | Area, Stacked area |
| **Specialized** | Stem, Step, Error bar, Pie, Polar |

---

## Mathematical Transformations

Available preset transformations:

- **Logarithmic**: log, log10, log2
- **Power**: square, cube, sqrt, cbrt
- **Trigonometric**: sin, cos, tan, arcsin, arccos, arctan
- **Other**: abs, inverse (1/x), exp, negate

**Derived Columns**: Create custom expressions like:
- `col1 / col2`
- `sqrt(col1**2 + col2**2)`
- `0.5 * mass * velocity**2`

---

## Requirements

- Python 3.10 or higher
- matplotlib ≥ 3.7
- numpy ≥ 1.24
- nicegui ≥ 1.4
- click ≥ 8.1

---

## Documentation

- **[PLAN.md](PLAN.md)** - Complete implementation plan and technical specifications
- **[CONTRIBUTING.md](CONTRIBUTING.md)** - Development setup and contribution guidelines
- **[AGENTS.md](AGENTS.md)** - Instructions for AI agents working on the project

---

## Contributing

Contributions are welcome! Please see [CONTRIBUTING.md](CONTRIBUTING.md) for:

- Development setup instructions
- Code style guidelines
- Testing requirements
- Pull request process

---

## Roadmap

See [PLAN.md](PLAN.md) for the detailed implementation plan.

### Current Status: Phase 1 - Core Foundation

- [x] Project structure
- [x] Package configuration
- [x] CLI framework
- [x] CI/CD pipelines
- [ ] TSV Parser implementation
- [ ] DataFrame implementation
- [ ] Basic plotting (Line, Bar, Pie)
- [ ] Export functionality
- [ ] UI implementation

---

## License

MIT License - see [LICENSE](LICENSE) file for details.

Copyright (c) 2025 Lallu Anthoor

---

## Support

- **Issues**: [GitHub Issues](https://github.com/lanthoor/plottini/issues)
- **Discussions**: [GitHub Discussions](https://github.com/lanthoor/plottini/discussions)
- **Author**: Lallu Anthoor (dev@spendly.co.in)

---

## Acknowledgments

Built with:
- [matplotlib](https://matplotlib.org/) - The plotting backend
- [NiceGUI](https://nicegui.io/) - The web UI framework
- [Click](https://click.palletsprojects.com/) - CLI framework
- [NumPy](https://numpy.org/) - Numerical computing

---

**Plottini** - Making publication-quality graphs accessible to everyone.
