kececilayout 0.2.2__tar.gz → 0.2.4__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: kececilayout
3
- Version: 0.2.2
3
+ Version: 0.2.4
4
4
  Summary: A deterministic node placement algorithm used in graph visualization. In this layout, nodes are arranged sequentially along a defined primary axis. Each subsequent node is then alternately offset along a secondary, perpendicular axis, typically moving to one side of the primary axis and then the other. Often, the magnitude of this secondary offset increases as nodes progress along the primary axis, creating a characteristic zig-zag or serpentine pattern.
5
5
  Home-page: https://github.com/WhiteSymmetry/kececilayout
6
6
  Author: Mehmet Keçeci
@@ -41,8 +41,11 @@ Dynamic: summary
41
41
  [![PyPI version](https://badge.fury.io/py/kececilayout.svg)](https://badge.fury.io/py/kececilayout)
42
42
  [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
43
43
 
44
- [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15313947.svg)](https://doi.org/10.5281/zenodo.15313947)
44
+ [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15313946.svg)](https://doi.org/10.5281/zenodo.15313946)
45
45
  [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15314329.svg)](https://doi.org/10.5281/zenodo.15314329)
46
+ [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15353535.svg)](https://doi.org/10.5281/zenodo.15353535)
47
+
48
+ [![WorkflowHub DOI](https://img.shields.io/badge/DOI-10.48546%2Fworkflowhub.datafile.17.1-blue)](https://doi.org/10.48546/workflowhub.datafile.17.1)
46
49
 
47
50
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/version.svg)](https://anaconda.org/bilgi/kececilayout)
48
51
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/latest_release_date.svg)](https://anaconda.org/bilgi/kececilayout)
@@ -50,10 +53,59 @@ Dynamic: summary
50
53
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/license.svg)](https://anaconda.org/bilgi/kececilayout)
51
54
 
52
55
  [![Open Source](https://img.shields.io/badge/Open%20Source-Open%20Source-brightgreen.svg)](https://opensource.org/)
53
- [![Documentation Status](https://app.readthedocs.org/projects/kececilayout/badge/?0.2.1=main)](https://kececilayout.readthedocs.io/en/main/?badge=main)
56
+ [![Documentation Status](https://app.readthedocs.org/projects/kececilayout/badge/?0.2.3=main)](https://kececilayout.readthedocs.io/en/latest)
54
57
 
55
58
  [![OpenSSF Best Practices](https://www.bestpractices.dev/projects/10531/badge)](https://www.bestpractices.dev/projects/10531)
56
59
 
60
+ [![Python CI](https://github.com/WhiteSymmetry/kececilayout/actions/workflows/python_ci.yml/badge.svg?branch=main)](https://github.com/WhiteSymmetry/kececilayout/actions/workflows/python_ci.yml)
61
+ [![codecov](https://codecov.io/gh/WhiteSymmetry/kececilayout/graph/badge.svg?token=1SDH8E9RAJ)](https://codecov.io/gh/WhiteSymmetry/kececilayout)
62
+ [![Documentation Status](https://readthedocs.org/projects/kececilayout/badge/?version=latest)](https://kececilayout.readthedocs.io/en/latest/)
63
+ [![Binder](https://terrarium.evidencepub.io/badge_logo.svg)](https://terrarium.evidencepub.io/v2/gh/WhiteSymmetry/kececilayout/HEAD)
64
+ [![PyPI version](https://badge.fury.io/py/kececilayout.svg)](https://badge.fury.io/py/kececilayout)
65
+ [![PyPI Downloads](https://static.pepy.tech/badge/kececilayout)](https://pepy.tech/projects/kececilayout)
66
+ [![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-2.1-4baaaa.svg)](CODE_OF_CONDUCT.md)
67
+
68
+ ---
69
+
70
+ <p align="left">
71
+ <table>
72
+ <tr>
73
+ <td style="text-align: center;">PyPI</td>
74
+ <td style="text-align: center;">
75
+ <a href="https://pypi.org/project/kececilayout/">
76
+ <img src="https://badge.fury.io/py/kececilayout.svg" alt="PyPI version" height="18"/>
77
+ </a>
78
+ </td>
79
+ </tr>
80
+ <tr>
81
+ <td style="text-align: center;">Conda</td>
82
+ <td style="text-align: center;">
83
+ <a href="https://anaconda.org/bilgi/kececilayout">
84
+ <img src="https://anaconda.org/bilgi/kececilayout/badges/version.svg" alt="conda-forge version" height="18"/>
85
+ </a>
86
+ </td>
87
+ </tr>
88
+ <tr>
89
+ <td style="text-align: center;">DOI</td>
90
+ <td style="text-align: center;">
91
+ <a href="https://doi.org/10.5281/zenodo.15313946">
92
+ <img src="https://zenodo.org/badge/DOI/10.5281/zenodo.15313946.svg" alt="DOI" height="18"/>
93
+ </a>
94
+ </td>
95
+ </tr>
96
+ <tr>
97
+ <td style="text-align: center;">License: MIT</td>
98
+ <td style="text-align: center;">
99
+ <a href="https://opensource.org/licenses/MIT">
100
+ <img src="https://img.shields.io/badge/License-MIT-yellow.svg" alt="License" height="18"/>
101
+ </a>
102
+ </td>
103
+ </tr>
104
+ </table>
105
+ </p>
106
+
107
+ ---
108
+
57
109
  **Kececi Layout (Keçeci Yerleşimi)**: A deterministic graph layout algorithm designed for visualizing linear or sequential structures with a characteristic "zig-zag" or "serpentine" pattern.
58
110
 
59
111
  *Python implementation of the Keçeci layout algorithm for graph visualization.*
@@ -684,15 +736,15 @@ If this library was useful to you in your research, please cite us. Following th
684
736
  ### BibTeX
685
737
 
686
738
  ```bibtex
687
- @misc{kececi_2025_15313947,
739
+ @misc{kececi_2025_15313946,
688
740
  author = {Keçeci, Mehmet},
689
741
  title = {kececilayout},
690
742
  month = may,
691
743
  year = 2025,
692
744
  publisher = {PyPI, Anaconda, Github, Zenodo},
693
745
  version = {0.2.0},
694
- doi = {10.5281/zenodo.15313947},
695
- url = {https://doi.org/10.5281/zenodo.15313947},
746
+ doi = {10.5281/zenodo.15313946},
747
+ url = {https://doi.org/10.5281/zenodo.15313946},
696
748
  }
697
749
 
698
750
  @misc{kececi_2025_15314329,
@@ -709,15 +761,41 @@ If this library was useful to you in your research, please cite us. Following th
709
761
  ### APA
710
762
 
711
763
  ```
712
- Keçeci, M. (2025). kececilayout (0.2.0). PyPI, Anaconda, GitHub, Zenodo. https://doi.org/10.5281/zenodo.15313947
713
764
 
714
- Keçeci, M. (2025). Keçeci Layout. https://doi.org/10.5281/zenodo.15314329
765
+ Keçeci, M. (2025). Keçeci Deterministic Zigzag Layout. WorkflowHub. https://doi.org/10.48546/workflowhub.document.31.1
766
+
767
+ Keçeci, M. (2025). Keçeci Zigzag Layout Algorithm. Authorea. https://doi.org/10.22541/au.175087581.16524538/v1
768
+
769
+ Keçeci, M. (2025). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15792684
770
+
771
+ Keçeci, M. (2025). When Nodes Have an Order: The Keçeci Layout for Structured System Visualization. HAL open science. https://hal.science/hal-05143155; https://doi.org/10.13140/RG.2.2.19098.76484
772
+
773
+ Keçeci, M. (2025). The Keçeci Layout: A Cross-Disciplinary Graphical Framework for Structural Analysis of Ordered Systems. Authorea. https://doi.org/10.22541/au.175156702.26421899/v1
774
+
775
+ Keçeci, M. (2025). Beyond Traditional Diagrams: The Keçeci Layout for Structural Thinking. Knowledge Commons. https://doi.org/10.17613/v4w94-ak572
776
+
777
+ Keçeci, M. (2025). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. figshare. Journal contribution. https://doi.org/10.6084/m9.figshare.29468135
778
+
779
+ Keçeci, M. (2025, July 3). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. OSF. https://doi.org/10.17605/OSF.IO/9HTG3
780
+
781
+ Keçeci, M. (2025). Beyond Topology: Deterministic and Order-Preserving Graph Visualization with the Keçeci Layout. WorkflowHub. https://doi.org/10.48546/workflowhub.document.34.4
782
+
783
+ Keçeci, M. (2025). A Graph-Theoretic Perspective on the Keçeci Layout: Structuring Cross-Disciplinary Inquiry. Preprints. https://doi.org/10.20944/preprints202507.0589
784
+
785
+ Keçeci, M. (2025). Keçeci Layout. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15314328
786
+
787
+ Keçeci, M. (2025). kececilayout [Data set]. WorkflowHub. https://doi.org/10.48546/workflowhub.datafile.17.1
788
+
789
+ Keçeci, M. (2025, May 1). Kececilayout. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15313946
790
+
715
791
  ```
716
792
 
717
793
  ### Chicago
718
794
 
719
795
  ```
720
- Keçeci, Mehmet. “Kececilayout”. PyPI, Anaconda, GitHub, Zenodo, 01 May 2025. https://doi.org/10.5281/zenodo.15313947.
796
+ Keçeci, Mehmet. kececilayout [Data set]. WorkflowHub, 2025. https://doi.org/10.48546/workflowhub.datafile.17.1
797
+
798
+ Keçeci, Mehmet. "Kececilayout". Zenodo, 01 May 2025. https://doi.org/10.5281/zenodo.15313946.
721
799
 
722
- Keçeci, Mehmet. Keçeci Layout”, 01 May 2025. https://doi.org/10.5281/zenodo.15314329.
800
+ Keçeci, Mehmet. "Keçeci Layout", 01 May 2025. https://doi.org/10.5281/zenodo.15314329.
723
801
  ```
@@ -3,8 +3,11 @@
3
3
  [![PyPI version](https://badge.fury.io/py/kececilayout.svg)](https://badge.fury.io/py/kececilayout)
4
4
  [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
5
5
 
6
- [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15313947.svg)](https://doi.org/10.5281/zenodo.15313947)
6
+ [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15313946.svg)](https://doi.org/10.5281/zenodo.15313946)
7
7
  [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15314329.svg)](https://doi.org/10.5281/zenodo.15314329)
8
+ [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15353535.svg)](https://doi.org/10.5281/zenodo.15353535)
9
+
10
+ [![WorkflowHub DOI](https://img.shields.io/badge/DOI-10.48546%2Fworkflowhub.datafile.17.1-blue)](https://doi.org/10.48546/workflowhub.datafile.17.1)
8
11
 
9
12
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/version.svg)](https://anaconda.org/bilgi/kececilayout)
10
13
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/latest_release_date.svg)](https://anaconda.org/bilgi/kececilayout)
@@ -12,10 +15,59 @@
12
15
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/license.svg)](https://anaconda.org/bilgi/kececilayout)
13
16
 
14
17
  [![Open Source](https://img.shields.io/badge/Open%20Source-Open%20Source-brightgreen.svg)](https://opensource.org/)
15
- [![Documentation Status](https://app.readthedocs.org/projects/kececilayout/badge/?0.2.1=main)](https://kececilayout.readthedocs.io/en/main/?badge=main)
18
+ [![Documentation Status](https://app.readthedocs.org/projects/kececilayout/badge/?0.2.3=main)](https://kececilayout.readthedocs.io/en/latest)
16
19
 
17
20
  [![OpenSSF Best Practices](https://www.bestpractices.dev/projects/10531/badge)](https://www.bestpractices.dev/projects/10531)
18
21
 
22
+ [![Python CI](https://github.com/WhiteSymmetry/kececilayout/actions/workflows/python_ci.yml/badge.svg?branch=main)](https://github.com/WhiteSymmetry/kececilayout/actions/workflows/python_ci.yml)
23
+ [![codecov](https://codecov.io/gh/WhiteSymmetry/kececilayout/graph/badge.svg?token=1SDH8E9RAJ)](https://codecov.io/gh/WhiteSymmetry/kececilayout)
24
+ [![Documentation Status](https://readthedocs.org/projects/kececilayout/badge/?version=latest)](https://kececilayout.readthedocs.io/en/latest/)
25
+ [![Binder](https://terrarium.evidencepub.io/badge_logo.svg)](https://terrarium.evidencepub.io/v2/gh/WhiteSymmetry/kececilayout/HEAD)
26
+ [![PyPI version](https://badge.fury.io/py/kececilayout.svg)](https://badge.fury.io/py/kececilayout)
27
+ [![PyPI Downloads](https://static.pepy.tech/badge/kececilayout)](https://pepy.tech/projects/kececilayout)
28
+ [![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-2.1-4baaaa.svg)](CODE_OF_CONDUCT.md)
29
+
30
+ ---
31
+
32
+ <p align="left">
33
+ <table>
34
+ <tr>
35
+ <td style="text-align: center;">PyPI</td>
36
+ <td style="text-align: center;">
37
+ <a href="https://pypi.org/project/kececilayout/">
38
+ <img src="https://badge.fury.io/py/kececilayout.svg" alt="PyPI version" height="18"/>
39
+ </a>
40
+ </td>
41
+ </tr>
42
+ <tr>
43
+ <td style="text-align: center;">Conda</td>
44
+ <td style="text-align: center;">
45
+ <a href="https://anaconda.org/bilgi/kececilayout">
46
+ <img src="https://anaconda.org/bilgi/kececilayout/badges/version.svg" alt="conda-forge version" height="18"/>
47
+ </a>
48
+ </td>
49
+ </tr>
50
+ <tr>
51
+ <td style="text-align: center;">DOI</td>
52
+ <td style="text-align: center;">
53
+ <a href="https://doi.org/10.5281/zenodo.15313946">
54
+ <img src="https://zenodo.org/badge/DOI/10.5281/zenodo.15313946.svg" alt="DOI" height="18"/>
55
+ </a>
56
+ </td>
57
+ </tr>
58
+ <tr>
59
+ <td style="text-align: center;">License: MIT</td>
60
+ <td style="text-align: center;">
61
+ <a href="https://opensource.org/licenses/MIT">
62
+ <img src="https://img.shields.io/badge/License-MIT-yellow.svg" alt="License" height="18"/>
63
+ </a>
64
+ </td>
65
+ </tr>
66
+ </table>
67
+ </p>
68
+
69
+ ---
70
+
19
71
  **Kececi Layout (Keçeci Yerleşimi)**: A deterministic graph layout algorithm designed for visualizing linear or sequential structures with a characteristic "zig-zag" or "serpentine" pattern.
20
72
 
21
73
  *Python implementation of the Keçeci layout algorithm for graph visualization.*
@@ -646,15 +698,15 @@ If this library was useful to you in your research, please cite us. Following th
646
698
  ### BibTeX
647
699
 
648
700
  ```bibtex
649
- @misc{kececi_2025_15313947,
701
+ @misc{kececi_2025_15313946,
650
702
  author = {Keçeci, Mehmet},
651
703
  title = {kececilayout},
652
704
  month = may,
653
705
  year = 2025,
654
706
  publisher = {PyPI, Anaconda, Github, Zenodo},
655
707
  version = {0.2.0},
656
- doi = {10.5281/zenodo.15313947},
657
- url = {https://doi.org/10.5281/zenodo.15313947},
708
+ doi = {10.5281/zenodo.15313946},
709
+ url = {https://doi.org/10.5281/zenodo.15313946},
658
710
  }
659
711
 
660
712
  @misc{kececi_2025_15314329,
@@ -671,15 +723,41 @@ If this library was useful to you in your research, please cite us. Following th
671
723
  ### APA
672
724
 
673
725
  ```
674
- Keçeci, M. (2025). kececilayout (0.2.0). PyPI, Anaconda, GitHub, Zenodo. https://doi.org/10.5281/zenodo.15313947
675
726
 
676
- Keçeci, M. (2025). Keçeci Layout. https://doi.org/10.5281/zenodo.15314329
727
+ Keçeci, M. (2025). Keçeci Deterministic Zigzag Layout. WorkflowHub. https://doi.org/10.48546/workflowhub.document.31.1
728
+
729
+ Keçeci, M. (2025). Keçeci Zigzag Layout Algorithm. Authorea. https://doi.org/10.22541/au.175087581.16524538/v1
730
+
731
+ Keçeci, M. (2025). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15792684
732
+
733
+ Keçeci, M. (2025). When Nodes Have an Order: The Keçeci Layout for Structured System Visualization. HAL open science. https://hal.science/hal-05143155; https://doi.org/10.13140/RG.2.2.19098.76484
734
+
735
+ Keçeci, M. (2025). The Keçeci Layout: A Cross-Disciplinary Graphical Framework for Structural Analysis of Ordered Systems. Authorea. https://doi.org/10.22541/au.175156702.26421899/v1
736
+
737
+ Keçeci, M. (2025). Beyond Traditional Diagrams: The Keçeci Layout for Structural Thinking. Knowledge Commons. https://doi.org/10.17613/v4w94-ak572
738
+
739
+ Keçeci, M. (2025). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. figshare. Journal contribution. https://doi.org/10.6084/m9.figshare.29468135
740
+
741
+ Keçeci, M. (2025, July 3). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. OSF. https://doi.org/10.17605/OSF.IO/9HTG3
742
+
743
+ Keçeci, M. (2025). Beyond Topology: Deterministic and Order-Preserving Graph Visualization with the Keçeci Layout. WorkflowHub. https://doi.org/10.48546/workflowhub.document.34.4
744
+
745
+ Keçeci, M. (2025). A Graph-Theoretic Perspective on the Keçeci Layout: Structuring Cross-Disciplinary Inquiry. Preprints. https://doi.org/10.20944/preprints202507.0589
746
+
747
+ Keçeci, M. (2025). Keçeci Layout. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15314328
748
+
749
+ Keçeci, M. (2025). kececilayout [Data set]. WorkflowHub. https://doi.org/10.48546/workflowhub.datafile.17.1
750
+
751
+ Keçeci, M. (2025, May 1). Kececilayout. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15313946
752
+
677
753
  ```
678
754
 
679
755
  ### Chicago
680
756
 
681
757
  ```
682
- Keçeci, Mehmet. “Kececilayout”. PyPI, Anaconda, GitHub, Zenodo, 01 May 2025. https://doi.org/10.5281/zenodo.15313947.
758
+ Keçeci, Mehmet. kececilayout [Data set]. WorkflowHub, 2025. https://doi.org/10.48546/workflowhub.datafile.17.1
759
+
760
+ Keçeci, Mehmet. "Kececilayout". Zenodo, 01 May 2025. https://doi.org/10.5281/zenodo.15313946.
683
761
 
684
- Keçeci, Mehmet. Keçeci Layout”, 01 May 2025. https://doi.org/10.5281/zenodo.15314329.
762
+ Keçeci, Mehmet. "Keçeci Layout", 01 May 2025. https://doi.org/10.5281/zenodo.15314329.
685
763
  ```
@@ -1,4 +1,5 @@
1
1
  # kececilayout/kececi_layout.py
2
+
2
3
  import itertools # Graphillion için eklendi
3
4
  import numpy as np # rustworkx
4
5
  import math
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: kececilayout
3
- Version: 0.2.2
3
+ Version: 0.2.4
4
4
  Summary: A deterministic node placement algorithm used in graph visualization. In this layout, nodes are arranged sequentially along a defined primary axis. Each subsequent node is then alternately offset along a secondary, perpendicular axis, typically moving to one side of the primary axis and then the other. Often, the magnitude of this secondary offset increases as nodes progress along the primary axis, creating a characteristic zig-zag or serpentine pattern.
5
5
  Home-page: https://github.com/WhiteSymmetry/kececilayout
6
6
  Author: Mehmet Keçeci
@@ -41,8 +41,11 @@ Dynamic: summary
41
41
  [![PyPI version](https://badge.fury.io/py/kececilayout.svg)](https://badge.fury.io/py/kececilayout)
42
42
  [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
43
43
 
44
- [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15313947.svg)](https://doi.org/10.5281/zenodo.15313947)
44
+ [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15313946.svg)](https://doi.org/10.5281/zenodo.15313946)
45
45
  [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15314329.svg)](https://doi.org/10.5281/zenodo.15314329)
46
+ [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.15353535.svg)](https://doi.org/10.5281/zenodo.15353535)
47
+
48
+ [![WorkflowHub DOI](https://img.shields.io/badge/DOI-10.48546%2Fworkflowhub.datafile.17.1-blue)](https://doi.org/10.48546/workflowhub.datafile.17.1)
46
49
 
47
50
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/version.svg)](https://anaconda.org/bilgi/kececilayout)
48
51
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/latest_release_date.svg)](https://anaconda.org/bilgi/kececilayout)
@@ -50,10 +53,59 @@ Dynamic: summary
50
53
  [![Anaconda-Server Badge](https://anaconda.org/bilgi/kececilayout/badges/license.svg)](https://anaconda.org/bilgi/kececilayout)
51
54
 
52
55
  [![Open Source](https://img.shields.io/badge/Open%20Source-Open%20Source-brightgreen.svg)](https://opensource.org/)
53
- [![Documentation Status](https://app.readthedocs.org/projects/kececilayout/badge/?0.2.1=main)](https://kececilayout.readthedocs.io/en/main/?badge=main)
56
+ [![Documentation Status](https://app.readthedocs.org/projects/kececilayout/badge/?0.2.3=main)](https://kececilayout.readthedocs.io/en/latest)
54
57
 
55
58
  [![OpenSSF Best Practices](https://www.bestpractices.dev/projects/10531/badge)](https://www.bestpractices.dev/projects/10531)
56
59
 
60
+ [![Python CI](https://github.com/WhiteSymmetry/kececilayout/actions/workflows/python_ci.yml/badge.svg?branch=main)](https://github.com/WhiteSymmetry/kececilayout/actions/workflows/python_ci.yml)
61
+ [![codecov](https://codecov.io/gh/WhiteSymmetry/kececilayout/graph/badge.svg?token=1SDH8E9RAJ)](https://codecov.io/gh/WhiteSymmetry/kececilayout)
62
+ [![Documentation Status](https://readthedocs.org/projects/kececilayout/badge/?version=latest)](https://kececilayout.readthedocs.io/en/latest/)
63
+ [![Binder](https://terrarium.evidencepub.io/badge_logo.svg)](https://terrarium.evidencepub.io/v2/gh/WhiteSymmetry/kececilayout/HEAD)
64
+ [![PyPI version](https://badge.fury.io/py/kececilayout.svg)](https://badge.fury.io/py/kececilayout)
65
+ [![PyPI Downloads](https://static.pepy.tech/badge/kececilayout)](https://pepy.tech/projects/kececilayout)
66
+ [![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-2.1-4baaaa.svg)](CODE_OF_CONDUCT.md)
67
+
68
+ ---
69
+
70
+ <p align="left">
71
+ <table>
72
+ <tr>
73
+ <td style="text-align: center;">PyPI</td>
74
+ <td style="text-align: center;">
75
+ <a href="https://pypi.org/project/kececilayout/">
76
+ <img src="https://badge.fury.io/py/kececilayout.svg" alt="PyPI version" height="18"/>
77
+ </a>
78
+ </td>
79
+ </tr>
80
+ <tr>
81
+ <td style="text-align: center;">Conda</td>
82
+ <td style="text-align: center;">
83
+ <a href="https://anaconda.org/bilgi/kececilayout">
84
+ <img src="https://anaconda.org/bilgi/kececilayout/badges/version.svg" alt="conda-forge version" height="18"/>
85
+ </a>
86
+ </td>
87
+ </tr>
88
+ <tr>
89
+ <td style="text-align: center;">DOI</td>
90
+ <td style="text-align: center;">
91
+ <a href="https://doi.org/10.5281/zenodo.15313946">
92
+ <img src="https://zenodo.org/badge/DOI/10.5281/zenodo.15313946.svg" alt="DOI" height="18"/>
93
+ </a>
94
+ </td>
95
+ </tr>
96
+ <tr>
97
+ <td style="text-align: center;">License: MIT</td>
98
+ <td style="text-align: center;">
99
+ <a href="https://opensource.org/licenses/MIT">
100
+ <img src="https://img.shields.io/badge/License-MIT-yellow.svg" alt="License" height="18"/>
101
+ </a>
102
+ </td>
103
+ </tr>
104
+ </table>
105
+ </p>
106
+
107
+ ---
108
+
57
109
  **Kececi Layout (Keçeci Yerleşimi)**: A deterministic graph layout algorithm designed for visualizing linear or sequential structures with a characteristic "zig-zag" or "serpentine" pattern.
58
110
 
59
111
  *Python implementation of the Keçeci layout algorithm for graph visualization.*
@@ -684,15 +736,15 @@ If this library was useful to you in your research, please cite us. Following th
684
736
  ### BibTeX
685
737
 
686
738
  ```bibtex
687
- @misc{kececi_2025_15313947,
739
+ @misc{kececi_2025_15313946,
688
740
  author = {Keçeci, Mehmet},
689
741
  title = {kececilayout},
690
742
  month = may,
691
743
  year = 2025,
692
744
  publisher = {PyPI, Anaconda, Github, Zenodo},
693
745
  version = {0.2.0},
694
- doi = {10.5281/zenodo.15313947},
695
- url = {https://doi.org/10.5281/zenodo.15313947},
746
+ doi = {10.5281/zenodo.15313946},
747
+ url = {https://doi.org/10.5281/zenodo.15313946},
696
748
  }
697
749
 
698
750
  @misc{kececi_2025_15314329,
@@ -709,15 +761,41 @@ If this library was useful to you in your research, please cite us. Following th
709
761
  ### APA
710
762
 
711
763
  ```
712
- Keçeci, M. (2025). kececilayout (0.2.0). PyPI, Anaconda, GitHub, Zenodo. https://doi.org/10.5281/zenodo.15313947
713
764
 
714
- Keçeci, M. (2025). Keçeci Layout. https://doi.org/10.5281/zenodo.15314329
765
+ Keçeci, M. (2025). Keçeci Deterministic Zigzag Layout. WorkflowHub. https://doi.org/10.48546/workflowhub.document.31.1
766
+
767
+ Keçeci, M. (2025). Keçeci Zigzag Layout Algorithm. Authorea. https://doi.org/10.22541/au.175087581.16524538/v1
768
+
769
+ Keçeci, M. (2025). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15792684
770
+
771
+ Keçeci, M. (2025). When Nodes Have an Order: The Keçeci Layout for Structured System Visualization. HAL open science. https://hal.science/hal-05143155; https://doi.org/10.13140/RG.2.2.19098.76484
772
+
773
+ Keçeci, M. (2025). The Keçeci Layout: A Cross-Disciplinary Graphical Framework for Structural Analysis of Ordered Systems. Authorea. https://doi.org/10.22541/au.175156702.26421899/v1
774
+
775
+ Keçeci, M. (2025). Beyond Traditional Diagrams: The Keçeci Layout for Structural Thinking. Knowledge Commons. https://doi.org/10.17613/v4w94-ak572
776
+
777
+ Keçeci, M. (2025). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. figshare. Journal contribution. https://doi.org/10.6084/m9.figshare.29468135
778
+
779
+ Keçeci, M. (2025, July 3). The Keçeci Layout: A Structural Approach for Interdisciplinary Scientific Analysis. OSF. https://doi.org/10.17605/OSF.IO/9HTG3
780
+
781
+ Keçeci, M. (2025). Beyond Topology: Deterministic and Order-Preserving Graph Visualization with the Keçeci Layout. WorkflowHub. https://doi.org/10.48546/workflowhub.document.34.4
782
+
783
+ Keçeci, M. (2025). A Graph-Theoretic Perspective on the Keçeci Layout: Structuring Cross-Disciplinary Inquiry. Preprints. https://doi.org/10.20944/preprints202507.0589
784
+
785
+ Keçeci, M. (2025). Keçeci Layout. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15314328
786
+
787
+ Keçeci, M. (2025). kececilayout [Data set]. WorkflowHub. https://doi.org/10.48546/workflowhub.datafile.17.1
788
+
789
+ Keçeci, M. (2025, May 1). Kececilayout. Open Science Articles (OSAs), Zenodo. https://doi.org/10.5281/zenodo.15313946
790
+
715
791
  ```
716
792
 
717
793
  ### Chicago
718
794
 
719
795
  ```
720
- Keçeci, Mehmet. “Kececilayout”. PyPI, Anaconda, GitHub, Zenodo, 01 May 2025. https://doi.org/10.5281/zenodo.15313947.
796
+ Keçeci, Mehmet. kececilayout [Data set]. WorkflowHub, 2025. https://doi.org/10.48546/workflowhub.datafile.17.1
797
+
798
+ Keçeci, Mehmet. "Kececilayout". Zenodo, 01 May 2025. https://doi.org/10.5281/zenodo.15313946.
721
799
 
722
- Keçeci, Mehmet. Keçeci Layout”, 01 May 2025. https://doi.org/10.5281/zenodo.15314329.
800
+ Keçeci, Mehmet. "Keçeci Layout", 01 May 2025. https://doi.org/10.5281/zenodo.15314329.
723
801
  ```
@@ -2,7 +2,7 @@ from setuptools import setup, find_packages
2
2
 
3
3
  setup(
4
4
  name="kececilayout",
5
- version="0.2.2",
5
+ version="0.2.4",
6
6
  description="A deterministic node placement algorithm used in graph visualization. In this layout, nodes are arranged sequentially along a defined primary axis. Each subsequent node is then alternately offset along a secondary, perpendicular axis, typically moving to one side of the primary axis and then the other. Often, the magnitude of this secondary offset increases as nodes progress along the primary axis, creating a characteristic zig-zag or serpentine pattern.",
7
7
  long_description=open("README.md").read(),
8
8
  long_description_content_type="text/markdown",
@@ -0,0 +1,17 @@
1
+ def test_placeholder():
2
+ assert True
3
+
4
+ def add_numbers(a, b):
5
+ return a + b
6
+
7
+ def test_add_numbers():
8
+ result = add_numbers(2, 3)
9
+ assert result == 5, f"Expected 5, but got {result}"
10
+
11
+ result2 = add_numbers(-1, 4)
12
+ assert result2 == 3, f"Expected 3, but got {result2}"
13
+
14
+ result3 = add_numbers(0, 0)
15
+ assert result3 == 0, f"Expected 0, but got {result3}"
16
+
17
+ test_add_numbers()
@@ -1,2 +0,0 @@
1
- def test_placeholder():
2
- assert True
File without changes
File without changes
File without changes