Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/cgbur/pc

Difference calculations for the terminal
https://github.com/cgbur/pc

calculator command-line-tool percent-change percentage productivity-tools statistics terminal tools zig

Last synced: 4 months ago
JSON representation

Difference calculations for the terminal

Awesome Lists containing this project

README

        


Usage Example

# `pc` - Change Calculator for the Terminal

`pc` is a lightweight, blazing-fast tool that simplifies both the calculation
and the understanding of differences between numbers. It allows you to quickly
evaluate performance changes and offers meaningful human-formatted output, all
within the convenience of your terminal.

## ✨ Features

- 🔥 **Fashionable Output:** Human readable, colorful, and easy to understand
- 🎯 **Always Accurate:** Calculates percent change correctly every time
- 🚀 **Blazing Fast:** Don't wait, get your results instantly
- ❤️ **Zig-Powered:** Crafted with love using Zig

## 🛠️ Usage

### 💻 Basic Calculation

Compute percentage changes and differences effortlessly:

```sh
❯ pc 18024 19503 11124 12321 340200 424212 1000000000
↑ 8.21% 1.08x [ 17.60KiB → 19.05KiB ]
↓ -43.0% 0.57x [ 19.0KiB → 10.9KiB ]
↑ 10.8% 1.11x [ 10.9KiB → 12.0KiB ]
↑ 2661% 27.6x [ 12KiB → 332KiB ]
↑ 24.7% 1.25x [ 332.2KiB → 414.3KiB ]
↑ 235631% 2357x [ 414KiB → 954MiB ]
```

### 🎓 Friendly Sizes by Default

Large numbers are automatically translated into familiar sizes like GiB, MiB, KiB:

```sh
❯ pc 1124122523 2421252122
↑ 115.4% 2.15x [ 1.0GiB → 2.3GiB ]
```

Need raw numbers? Use the `-r` option:

```sh
❯ pc 1124122523 2421252122 -r
↑ 115.4% 2.15x [ 1124122496 → 2421252096 ]
```

### 🔀 Flexibility with Delimiters

By default, `pc` tokenizes the input with the default delimiters (` \n\t\r,;:|`). Use
the `--delimiters` or `-d` option to specify additional delimiters:

```sh
❯ echo "15@20@3 6" | pc -d "@"
↑ 33.3% 1.33x [ 15 → 20 ]
↓ -85% 0.15x [ 20 → 3 ]
↑ 100% 2x [ 3 → 6 ]
```

### 📐 Fixed Calculation

Use the `--fixed` or `-f` flags to evaluate changes relative to a specific
reference point in your series. You can specify positive or negative indices to
choose the reference number.

Evaluate changes relative to the first number (default):

```sh
❯ pc 1 2 3 4 -f
↑ 100% 2x [ 1 → 2 ]
↑ 200% 3x [ 1 → 3 ]
↑ 300% 4x [ 1 → 4 ]
```

Or choose a different reference point (one-based):

```sh
❯ pc 1 2 3 4 -f 2
↓ -50% 0.50x [ 2 → 1 ]
↑ 50% 1.50x [ 2 → 3 ]
↑ 100% 2x [ 2 → 4 ]
```

Or index from the end of the series with negative numbers:

```sh
❯ pc 1 2 3 4 -f -1
↓ -75% 0.25x [ 4 → 1 ]
↓ -50% 0.50x [ 4 → 2 ]
↓ -25% 0.75x [ 4 → 3 ]
```

### 📄 Output Formats

Specify the output format with the `--format` option. Currently, `pc` supports
the following formats:

- Human-readable (default)
- JSON
- CSV

#### JSON Output

```sh
❯ pc 18024 19503 --format json | jq
[
{
"percent": 8.20572566986084,
"times": 1.082057237625122,
"prev": 18024,
"cur": 19503
}
]
```

#### CSV Output

```sh
❯ pc 18024 19503 --format csv
percent,times,prev,cur
8.20572566986084,1.082057237625122,18024,19503
```

For the full command list, simply run:

```sh
pc --help
```

## 📥 Installation

### Prebuilt Binaries Available

Find them on the [releases](https://github.com/cgbur/pc/releases) page.

#### Supported Releases

- Linux: `aarch64-linux-pc`, `riscv64-linux-pc`, `x86_64-linux-pc`
- macOS: `aarch64-macos-pc`
- Windows: `x86_64-windows-pc.exe`

#### Installation Example for Linux (x86_64)

```bash
wget -O pc https://github.com/cgbur/pc/releases/latest/download/x86_64-linux-pc
chmod +x pc
mv pc ~/.local/bin/pc
```

Replace the file name in the URL with the corresponding one for other Linux architectures.

### Build from Source

To build from source, you'll need [Zig](https://ziglang.org):

```sh
git clone https://github.com/cgbur/pc.git
cd pc
zig build -Doptimize=ReleaseSafe
cp zig-out/bin/pc ~/.local/bin/pc
```

## 📝 Future Plans

- \[ \] Think of more features to add