Metadata-Version: 2.4
Name: pyudskit
Version: 0.2.0
Summary: Talk to your ECU in plain English — LLM-powered ISO 14229 UDS assistant
Project-URL: Homepage, https://github.com/sureshkonar/pyudskit
Project-URL: Documentation, https://pyudskit.readthedocs.io
Project-URL: Issues, https://github.com/sureshkonar/pyudskit/issues
License: MIT
Keywords: ai,automotive,can,diagnostics,ecu,iso14229,llm,uds
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Scientific/Engineering
Classifier: Topic :: Software Development :: Libraries
Requires-Python: >=3.10
Requires-Dist: anthropic>=0.25.0
Provides-Extra: can
Requires-Dist: python-can>=4.0; extra == 'can'
Provides-Extra: dev
Requires-Dist: black; extra == 'dev'
Requires-Dist: mypy; extra == 'dev'
Requires-Dist: pytest-mock; extra == 'dev'
Requires-Dist: pytest>=8.0; extra == 'dev'
Requires-Dist: ruff; extra == 'dev'
Provides-Extra: doip
Requires-Dist: doipy>=0.3; extra == 'doip'
Description-Content-Type: text/markdown

# pyudskit · Talk to your ECU in plain English

![PyPI](https://img.shields.io/pypi/v/pyudskit)
![Python](https://img.shields.io/pypi/pyversions/pyudskit)
![License](https://img.shields.io/badge/license-MIT-blue)
![Standard](https://img.shields.io/badge/standard-ISO%2014229-orange)

> LLM-powered ISO 14229 UDS assistant for automotive diagnostics.
> Encode, decode, and understand UDS messages using plain English.

---

## Table of Contents

- Overview
- Install
- Quick Start
- Architecture
- Methods at a Glance (UDS + AI)
- Offline Services (No LLM)
- AI Client (LLM)
- Examples
- API Reference
- License
- Links

---

## Overview

pyudskit is a production‑quality Python library that wraps the full ISO 14229 UDS protocol and exposes it through plain‑English prompts and structured helpers. It is designed for beginners who want one‑liners and for advanced engineers who need full control over bytes, sessions, and diagnostic flows.

---

## Install

```python
pip install pyudskit
```

```python
export ANTHROPIC_API_KEY="sk-ant-..."
```

---

## Quick Start

```python
from pyudskit import UDS

uds = UDS()

# Ask a plain-English question
print(uds.ask("What is UDS?"))

# Encode a request
print(uds.encode("Read the VIN"))  # 22 F1 90

# Decode a response
print(uds.decode("62 F1 90 57 30 4C 41 53 54 31 32 33 34 35 36 37 38"))

# Explain a DTC
print(uds.explain_dtc("P0301"))
```

---

## Architecture

```mermaid
flowchart LR
    A[Plain-English Request] --> B[LLM Prompting]
    B --> C[UDS Bytes]
    C --> D[ECU]
    D --> E[UDS Response]
    E --> F[Decode + Explain]
```

```mermaid
pie title UDS Services by Group
    "Session Management" : 11
    "Data Transmission" : 7
    "DTC Management" : 2
    "I/O Control" : 1
    "Routine Control" : 1
    "Upload/Download" : 5
```

---

## Methods at a Glance (UDS + AI)

### UDS Client (Beginner)

- `ask(question)`
- `encode(description)`
- `decode(hex_bytes)`
- `explain_dtc(dtc_code)`
- `explain_service(service)`
- `explain_session(session)`
- `explain_nrc(nrc)`
- `decode_dtc_status(status_byte)`
- `lookup_did(did)`
- `help()`

### UDS Client (Advanced)

- `encode_request(description)`
- `decode_response(hex_bytes)`
- `read_did(did)`
- `read_dids(dids)`
- `write_did(did, data_hex)`
- `read_memory(address, length, addr_len=4, size_len=1)`
- `write_memory(address, data_hex, addr_len=4)`
- `read_scaling_did(did)`
- `define_dynamic_did(dynamic_did, source_dids)`
- `clear_dynamic_did(dynamic_did)`
- `read_dtcs(status_mask=0x08)`
- `read_dtc_snapshot(dtc_hex, record_num=0xFF)`
- `read_dtc_extended(dtc_hex, record_num=0xFF)`
- `read_supported_dtcs()`
- `clear_dtcs(group="all")`
- `ecu_reset(reset_type="hard")`
- `tester_present(suppress=True)`
- `communication_control(action="disable")`
- `control_dtc_setting(setting="off")`
- `io_control(did, option, value_hex="")`
- `routine_control(routine_id, action="start", data_hex="")`
- `request_download(address, size, compression=0, encrypting=0)`
- `request_upload(address, size)`
- `transfer_data(block_seq, data_hex)`
- `request_transfer_exit()`
- `request_file_transfer(mode, file_path)`
- `security_access_seed(level=1)`
- `security_access_key(level=1, key_hex="")`
- `switch_session(session="extended")`
- `security_access_flow(level=1)`
- `programming_flow()`
- `dtc_reading_flow()`
- `io_control_flow(did)`
- `eol_flow()`
- `ota_update_flow()`
- `list_services(group=None)`
- `list_dids()`
- `list_nrcs()`
- `list_routines()`
- `lookup_nrc(nrc_byte)`
- `lookup_service(sid)`
- `clear_session()`
- `ecu_state` (property)

### AI Client (LLM)

- `encode(description)`
- `decode(hex_bytes)`
- `explain_service_result(service, result)`
- `verify_service_result(service, result)`
- `explain_response(service, response_hex)`
- `explain_dtc(dtc_code)`
- `explain_dtc_status(dtc_code, status_byte)`
- `explain_service(service_name_or_sid)`
- `explain_nrc(nrc)`
- `explain_session(session)`
- `get_flow(flow_name)`
- `analyze(hex_bytes)`
- `compare(expected_hex, actual_hex)`
- `suggest_next_step(last_request, last_response)`
- `chat(message)`
- `clear_history()`
- `reset()`

---

## Offline Services (No LLM)

Each service class supports `build_request`, `parse_response`, and `validate`.

### Session Management

- `DiagnosticSessionControl`
- `ECUReset`
- `SecurityAccess`
- `CommunicationControl`
- `Authentication`
- `TesterPresent`
- `AccessTimingParameter`
- `SecuredDataTransmission`
- `ControlDTCSetting`
- `ResponseOnEvent`
- `LinkControl`

### Data Transmission

- `ReadDataByIdentifier`
- `ReadMemoryByAddress`
- `ReadScalingDataByIdentifier`
- `ReadDataByPeriodicIdentifier`
- `DynamicallyDefineDataIdentifier`
- `WriteDataByIdentifier`
- `WriteMemoryByAddress`

### DTC Management

- `ClearDiagnosticInformation`
- `ReadDTCInformation`

### I/O Control

- `InputOutputControlByIdentifier`

### Routine Control

- `RoutineControl`

### Upload / Download

- `RequestDownload`
- `RequestUpload`
- `TransferData`
- `RequestTransferExit`
- `RequestFileTransfer`

---

## AI Client (LLM)

```python
from pyudskit.ai import AIClient
from pyudskit.services import ReadDataByIdentifier

ai = AIClient()
svc = ReadDataByIdentifier()
req = svc.build_request([0xF190])

print(ai.explain_service_result(svc, req))
print(ai.verify_service_result(svc, req))
print(ai.decode("7F 22 31"))
```

---

## Examples

### Workshop DTC Scan

```python
from pyudskit import UDS

uds = UDS()

result = uds.read_dtcs(0x08)
print(result["uds_bytes"])  # 19 02 08

for code in ["P0301", "U0100", "B0020"]:
    print(uds.explain_dtc(code))

print(uds.clear_dtcs())
```

### ECU Flash Programming

```python
from pyudskit import UDS

uds = UDS()

uds.switch_session("extended")
uds.communication_control("disable")
uds.control_dtc_setting("off")
uds.security_access_flow(level=1)
uds.switch_session("programming")
uds.routine_control(0xFF00, "start")
uds.request_download(0x08000000, 0x10000)
uds.transfer_data(0x01, "AA BB CC ...")
uds.request_transfer_exit()
uds.ecu_reset("hard")
```

---

## API Reference

https://pyudskit.readthedocs.io

---

## License

MIT

---

## Links

- Documentation: https://pyudskit.readthedocs.io
- Issues: https://github.com/sureshkonar/pyudskit/issues
- GitHub: https://github.com/sureshkonar/pyudskit
- PyPI: https://pypi.org/project/pyudskit
- Get Anthropic API Key: https://console.anthropic.com
