PHPackages                             runbiscuit/dijkstra - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. runbiscuit/dijkstra

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

runbiscuit/dijkstra
===================

A simple PHP implementation on Dijkstra's algorithm generated by ChatGPT

v1.1.1(4mo ago)08MITPHP

Since Dec 21Pushed 4mo agoCompare

[ Source](https://github.com/runbiscuit/php-dijkstra)[ Packagist](https://packagist.org/packages/runbiscuit/dijkstra)[ Docs](https://github.com/runbiscuit/dijkstra)[ RSS](/packages/runbiscuit-dijkstra/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (3)Dependencies (1)Versions (4)Used By (0)

Dijkstra PHP Implementation (forked)
====================================

[](#dijkstra-php-implementation-forked)

Forked from [diolan12/dijkstra](https://github.com/diolan12/dijkstra).

[![PHP Composer](https://github.com/diolan12/dijkstra/actions/workflows/php.yml/badge.svg)](https://github.com/diolan12/dijkstra/actions/workflows/php.yml)[![Downloads](https://camo.githubusercontent.com/5b2b98addfe68fcc9992bfe7971093225e1ed1b668bfcb44bdae26a0a8523878/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f64696f6c616e31322f64696a6b73747261)](https://packagist.org/packages/diolan12/dijkstra)[![Latest Stable Version](https://camo.githubusercontent.com/3c0ca47fd14a6ae0f1c1f486f5b16551ae32f90f630f5ff37471aca32e5a912a/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f64696f6c616e31322f64696a6b73747261)](https://packagist.org/packages/diolan12/dijkstra)[![License](https://camo.githubusercontent.com/a9b56099b32bb2db706ed973826049ea8caa60a435156222bde074ab4bdda931/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f6c2f64696f6c616e31322f64696a6b73747261)](LICENSE)

A simple PHP implementation for Dijkstra's algorithm

Generated by OpenAI ChatGPT [Mar 14 Version](https://help.openai.com/en/articles/6825453-chatgpt-release-notes)

See [Wikipedia](https://en.wikipedia.org/wiki/Dijkstra%27s_algorithm)

Installation
------------

[](#installation)

```
composer require diolan12/dijkstra

```

Usage
-----

[](#usage)

[![Dijkstra_Animation](graph.png)](graph.png)

### Using `addVertex` or `addEdge` method

[](#using-addvertex-or-addedge-method)

```
// Adding edge
$dijkstra->addEdge('D', 'B', 5)->addEdge('D', 'C', 6);
// Is equals to adding vertex
$dijkstra->addVertex('D', ['B' => 5, 'C' => 6]);
```

```
use Diolan12\Dijkstra;

$dijkstra = new \Diolan12\Dijkstra();
// or
$dijkstra = new Dijkstra();
// or
$dijkstra = Dijkstra::instance();

// Add vertices and edges
$dijkstra->addVertex('A', ['B' => 4, 'C' => 2]);
$dijkstra->addVertex('B', ['A' => 4, 'C' => 1, 'D' => 4]);
$dijkstra->addVertex('C', ['A' => 2, 'B' => 1, 'D' => 6]);
$dijkstra->addEdge('D', 'B', 4, true)->addEdge('D', 'C', 6, true);

$paths = $dijkstra->findShortestPath('A', 'D'); // [A, C, B, D]
```

### Using graph via class instantiation

[](#using-graph-via-class-instantiation)

Creating graph like this

```
$graph = [
    'A' => [
        'B' => 4,
        'C' => 2
    ],
    'B' => [
        'A' => 4,
        'C' => 1,
        'D' => 4
    ],
    'C' => [
        'A' => 2,
        'B' => 1,
        'D' => 6
    ],
    'D' => [
        'B' => 4,
        'C' => 6
    ]
];

$dijkstra = Dijkstra::instance($graph);
```

Is the same with this method

```
$dijkstra->addVertex('A', ['B' => 4, 'C' => 2]);
$dijkstra->addVertex('B', ['A' => 4, 'C' => 1, 'D' => 4]);
$dijkstra->addVertex('C', ['A' => 2, 'B' => 1, 'D' => 6]);
$dijkstra->addEdge('D', 'B', 4)->addEdge('D', 'C', 6);
```

Method `addVertex` vs `addEdge`
-------------------------------

[](#method-addvertex-vs-addedge)

`addVertex`: This method is used to add a vertex to the graph. A vertex represents a point or node in the graph. In the context of the Dijkstra algorithm, a vertex can be thought of as a location or node in a network. The addVertex method takes two parameters: the name of the vertex and an array of neighboring vertices (edges) with their corresponding edge weights. It adds the vertex and its associated edges to the graph.

`addEdge`: This method is used to add an edge between two vertices in the graph. An edge represents a connection or link between two vertices. In the context of the Dijkstra algorithm, an edge represents a cable route or path between two locations in a network. The addEdge method takes three parameters: the source vertex, the destination vertex, and the weight or cost of the edge. It establishes the connection between the source and destination vertices with the specified weight.

To summarize, addVertex is used to add a vertex with its neighboring edges to the graph, while addEdge is used to establish a connection (edge) between two vertices with a specified weight. Together, these methods allow you to build the graph representation required for the Dijkstra algorithm to find the shortest path between vertices in the network.

Method `findShortestPath`
-------------------------

[](#method-findshortestpath)

To make this library work in use cases where edges should be "taggable" and contain other metadata, the following methods have been modified:

`addEdge($src, $dest, $weight, ?string $tag = null, array $data = [], $reversible = false)`: Edges can contain a `tag` parameter and `data` parameter. `addVertex($name, $edges)`: Edges can be an array of arrays with the keys `tag`, `data` and `weight`, or just the `weight` value.

`findShortestPath($start, $end, $verbose = false)`: In order to receive the supplied data in our response, the `verbose` parameter has been added.

 `findShortestPath(start: 'A', end: 'D', verbose: true)` output:```
array(4) {
  ["cost"]=>
  int(7)
  ["edges"]=>
  array(3) {
    [0]=>
    array(3) {
      ["tag"]=>
      string(6) "A to C"
      ["data"]=>
      array(0) {
      }
      ["weight"]=>
      int(2)
    }
    [1]=>
    array(3) {
      ["tag"]=>
      string(6) "C to B"
      ["data"]=>
      array(0) {
      }
      ["weight"]=>
      int(1)
    }
    [2]=>
    array(3) {
      ["tag"]=>
      string(6) "B to D"
      ["data"]=>
      array(0) {
      }
      ["weight"]=>
      int(4)
    }
  }
  ["path"]=>
  array(4) {
    [0]=>
    string(1) "A"
    [1]=>
    string(1) "C"
    [2]=>
    string(1) "B"
    [3]=>
    string(1) "D"
  }
  ["merged"]=>
  array(7) {
    [0]=>
    string(1) "A"
    [1]=>
    array(3) {
      ["tag"]=>
      string(6) "A to C"
      ["data"]=>
      array(0) {
      }
      ["weight"]=>
      int(2)
    }
    [2]=>
    string(1) "C"
    [3]=>
    array(3) {
      ["tag"]=>
      string(6) "C to B"
      ["data"]=>
      array(0) {
      }
      ["weight"]=>
      int(1)
    }
    [4]=>
    string(1) "B"
    [5]=>
    array(3) {
      ["tag"]=>
      string(6) "B to D"
      ["data"]=>
      array(0) {
      }
      ["weight"]=>
      int(4)
    }
    [6]=>
    string(1) "D"
  }
}

```

Dev Test
--------

[](#dev-test)

```
./vendor/bin/phpunit tests

```

###  Health Score

33

—

LowBetter than 75% of packages

Maintenance78

Regular maintenance activity

Popularity4

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity37

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~11 days

Total

3

Last Release

122d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/e37f32b08389ca181d0ba35b3dbc9f8caf6a7c56990919744d35d3d24af8f84a?d=identicon)[biscuit.sh](/maintainers/biscuit.sh)

---

Top Contributors

[![diolan12](https://avatars.githubusercontent.com/u/24894631?v=4)](https://github.com/diolan12 "diolan12 (64 commits)")

---

Tags

phpAlgorithmdijkstraChatGptpathfinding

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/runbiscuit-dijkstra/health.svg)

```
[![Health](https://phpackages.com/badges/runbiscuit-dijkstra/health.svg)](https://phpackages.com/packages/runbiscuit-dijkstra)
```

###  Alternatives

[rubix/ml

A high-level machine learning and deep learning library for the PHP language.

2.2k1.4M28](/packages/rubix-ml)[fisharebest/algorithm

Implementation of standard algorithms in PHP.

7192.7k1](/packages/fisharebest-algorithm)[imanghafoori/laravel-anypass

A minimal yet powerful package to help you in development.

21421.6k](/packages/imanghafoori-laravel-anypass)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
