JSON schemas and specifications for Rhylthyme programs and environments
Project description
Rhylthyme Specification (Alpha)
⚠️ ALPHA RELEASE - This specification is in early development and may change significantly before the first stable release.
Standards and schema for a real-time program logistics description markup language.
Version Information
- Current Version: 0.1.0a1 (Alpha)
- Schema Version: 0.1.0-alpha
- Status: Early development - breaking changes may occur
Overview
Rhylthyme is a JSON-based markup language for describing real-time programs that coordinate multiple parallel tracks of work with resource constraints, timing dependencies, and flexible execution patterns. It's designed for scenarios like restaurant kitchens, laboratory workflows, manufacturing processes, and any situation requiring coordinated real-time execution.
Alpha Release Notes
This alpha release includes:
- ✅ Basic program structure with tracks and steps
- ✅ Simplified "on" trigger syntax
- ✅ Resource constraints
- ✅ Variable and fixed duration types
- ✅ Batch processing with staggering
- 🔄 Environment integration (in progress)
- 🔄 Advanced validation rules (in progress)
- ❌ Resource specifications (planned)
- ❌ Environment schemas (planned)
Schema Structure
The Rhylthyme schema defines programs as JSON objects with the following key components:
Program-Level Properties
programId(required): Unique identifier for the programname(required): Human-readable namedescription: Detailed descriptionversion: Program version number (should match schema version)environmentType: Type of environment (e.g., 'kitchen', 'laboratory')actors: Number of available workers/operatorstracks(required): Array of parallel execution tracksresourceConstraints(required): Resource usage limitsstartTrigger: How the program begins execution
Example: Restaurant Breakfast Service
{
"programId": "restaurant-breakfast",
"name": "Restaurant Breakfast Service",
"description": "Professional restaurant breakfast service workflow with coordinated cooking and plating",
"version": "0.1.0-alpha",
"environmentType": "kitchen",
"actors": 2,
"startTrigger": {
"type": "manual"
},
"tracks": [
{
"trackId": "scrambled-eggs",
"name": "Scrambled Eggs",
"description": "Multiple orders of scrambled eggs",
"batch_size": 3,
"steps": [
{
"stepId": "eggs-crack-whisk",
"name": "Crack and Whisk Eggs",
"description": "Crack eggs into a bowl and whisk with salt and pepper",
"task": "prep-work",
"trigger": {
"type": "programStart"
},
"duration": {
"type": "fixed",
"seconds": 60
}
},
{
"stepId": "eggs-heat-pan",
"name": "Heat Pan",
"description": "Place pan on stove and heat to medium",
"trigger": {
"on": "eggs-crack-whisk"
},
"duration": {
"type": "variable",
"minSeconds": 60,
"maxSeconds": 120,
"defaultSeconds": 90,
"triggerName": "pan-ready"
},
"task": "stove-burner"
}
]
}
],
"resourceConstraints": [
{
"task": "stove-burner",
"maxConcurrent": 4,
"description": "Maximum number of stove burners that can be used simultaneously"
}
]
}
Track Structure
Tracks represent parallel workflows within a program. Each track can have multiple steps and can be executed multiple times (batch processing).
Track Properties
trackId(required): Unique identifiername(required): Human-readable namedescription: Detailed descriptionbatch_size: Number of iterations (default: 1)stagger: Time delay between batch instancespriority: Execution priority (lower = higher priority)steps(required): Array of sequential steps
Example: Bacon Cooking Track
{
"trackId": "bacon",
"name": "Bacon",
"description": "Multiple orders of bacon",
"batch_size": 2,
"steps": [
{
"stepId": "bacon-prep",
"name": "Prepare Bacon",
"description": "Place bacon strips in cold pan",
"task": "prep-work",
"trigger": {
"type": "programStart"
},
"duration": {
"type": "fixed",
"seconds": 60
}
},
{
"stepId": "bacon-cook",
"name": "Cook Bacon",
"description": "Cook bacon, flipping occasionally until crispy",
"trigger": {
"on": "bacon-prep"
},
"duration": {
"type": "variable",
"minSeconds": 480,
"maxSeconds": 720,
"defaultSeconds": 600,
"triggerName": "bacon-done"
},
"task": "stove-burner"
}
]
}
Step Structure
Steps are the individual work units within a track. They define what work is done, how long it takes, and when it starts.
Step Properties
stepId(required): Unique identifiername(required): Human-readable namedescription: Detailed descriptiontask: Resource/tool required for this steptrigger(required): When this step beginsduration(required): How long the step takesresources: Array of required resourcesflex: Whether this step can expand to fill available time
Trigger Types
1. Program Start
{
"type": "programStart"
}
Step begins immediately when the program starts.
2. On Another Step (Simplified Syntax)
{
"on": "eggs-crack-whisk"
}
Step begins when the specified step completes.
3. On Step with Offset
{
"on": "eggs-crack-whisk",
"offsetSeconds": 30
}
Step begins 30 seconds after the specified step completes.
4. On Step Start Event
{
"on": "eggs-crack-whisk",
"event": "start"
}
Step begins when the specified step starts (not when it completes).
5. Manual Trigger
{
"type": "manual",
"triggerName": "start-cooking"
}
Step begins when manually triggered.
Duration Types
1. Fixed Duration
{
"type": "fixed",
"seconds": 60
}
Step takes exactly 60 seconds.
2. Variable Duration
{
"type": "variable",
"minSeconds": 480,
"maxSeconds": 720,
"defaultSeconds": 600,
"triggerName": "bacon-done"
}
Step duration varies based on conditions, with manual completion trigger.
3. Time String Format
{
"type": "fixed",
"timeString": "2m30s"
}
Duration specified as a human-readable time string.
Resource Constraints
Resource constraints limit how many instances of a task can run simultaneously.
{
"resourceConstraints": [
{
"task": "stove-burner",
"maxConcurrent": 4,
"description": "Maximum number of stove burners that can be used simultaneously"
},
{
"task": "toaster",
"maxConcurrent": 2,
"description": "Maximum number of toasters that can be used simultaneously"
}
]
}
Advanced Features
Batch Processing with Staggering
{
"trackId": "toast",
"name": "Toast",
"description": "Multiple orders of toast",
"batch_size": 4,
"stagger": "30s",
"steps": [
{
"stepId": "toast-cook",
"name": "Make Toast",
"description": "Place bread in toaster and toast until golden brown",
"trigger": {
"type": "programStartOffset",
"offsetSeconds": 120
},
"duration": {
"type": "fixed",
"seconds": 210
},
"task": "toaster"
}
]
}
This creates 4 toast orders, each starting 30 seconds after the previous one.
Flexible Steps
{
"stepId": "wait-for-eggs",
"name": "Wait for Eggs",
"description": "Flexible waiting period while eggs cook",
"task": "waiting",
"trigger": {
"on": "eggs-start-cooking"
},
"duration": {
"type": "variable",
"minSeconds": 0,
"maxSeconds": 300,
"defaultSeconds": 180
},
"flex": true
}
Flexible steps can expand or contract to fill available time gaps.
Environment Integration
Programs can reference environment definitions that specify available resources and their capabilities.
{
"programId": "restaurant-breakfast",
"name": "Restaurant Breakfast Service",
"version": "0.1.0-alpha",
"environmentType": "kitchen",
"environment": "restaurant-standard.json"
}
Validation
The schema enforces:
- Required fields are present
- Step dependencies are valid
- Resource constraints are reasonable
- Duration values are positive
- Track and step IDs are unique within their scope
Usage Examples
Simple Sequential Workflow
{
"programId": "simple-cooking",
"name": "Simple Cooking",
"version": "0.1.0-alpha",
"tracks": [
{
"trackId": "main",
"name": "Main Track",
"steps": [
{
"stepId": "prep",
"name": "Preparation",
"task": "prep-work",
"trigger": {"type": "programStart"},
"duration": {"type": "fixed", "seconds": 60}
},
{
"stepId": "cook",
"name": "Cooking",
"task": "stove-burner",
"trigger": {"on": "prep"},
"duration": {"type": "fixed", "seconds": 300}
}
]
}
],
"resourceConstraints": [
{"task": "stove-burner", "maxConcurrent": 2}
]
}
Complex Parallel Workflow
{
"programId": "breakfast-service",
"name": "Breakfast Service",
"version": "0.1.0-alpha",
"actors": 3,
"tracks": [
{
"trackId": "eggs",
"name": "Eggs Station",
"batch_size": 5,
"stagger": "45s",
"steps": [
{
"stepId": "eggs-prep",
"name": "Prepare Eggs",
"task": "prep-work",
"trigger": {"type": "programStart"},
"duration": {"type": "fixed", "seconds": 30}
},
{
"stepId": "eggs-cook",
"name": "Cook Eggs",
"task": "stove-burner",
"trigger": {"on": "eggs-prep"},
"duration": {"type": "variable", "minSeconds": 120, "maxSeconds": 180, "defaultSeconds": 150}
}
]
},
{
"trackId": "bacon",
"name": "Bacon Station",
"batch_size": 3,
"stagger": "60s",
"steps": [
{
"stepId": "bacon-cook",
"name": "Cook Bacon",
"task": "stove-burner",
"trigger": {"type": "programStartOffset", "offsetSeconds": 30},
"duration": {"type": "fixed", "seconds": 600}
}
]
}
],
"resourceConstraints": [
{"task": "stove-burner", "maxConcurrent": 4},
{"task": "prep-work", "maxConcurrent": 2}
]
}
Advanced Trigger Examples
Cross-Track Dependencies
{
"stepId": "plate-breakfast",
"name": "Plate Breakfast",
"description": "Plate the complete breakfast when all components are ready",
"task": "plating",
"trigger": {
"on": "eggs-cook",
"on": "bacon-cook",
"on": "toast-cook"
},
"duration": {"type": "fixed", "seconds": 30}
}
Offset from Step Completion
{
"stepId": "serve-breakfast",
"name": "Serve Breakfast",
"description": "Serve the plated breakfast after a brief rest period",
"task": "service",
"trigger": {
"on": "plate-breakfast",
"offsetSeconds": 15
},
"duration": {"type": "fixed", "seconds": 20}
}
Step Start Event
{
"stepId": "preheat-oven",
"name": "Preheat Oven",
"description": "Start preheating when cooking begins",
"task": "oven",
"trigger": {
"on": "eggs-cook",
"event": "start"
},
"duration": {"type": "fixed", "seconds": 300}
}
Schema Files
schemas/program_schema_0.1.0-alpha.json- Main program schema (Alpha version)schemas/program_schema.json- Latest program schema (symlink to alpha version)schemas/environment_schema.json- Environment definitions (coming soon)schemas/resource_schema.json- Resource specifications (coming soon)
Migration Guide
From Pre-Alpha to Alpha (0.1.0a1)
-
Add version field to all programs:
{ "version": "0.1.0-alpha" }
-
Update trigger syntax (optional but recommended):
- Old:
{"type": "afterStep", "stepId": "step-id"} - New:
{"on": "step-id"}
- Old:
-
Schema validation now requires version field
Roadmap
Alpha Phase (Current)
- Basic program structure
- Simplified trigger syntax
- Resource constraints
- Environment schemas
- Advanced validation
Beta Phase (Planned)
- Resource specifications
- Template system
- Advanced planning algorithms
- Performance optimizations
1.0 Release (Planned)
- Stable API
- Complete documentation
- Migration tools
- Ecosystem tools
Contributing
This is an alpha release. We welcome feedback and contributions, but please note that breaking changes may occur. Please:
- Test thoroughly with your use cases
- Report issues with detailed examples
- Suggest improvements with concrete proposals
- Be prepared for schema changes
License
Apache License 2.0
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file rhylthyme_spec-0.1.0a0.tar.gz.
File metadata
- Download URL: rhylthyme_spec-0.1.0a0.tar.gz
- Upload date:
- Size: 17.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e80d125e12475d6e6e59c32df176c7564b50c7ecce52457f8a97d68e691b92bb
|
|
| MD5 |
e45d061b3746884c366dae108055194d
|
|
| BLAKE2b-256 |
fcafca8ec2ac47d988223589284d14eb8724291c023dcd33400fc8dd44eccd7e
|
File details
Details for the file rhylthyme_spec-0.1.0a0-py3-none-any.whl.
File metadata
- Download URL: rhylthyme_spec-0.1.0a0-py3-none-any.whl
- Upload date:
- Size: 15.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.9.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eca3351ec68d666e12b5288829c332562e44a6da45ebd1337c02d82d4e46116d
|
|
| MD5 |
8ac2a7ba6a51ce8f4b76c742328a0c54
|
|
| BLAKE2b-256 |
01ee0894943e7344f65963738666dc373b2d3b4b47ab654845b3e6f2eda67992
|