Features: - BMAD (Build Modular AI-driven Development) framework setup - BMM, BMB, CIS, Core modules configured - Story 1.1: Component trait with error handling - Workspace Cargo.toml with components crate - 31 tests passing (19 unit + 12 doc tests) Technical: - Component trait with compute_residuals, jacobian_entries, n_equations - ComponentError enum with thiserror - JacobianBuilder for sparse matrix construction - Object-safe trait supporting Box<dyn Component> - Comprehensive documentation and examples
548 lines
24 KiB
Markdown
548 lines
24 KiB
Markdown
---
|
||
stepsCompleted:
|
||
- step-01-init
|
||
- step-02-discovery
|
||
- step-03-success
|
||
- step-04-journeys
|
||
- step-05-domain
|
||
- step-06-innovation
|
||
- step-07-project-type
|
||
- step-08-scoping
|
||
- step-09-functional
|
||
- step-10-nonfunctional
|
||
- step-11-polish
|
||
- step-12-complete
|
||
inputDocuments:
|
||
- /Users/sepehr/dev/Entropyk/_bmad-output/planning-artifacts/product-brief-Entropyk-2026-02-12.md
|
||
documentCounts:
|
||
briefCount: 1
|
||
researchCount: 0
|
||
brainstormingCount: 0
|
||
projectDocsCount: 0
|
||
classification:
|
||
projectType: developer_tool
|
||
domain: scientific
|
||
complexity: high
|
||
projectContext: greenfield
|
||
workflowType: prd
|
||
---
|
||
|
||
# Product Requirements Document - RustThermoCycle
|
||
|
||
**Project:** Entropyk
|
||
**Author:** Sepehr
|
||
**Date:** 2026-02-12
|
||
**Status:** ✅ Complete
|
||
|
||
---
|
||
|
||
## Executive Summary
|
||
|
||
RustThermoCycle est une librairie de simulation thermodynamique haute-performance écrite en Rust. Elle vise à remplacer les outils Python existants (tespy, CoolProp) en offrant une **performance 100x supérieure** et une **robustesse garantie** grâce à une architecture solver-agnostique avec fallback intelligent.
|
||
|
||
**Différenciateur clé :** Première librairie thermodynamique industrielle offrant des garanties temporelles strictes (< 1s convergence), permettant le Hardware-in-the-Loop (HIL) impossible avec Python.
|
||
|
||
---
|
||
|
||
## Success Criteria
|
||
|
||
### User Success
|
||
|
||
**Le "Moment Magique" - Instantanéité Perçue :**
|
||
- L'utilisateur modifie un paramètre (ex: Température extérieure) et le résultat s'affiche instantanément sans spinner de chargement
|
||
- **Hard Constraint** : Temps de convergence Steady State < **1 seconde** même en "Cold Start"
|
||
- Pour les développeurs d'interface : Sliders réactifs sans latence perceptible
|
||
|
||
### Business Success
|
||
|
||
**Différenciation Hardware-in-the-Loop (HIL) :**
|
||
- Permettre la simulation en temps réel sur banc de test
|
||
- Fréquence de simulation > **1 Hz** (aussi rapide que le contrôleur physique)
|
||
- **Impossible avec Python** - avantage compétitif clair
|
||
|
||
### Technical Success
|
||
|
||
**Performance Hard Real-Time :**
|
||
|
||
| Métrique | Cible |
|
||
|----------|-------|
|
||
| Cycle simple (Mono-étagé) | **< 100 ms** |
|
||
| Cycle complexe (Multi-circuits) | **< 1 s** |
|
||
| Optimisation locale (Inverse Control) | **< 1 s** |
|
||
| Carte 3600 points (1h simulée) | **< 3 s totales** |
|
||
|
||
**Robustesse sous Contrainte de Temps :**
|
||
- Timeout strict ou Max Iterations obligatoire
|
||
- Mieux vaut erreur "Non-Convergence" en 0.5s que recherche infinie
|
||
- Architecture : Newton-Raphson (convergence quadratique) avec fallback optimisé
|
||
|
||
---
|
||
|
||
## Product Scope
|
||
|
||
### MVP - Minimum Viable Product
|
||
|
||
**Scope Essentiel :**
|
||
- Compresseur, Condenseur, Détendeur, Évaporateur, Économiseur
|
||
- Support CoolProp pour fluides frigorigènes
|
||
- Topologie multi-circuits (N circuits indépendants)
|
||
- Gestion des états ON/OFF/BYPASS
|
||
- Solveur avec garantie < 1s (Newton-Raphson + fallback)
|
||
- Zero-Panic Policy (Result<T, ThermoError>)
|
||
- Pas d'allocation dynamique dans la boucle de résolution
|
||
|
||
### Growth Features (Post-MVP)
|
||
|
||
- WebAssembly compilation pour interfaces web
|
||
- API graphique/visualisation des cycles
|
||
- Composants additionnels (Pompe, Échangeur eau/eau, etc.)
|
||
- Support d'autres backends thermodynamiques (RefProp)
|
||
- Parallélisation multi-threading
|
||
|
||
### Vision (Future)
|
||
|
||
- Simulation transitoire (dynamique, pas juste steady-state)
|
||
- Intégration directe avec outils de contrôle (PLC, DDC)
|
||
- Bibliothèque de cycles pré-configurés (standards industriels)
|
||
- Interface graphique complète (drag & drop de composants)
|
||
|
||
---
|
||
|
||
## User Journeys
|
||
|
||
### Persona 1 : R&D Engineer - "Marie la Dimensionneuse"
|
||
|
||
**Situation :** Marie travaille chez un fabricant de pompes à chaleur. Elle doit optimiser un cycle à deux étages pour une nouvelle gamme. Avec tespy, son script Python met 3 heures pour 100 combinaisons. Elle doit livrer demain.
|
||
|
||
**Parcours :**
|
||
1. **Découverte :** Elle lit la documentation RustThermoCycle, remarque la promesse "< 1s"
|
||
2. **Première simulation :** Elle définit sa machine bi-circuit en Rust
|
||
3. **Optimisation :** Lance l'exploration paramétrique (3600 points)
|
||
4. **Climax :** Résultats en **< 3 secondes** - elle peut itérer en temps réel
|
||
5. **Résolution :** Livraison à temps, nouvelle capacité d'études paramétriques
|
||
|
||
**État émotionnel :** 😰 Stressée → 🤔 Intriguée → 😲 Étonnée → 🎉 Triomphante
|
||
|
||
### Persona 2 : Web Developer - "Charlie le Configurateur"
|
||
|
||
**Situation :** Charlie développe un configurateur web B2B. Il veut des sliders réactifs sans spinner.
|
||
|
||
**Parcours :**
|
||
1. **Setup :** Compile RustThermoCycle en WebAssembly
|
||
2. **Intégration :** Expose l'API via wasm-bindgen
|
||
3. **UI :** Crée composant React avec sliders
|
||
4. **Climax :** Déplace un slider → Recalcul en **< 100ms**, expérience fluide
|
||
5. **Résolution :** Configurateur supérieur aux concurrents, clients enchantés
|
||
|
||
**État émotionnel :** 🤔 Curieux → 🛠️ Concentré → ✨ Magique → 🚀 Confiant
|
||
|
||
### Persona 3 : Researcher - "Robert le Topologue"
|
||
|
||
**Situation :** Robert est doctorant. Cycle CO2 avec Éjecteur + sous-refroidisseur. EES = 200 équations manuelles. tespy diverge au point critique. Il est bloqué.
|
||
|
||
**Parcours :**
|
||
1. **Installation :** Découvre l'API Graphe RustThermoCycle
|
||
2. **Modélisation :** Instancie `Ejector`, `FlashTank`, `Compressor`, connecte avec `system.connect()`
|
||
3. **Debug :** Active mode "Verbose" pour voir les résidus
|
||
4. **Climax :** Newton-Raphson diverge → **Fallback auto** en Substitution Séquentielle → stabilisation → retour Newton → **Convergé en 450ms**
|
||
5. **Résolution :** Publie son papier avec code reproductible, bilan d'exergie validé auto
|
||
|
||
**État émotionnel :** 😤 Bloqué → 🤨 Dubitatif → 😮 Fasciné → 🎓 Accompli
|
||
|
||
### Persona 4 : HIL & Control Engineer - "Sarah du Banc d'Essai"
|
||
|
||
**Situation :** Sarah doit valider algorithme de dégivrage sur PLC réel. Besoin de "Jumeau Numérique" temps réel. Python trop lent (GC pauses).
|
||
|
||
**Parcours :**
|
||
1. **Setup :** Compile RustThermoCycle en `.dll` / `.so` avec FFI C
|
||
2. **Configuration :** Modèle reçoit ouverture vanne (Input), renvoie Pression (Output) toutes les 100ms
|
||
3. **Test :** Lancement banc d'essai
|
||
4. **Climax :** Calcul état thermodynamique en **12ms** (< 100ms limite), mémoire stable (Rust ownership), 48h sans interruption
|
||
5. **Résolution :** Validation avant prototype physique, économie 3 semaines chambre climatique
|
||
|
||
**État émotionnel :** ⏱️ Pressée → 🔧 Technique → 🎯 Précise → 💰 Victorieuse
|
||
|
||
### Persona 5 : Data Engineer - "David le Batch-Processor"
|
||
|
||
**Situation :** David génère des datasets massifs pour entraîner des modèles IA (Surrogate Models). Besoin de throughput maximal.
|
||
|
||
**Parcours :**
|
||
1. **Architecture :** Utilise RustThermoCycle via CLI
|
||
2. **Parallélisation :** Exploite `Send + Sync` pour utiliser 100% des cœurs CPU
|
||
3. **Exécution :** Batch de millions de scénarios
|
||
4. **Climax :** Throughput maximum, zero contention, résultats cohérents
|
||
5. **Résolution :** Dataset d'entraînement généré rapidement, modèle IA prêt
|
||
|
||
**État émotionnel :** 📊 Ambitieux → ⚡ Performant → 🧮 Satisfait
|
||
|
||
### Journey Requirements Summary
|
||
|
||
**Capacités révélées par les parcours :**
|
||
|
||
| Parcours | Capacités Critiques |
|
||
|----------|---------------------|
|
||
| **Marie (R&D)** | Multi-circuits, Optimisation paramétrique, Performance < 1s |
|
||
| **Charlie (Web)** | WebAssembly compilation, API exposable, Latence < 100ms |
|
||
| **Robert (Chercheur)** | API Graphe intuitive, Fallback solver auto, Debug verbose, Validation exergie |
|
||
| **Sarah (HIL)** | FFI C (`.dll`/`.so`), Temps réel < 100ms, Memory safety (48h+), Deterministe |
|
||
| **David (Batch)** | Thread-Safety (`Send + Sync`), CLI, Parallélisation multi-cœur |
|
||
|
||
**Pattern commun :** Le **Solver-agnostic avec fallback** et la **performance hard real-time** sont des différenciateurs transversaux essentiels.
|
||
|
||
---
|
||
|
||
## Domain-Specific Requirements
|
||
|
||
### Standards Industriels & Validation
|
||
|
||
**Composants Compressors (AHRI 540) :**
|
||
- Implémentation stricte du standard **AHRI 540** pour la modélisation des compresseurs
|
||
- Support des coefficients standardisés (10 coefficients) fournis par les fabricants (Bitzer, Copeland, Danfoss)
|
||
- Le code doit ingérer les polynômes de performance compressors au format industriel standard
|
||
|
||
**Propriétés Fluides (NIST/CoolProp) :**
|
||
- **Gold Standard :** NIST REFPROP
|
||
- **Open Source :** CoolProp référence
|
||
- **Exigence Performance :** Système capable de charger des tables de fluides (Tabular Interpolation) pour correspondre aux résultats NIST à **< 0.01%** près, tout en étant **100x plus rapide** que l'appel EOS direct
|
||
|
||
### Précision & Tolérances (Grade "Simulation Scientifique Critique")
|
||
|
||
| Type de Bilan | Tolérance |
|
||
|---------------|-----------|
|
||
| **Bilan de Masse** | Σ ṁ_in - Σ ṁ_out < **10⁻⁹ kg/s** (quasi-zéro machine) |
|
||
| **Bilan Énergétique** | Σ Q̇ + Ẇ - Σ (ṁ · h) < **10⁻⁶ kW** (1 milliwatt) |
|
||
| **Convergence Pression** | Résidu maximal : **1 Pa** (10⁻⁵ bar) |
|
||
|
||
*Note : La tolérance "bricolage" de 0.1% est inacceptable pour l'optimisation numérique (accumulation d'erreurs).*
|
||
|
||
### Traçabilité & Reproductibilité
|
||
|
||
Chaque résultat de simulation (`SimulationResult`) doit contenir un header de métadonnées :
|
||
- `solver_version` : Version du moteur Rust (ex: 0.1.0)
|
||
- `fluid_backend` : Version de la librairie fluide (ex: CoolProp 6.4.1)
|
||
- `input_hash` : Hash SHA-256 de la configuration d'entrée pour garantir la correspondance résultat/inputs
|
||
|
||
### Aspects Spécifiques au Domaine (Critical Pain Points)
|
||
|
||
#### A. Gestion du Point Critique (Critical Region)
|
||
- **Problème :** Pour le CO2 (R744), le cycle passe souvent au-dessus du point critique
|
||
- **Risque :** Les dérivées partielles (∂P/∂ρ) explosent (NaN) près du point critique
|
||
- **Solution :** Le solveur doit utiliser un "Damping" (amortissement) automatique dans cette zone
|
||
|
||
#### B. Glissement de Température (Temperature Glide)
|
||
- **Problème :** Pour les mélanges zeotropiques (R454B, R32/R125), la température change pendant l'évaporation à pression constante
|
||
- **Risque :** Calcul des échangeurs supposant T_sat = Constante (erreur significative)
|
||
- **Solution :** Le calcul doit intégrer le glissement (Bubble Point → Dew Point) sans approximation
|
||
|
||
---
|
||
|
||
## Innovation & Novel Patterns
|
||
|
||
### Detected Innovation Areas
|
||
|
||
#### Innovation #1 : Architecture Solver-Agnostic avec Fallback Intelligent ⭐
|
||
**Signal :** Newton-Raphson diverge → Fallback auto en Substitution Séquentielle → retour Newton → Convergé
|
||
**Innovation :** Aucun outil existant ne permet de switcher dynamiquement entre solveurs sans modifier le code modèle
|
||
**Impact :** Convergence garantie même dans les zones critiques (CO2 au point critique)
|
||
**Statut :** **Innovation Critique (Money Maker)** - La robustesse est le différenciateur commercial principal
|
||
|
||
#### Innovation #2 : Performance Hard Real-Time Garantie
|
||
**Signal :** < 1s Cold Start, < 100ms cycle simple, déterministe 12ms pour HIL
|
||
**Innovation :** Première librairie thermodynamique avec garanties temporelles strictes
|
||
**Impact :** Hardware-in-the-Loop possible (impossible avec Python/GC pauses)
|
||
|
||
#### Innovation #3 : Topologie Multi-Circuits avec Couplage Thermique
|
||
**Signal :** N circuits indépendants avec échangeurs thermiques entre circuits
|
||
**Innovation :** Graphe orienté multi-fluides dans un même modèle
|
||
**Impact :** Simulation native de machines complexes (pompes à chaleur double-circuit)
|
||
|
||
#### Innovation #4 : Zero-Panic + No-Allocation
|
||
**Signal :** Result<T, ThermoError>, pas d'allocation dynamique dans la boucle
|
||
**Innovation :** Garanties mémoire Rust appliquées au calcul scientifique
|
||
**Impact :** Certification possible, déploiement embarqué (48h+ sans fuite)
|
||
|
||
#### Innovation #5 : Native Inverse Control via Residual Embedding ⭐
|
||
**Signal :** "Calculer l'ouverture de vanne pour une surchauffe cible"
|
||
**Innovation :** Consigne de contrôle intégrée directement comme équation résiduelle dans la matrice système
|
||
**Différence :** Pas de boucle d'optimisation externe - la vanne devient une inconnue du système résolue simultanément
|
||
**Impact :** Simulation du comportement d'un régulateur PID parfait en "One-Shot", sans itérations externes
|
||
|
||
### Market Context & Competitive Landscape
|
||
|
||
| Solution | Limitation | Notre Avantage |
|
||
|----------|-----------|----------------|
|
||
| **tespy** | Python lent, solveur unique, divergence = crash | 100x plus rapide, fallback intelligent |
|
||
| **EES** | Équations manuelles, pas d'API graphe | API intuitive, modèle composant |
|
||
| **CoolProp** | Backend thermo uniquement, pas de solveur cycle | Intégration native, multi-circuits |
|
||
| **Commercial** | Solveur verrouillé, pas d'accès interne | Solver-agnostic, open source |
|
||
|
||
### Validation Approach
|
||
|
||
1. **Benchmark vs tespy/CoolProp** : Même cycle, mesurer speedup (objectif 100x)
|
||
2. **HIL Validation** : Connecter à PLC réel, mesurer latence (objectif < 20ms)
|
||
3. **Convergence Stress Test** : Cycles CO2 proches point critique
|
||
4. **Memory Safety Audit** : Valgrind + **Miri** (interpréteur MIR Rust) sur 48h
|
||
|
||
### Risk Mitigation
|
||
|
||
#### Si le solveur ne converge pas dans le budget temps (HIL) :
|
||
|
||
**Stratégie de Dégradation Gracieuse :**
|
||
|
||
1. **Time-Budgeted Solving :** Vérification horloge système à chaque itération, arrêt si `elapsed > max_time`
|
||
2. **Zero-Order Hold (ZOH) avec Flag :** Retour du résultat précédent avec `ComputationStatus::Timeout`
|
||
3. **Jacobian Freezing :** Option de ne pas recalculer la Jacobienne à chaque pas (gain 80% CPU, perte de précision minime acceptable en HIL)
|
||
|
||
**Cas Extrême :** Si Newton-Raphson + fallback ne converge pas dans 0.5s
|
||
- Retour immédiat avec status `NonConverged`
|
||
- Utilisation du dernier état stable connu
|
||
- Logging détaillé pour diagnostic post-mortem
|
||
|
||
---
|
||
|
||
## Developer Tool Specific Requirements
|
||
|
||
### Language Support & FFI Strategy
|
||
|
||
**Rust Native (Le Cœur) :**
|
||
- API pure et "Safe" pour les développeurs d'applications (Charlie)
|
||
- Focus sur l'ergonomie Rust (ownership, types, performance)
|
||
|
||
**Python Bindings via PyO3 & Maturin (Le "Cheval de Troie") :**
|
||
- Permettre à Alice de remplacer `import tespy` par `import rust_thermo_cycle` sans réécrire sa logique
|
||
- **Vecteur d'adoption #1** : "Gardez votre Python, mais allez 100x plus vite"
|
||
- Distribution : Wheels pré-compilées (manylinux) sur PyPI
|
||
|
||
**C FFI via cbindgen (Pour le HIL) :**
|
||
- Génération automatique des headers `.h` pour intégration C/C++
|
||
- PLC, LabView, Simulink compatibles
|
||
|
||
### Packaging & Distribution
|
||
|
||
| Canal | Méthode | Utilisateur |
|
||
|-------|---------|-------------|
|
||
| **Rust** | `crates.io` | Développeurs Rust |
|
||
| **Python** | `pip install rust-thermo-cycle` (Wheels PyPI) | Data Scientists, R&D |
|
||
| **C/C++** | Headers + Librairies dynamiques | Intégrateurs HIL |
|
||
| **Docker** | Image `rust-thermo-lab` (JupyterLab + Rust kernel + CoolProp) | Nouveaux utilisateurs |
|
||
|
||
### Documentation Strategy
|
||
|
||
**API Docs (rustdoc) :**
|
||
- Signatures de fonctions, traits, types
|
||
- Documentation inline avec exemples de code
|
||
|
||
**Physics Manual (mdBook) :**
|
||
- Explication des équations résolues (Peng-Robinson, etc.)
|
||
- Guide du physicien, pas juste du développeur
|
||
- Formules mathématiques avec MathJax
|
||
|
||
**ADR (Architecture Decision Records) :**
|
||
- Pourquoi Newton-Raphson vs Broyden ?
|
||
- Pourquoi CoolProp vs RefProp ?
|
||
- Pourquoi Graphe vs Équations ?
|
||
|
||
### Code Examples Prioritaires
|
||
|
||
1. **"Benchmark Demo" (Le Vendeur) :**
|
||
```
|
||
1000 simulations PAC simple
|
||
Temps total : 450ms
|
||
(Est. Python : 45s)
|
||
Speedup : 100x
|
||
```
|
||
|
||
2. **"Inverse Control" :**
|
||
- Définir `Superheat_Target = 5K`
|
||
- Laisser le solveur trouver l'ouverture de vanne
|
||
|
||
3. **"Hybrid PyO3" :**
|
||
- Python appelle Rust pour calcul lourd
|
||
- Matplotlib pour tracer diagramme P-h
|
||
|
||
### DevEx & Qualité
|
||
|
||
**CI/CD Pipeline (GitHub Actions) :**
|
||
- `cargo test` : Unit tests
|
||
- `cargo bench` : Performance regression
|
||
- `valgrind` : Memory leaks (FFI)
|
||
- `cargo clippy -- -D warnings` : Tolérance zéro sur le style
|
||
- `miri test` : Undefined behavior detection
|
||
|
||
**Qualité Code :**
|
||
- `#![deny(warnings)]` dans `lib.rs`
|
||
- 100% documentation publique
|
||
- Examples compilés et testés dans CI
|
||
|
||
---
|
||
|
||
## Project Scoping & Phased Development
|
||
|
||
### MVP Strategy & Philosophy
|
||
|
||
**MVP Approach :** Platform MVP
|
||
Le produit est utile uniquement si tous les éléments critiques fonctionnent ensemble : solveur robuste (fallback), performance garantie (< 1s), API ergonomique (Rust + Python).
|
||
|
||
### MVP Feature Set (Phase 1)
|
||
|
||
**Core User Journeys Supported :**
|
||
- Marie (R&D) : Optimisation paramétrique avec performance < 1s
|
||
- Robert (Chercheur) : Cycle complexe avec fallback solver
|
||
- Alice (Python) : Migration depuis tespy via PyO3
|
||
|
||
**Must-Have Capabilities :**
|
||
|
||
| Domaine | Features MVP |
|
||
|---------|-------------|
|
||
| **Composants** | Compresseur (AHRI 540), Condenseur, Détendeur, Évaporateur, Économiseur (Bypass support) |
|
||
| **Topologie** | Single circuit + Multi-circuits (2 max), Couplage thermique basique |
|
||
| **Solveur** | Newton-Raphson + Substitution Séquentielle (fallback), Timeout < 1s, Critère : Delta P < 1 Pa |
|
||
| **Bindings** | Rust native (crates.io), Python (PyO3 + PyPI) |
|
||
| **Validation** | Benchmark vs tespy (100x speedup), Test CO2 point critique |
|
||
|
||
### Post-MVP Features
|
||
|
||
**Phase 2 (Growth) :**
|
||
- FFI C pour HIL (Sarah)
|
||
- WebAssembly pour web (Charlie)
|
||
- Composants additionnels (Pompe, Échangeur eau/eau)
|
||
- Optimisation multi-cœurs (David)
|
||
|
||
**Phase 3 (Expansion) :**
|
||
- Simulation transitoire (dynamique, pas juste steady-state)
|
||
- Bibliothèque de cycles pré-configurés (standards industriels)
|
||
- Interface graphique web (drag & drop)
|
||
|
||
### Risk Mitigation Strategy
|
||
|
||
**Technical Risks :**
|
||
- CoolProp instable → Fallback sur tables tabulaires NIST
|
||
- Newton-Raphson diverge → Substitution Séquentielle auto
|
||
|
||
**Market Risks :**
|
||
- Migration Python difficile → API PyO3 identique à tespy
|
||
|
||
**Resource Risks :**
|
||
- 1 développeur → Scope strict, pas de transitoire en MVP
|
||
|
||
---
|
||
|
||
## Functional Requirements
|
||
|
||
### 1. Modélisation des Composants (Component Modeling)
|
||
|
||
- **FR1** : Le système peut modéliser un Compresseur selon la norme AHRI 540 avec coefficients du fabricant
|
||
- **FR2** : Le système peut modéliser un Condenseur avec transfert thermique calculé
|
||
- **FR3** : Le système peut modéliser un Détendeur (détente isenthalpique)
|
||
- **FR4** : Le système peut modéliser un Évaporateur avec changement de phase
|
||
- **FR5** : Le système peut modéliser un Économiseur (échangeur interne) avec mode Bypass
|
||
- **FR6** : Chaque composant peut être dans l'état OperationalState (On, Off, Bypass)
|
||
- **FR7** : En mode Off, un composant actif contribue un débit massique nul au système
|
||
- **FR8** : En mode Bypass, un composant se comporte comme un tuyau adiabatique (P_in = P_out, h_in = h_out)
|
||
|
||
### 2. Gestion de la Topologie (System Topology)
|
||
|
||
- **FR9** : L'utilisateur peut définir une Machine contenant N circuits fluidiques indépendants
|
||
- **FR10** : L'utilisateur peut connecter des composants via des Ports (entrée/sortie)
|
||
- **FR11** : Le système supporte les connexions entre circuits (couplage thermique)
|
||
- **FR12** : Le système peut résoudre les N circuits simultanément ou séquentiellement
|
||
- **FR13** : Le système gère mathématiquement les branches à débit nul sans division par zéro
|
||
|
||
### 3. Résolution du Système (Solver)
|
||
|
||
- **FR14** : Le système peut résoudre les équations par méthode Newton-Raphson
|
||
- **FR15** : Le système peut résoudre les équations par Substitution Séquentielle (Picard)
|
||
- **FR16** : Le solveur bascule automatiquement en Substitution Séquentielle si Newton-Raphson diverge
|
||
- **FR17** : Le solveur respecte un budget temps configurable (timeout)
|
||
- **FR18** : En cas de timeout, le solveur retourne le meilleur état connu avec statut NonConverged
|
||
- **FR19** : Le solveur peut geler le calcul de la Jacobienne pour accélérer (Jacobian Freezing)
|
||
- **FR20** : Le critère de convergence vérifie Delta Pression < 1 Pa (1e-5 bar)
|
||
- **FR21** : Pour multi-circuits, la convergence globale est atteinte quand TOUS les circuits convergent
|
||
- **FR42** : Le système inclut une heuristique d'Initialisation Automatique (Smart Guesser) proposant des valeurs de pression initiales cohérentes basées sur les températures sources/puits
|
||
|
||
### 4. Inverse Control (Régulation)
|
||
|
||
- **FR22** : L'utilisateur peut définir des contraintes de sortie (ex: Superheat = 5K)
|
||
- **FR23** : Le système calcule les entrées nécessaires (ex: ouverture vanne) en respectant des Contraintes Bornées (0.0 ≤ Valve ≤ 1.0). Si la solution est hors bornes, le solveur retourne une erreur "Saturation" ou "ControlLimitReached"
|
||
- **FR24** : L'Inverse Control est résolu simultanément avec les équations du cycle (One-Shot)
|
||
|
||
### 5. Propriétés des Fluides (Fluid Properties)
|
||
|
||
- **FR25** : Le système peut charger des propriétés de fluides via CoolProp
|
||
- **FR26** : Le système supporte les tables tabulaires (Tabular Interpolation) pour performance 100x
|
||
- **FR27** : Le système gère les fluides purs et les mélanges (R32/R125, R454B)
|
||
- **FR28** : Le système gère le glissement de température (Temperature Glide) pour mélanges zeotropiques
|
||
- **FR29** : Le système utilise le damping automatique près du point critique (CO2 R744)
|
||
- **FR40** : Le système gère les Fluides Incompressibles (Eau, Glycol, Air Humide simplifié) via des modèles allégés (Cp constant ou polynomial) pour les sources et puits de chaleur
|
||
|
||
### 6. API & Interfaces
|
||
|
||
- **FR30** : API Rust native avec types et ownership safety
|
||
- **FR31** : Bindings Python via PyO3 avec API compatible tespy
|
||
- **FR32** : FFI C pour intégration avec systèmes externes (PLC, LabView)
|
||
- **FR33** : WebAssembly compilation supportée pour interfaces web
|
||
- **FR34** : CLI pour exécution batch de simulations
|
||
|
||
### 7. Sérialisation & Persistance
|
||
|
||
- **FR41** : Le graphe complet (Topologie + Paramètres + État du Fluide) est sérialisable/désérialisable en JSON (ou TOML)
|
||
|
||
### 8. Validation & Diagnostics
|
||
|
||
- **FR35** : Le système vérifie automatiquement le bilan de masse (Σ ṁ_in - Σ ṁ_out < 1e-9 kg/s)
|
||
- **FR36** : Le système vérifie automatiquement le bilan énergétique (Σ Q̇ + Ẇ - Σ (ṁ · h) < 1e-6 kW)
|
||
- **FR37** : Chaque résultat contient métadonnées de traçabilité (version solver, version fluide, hash SHA-256 input)
|
||
- **FR38** : Mode Debug Verbose pour afficher les résidus et l'historique de convergence
|
||
- **FR39** : Gestion des erreurs via Result<T, ThermoError> (Zero-Panic Policy)
|
||
|
||
---
|
||
|
||
## Non-Functional Requirements
|
||
|
||
### Performance
|
||
|
||
- **NFR1** : Temps de convergence Steady State < **1 seconde** pour cycle standard en Cold Start
|
||
- **NFR2** : Cycle simple (Mono-étagé) résolu en **< 100 ms**
|
||
- **NFR3** : Cycle complexe (Multi-circuits) résolu en **< 1 seconde**
|
||
- **NFR4** : Pas d'allocation dynamique dans la boucle de résolution (allocation pré-calculée uniquement)
|
||
- **NFR5** : Déterminisme garanti : mêmes entrées → mêmes résultats à 1e-9 près sur toutes les plateformes (x86, ARM, WASM)
|
||
- **NFR6** : Latence HIL < **20 ms** pour intégration temps réel avec PLC
|
||
|
||
### Fiabilité (Reliability)
|
||
|
||
- **NFR7** : Zero-Panic Policy : aucun crash même avec entrées invalides ou états impossibles
|
||
- **NFR8** : Memory Safety garantie par Rust ownership system (pas de fuite mémoire, pas de use-after-free)
|
||
- **NFR9** : Capacité à tourner **48h+** sans interruption ni dégradation (HIL/Emabarqué)
|
||
- **NFR10** : Gestion gracieuse des erreurs : timeout, non-convergence, saturation retournent Result<T, Error> explicite
|
||
|
||
### Intégration
|
||
|
||
- **NFR11** : Compatibilité CoolProp 6.4+ pour propriétés des fluides
|
||
- **NFR12** : FFI C stable : headers .h auto-générés via cbindgen, compatible C99/C++
|
||
- **NFR13** : WebAssembly déterministe : même comportement que natif, pas de source de non-déterminisme
|
||
- **NFR14** : Python bindings PyO3 : API compatible tespy pour migration facilitée
|
||
|
||
### Maintenabilité
|
||
|
||
- **NFR15** : Documentation 100% des API publiques (rustdoc)
|
||
- **NFR16** : CI/CD automatisé : tests, benchmarks, memory checks (Valgrind + Miri)
|
||
- **NFR17** : Tolérance zéro warnings : `cargo clippy -- -D warnings`
|
||
|
||
---
|
||
|
||
## Document Information
|
||
|
||
**Workflow :** BMAD Create PRD
|
||
**Steps Completed :** 12/12
|
||
**Total FRs :** 42
|
||
**Total NFRs :** 17
|
||
**Personas :** 5
|
||
**Innovations :** 5
|
||
|
||
**Last Updated :** 2026-02-12
|
||
**Status :** ✅ Complete & Ready for Implementation
|
||
|
||
---
|
||
|
||
*Ce PRD sert de fondation pour toutes les activités de développement produit. Tout le travail de conception, d'architecture et de développement doit être tracé vers les exigences et la vision documentées dans ce PRD.*
|