Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/engineerjoe440/selprotopy
Schweitzer Engineering Laboratories (SEL) Protocol Bindings in Python
https://github.com/engineerjoe440/selprotopy
protocol protocol-bindings protocol-library protocol-parser protocols schweitzer-engineering-laboratories sel-protocol
Last synced: 2 months ago
JSON representation
Schweitzer Engineering Laboratories (SEL) Protocol Bindings in Python
- Host: GitHub
- URL: https://github.com/engineerjoe440/selprotopy
- Owner: engineerjoe440
- License: mit
- Created: 2020-09-19T16:57:03.000Z (over 4 years ago)
- Default Branch: develop
- Last Pushed: 2024-05-01T03:47:26.000Z (9 months ago)
- Last Synced: 2024-08-09T05:52:25.316Z (6 months ago)
- Topics: protocol, protocol-bindings, protocol-library, protocol-parser, protocols, schweitzer-engineering-laboratories, sel-protocol
- Language: Python
- Homepage: https://selprotopy.readthedocs.io/
- Size: 3.17 MB
- Stars: 16
- Watchers: 7
- Forks: 3
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SELProtoPy
Schweitzer Engineering Laboratories (SEL) Protocol Bindings in Python[![PyPI Version](https://img.shields.io/pypi/v/selprotopy.svg?color=blue&logo=pypi&logoColor=white)](https://pypi.org/project/selprotopy/)
[![Downloads](https://pepy.tech/badge/selprotopy)](https://pepy.tech/project/selprotopy)
[![Stars](https://img.shields.io/github/stars/engineerjoe440/selprotopy?logo=github)](https://github.com/engineerjoe440/selprotopy/)
[![License](https://img.shields.io/pypi/l/selprotopy.svg?color=blue)](https://github.com/engineerjoe440/selprotopy/blob/master/LICENSE.txt)[![pydocstyle](https://github.com/engineerjoe440/selprotopy/actions/workflows/pydocstyle.yml/badge.svg?branch=master)](https://github.com/engineerjoe440/selprotopy/actions/workflows/pydocstyle.yml)
[![pylint](https://github.com/engineerjoe440/selprotopy/actions/workflows/pylint.yml/badge.svg)](https://github.com/engineerjoe440/selprotopy/actions/workflows/pylint.yml)GitHub Pages (development documentation): https://engineerjoe440.github.io/selprotopy/
ReadTheDocs (production documentation): https://selprotopy.readthedocs.io/
***This project is still in early stages, much is still to come.***
## Description
`selprotopy` is intended to be used as a protocol binding suite for the SEL Protocol
suite which includes SEL Fast Meter, SEL Fast Message, and SEL Fast Operate; each of
which are proprietary protocols designed by
[Schweitzer Engineering Laboratories](https://selinc.com/) for use primarily with
protective electric relays, and other intelligent electronic devices.# ⚠️ Caution
***This project, although binding SEL Protocol, is not sponsored, tested, or vetted in any
way by Schweitzer Engineering Laboratories (SEL). This project is authored and maintained
as an open-source project. Testing is performed on a very small set of hardware running
in the author's basement. In short, this project has no association with SEL.****Since this project is not rigorously tested across all SEL devices or in a wide variety
of use-cases, any time this project is used, it should first be thoroughly tested. This
project is not intended to serve protection-class systems in any capacity. It should
primarily be used for research, exploration, and other learning objectives.*## :books: Protocol Documentation
SEL Protocol was introduced in the early 1990s to support various communications and
control of SEL protective relays. SEL provided a very supportive
[application guide](https://selinc.com/api/download/5026/?lang=en) which provides great
detail about the protocol's implementation. This application guide is a great resource
and thoroughly documents the core framework of SEL Protocol. This guide is the basis of
the bindings provided here. The guide can be accessed with a free account on the SEL
website: [](https://selinc.com/)## Installation
**From PyPI as a Python Package**
Just go ahead and issue: `pip install selprotopy`
**From Source on Github**
To install `selprotopy` from GitHub:
1. Download the repository as a zipped package.
2. Unzip the repository.
3. Open a terminal (command-prompt) and navigate to the new folder that's been unzipped.
(*Hint:* Use `cd /selprotopy`)
4. Use `pip` or `python` to install with the following commands, respectively:
- `$> pip install .`
- `$> python setup.py install`
5. Verify that it's been installed by opening a Python instance and importing:
`>>> import selprotopy` If no errors arise, the package has been installed.## Contributing
Want to get involved? We'd love to have your help!
Please help us by identifying any issues that you come across. If you find an error,
bug, or just have questions, jump over to the
[issue](https://github.com/engineerjoe440/selprotopy/issues) page.If you want to add features, or contribute yourself, feel free to open a pull-request.
### Contact Info
:information_source: *As mentioned in the
[caution](https://github.com/engineerjoe440/selprotopy#warning-caution) above, this
project is not associated with Schweitzer Engineering Laboratories (SEL) in any
way, and as such, all contacts for questions, support, or other items should be
directed to the resources listed here.*For issues found in the source code itself, please feel free to open an
[issue](https://github.com/engineerjoe440/selprotopy/issues), but for general inquiries
and other contact, feel free to address Joe Stanley, the project maintainer.- [[email protected]](mailto:[email protected])