27 KiB
| stepsCompleted | inputDocuments | documentCounts | classification | 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, Coils air)
- Support d'autres backends thermodynamiques (RefProp)
- Parallélisation multi-threading
- Validation ASHRAE 140 / BESTEST (cas de test standardisés)
- Calibration inverse (estimation des paramètres depuis données banc d'essai)
- Export données synthétiques (génération de datasets pour ML/surrogates)
Vision (Future)
- Simulation transitoire (dynamique, pas juste steady-state)
- Part-load / cyclage (courbes PLF, pertes de cyclage)
- Frost / defrost (pompes à chaleur air)
- Moving boundary (échangeurs discretisés, zones superheated/two-phase/subcooled)
- 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 :
- Découverte : Elle lit la documentation RustThermoCycle, remarque la promesse "< 1s"
- Première simulation : Elle définit sa machine bi-circuit en Rust
- Optimisation : Lance l'exploration paramétrique (3600 points)
- Climax : Résultats en < 3 secondes - elle peut itérer en temps réel
- 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 :
- Setup : Compile RustThermoCycle en WebAssembly
- Intégration : Expose l'API via wasm-bindgen
- UI : Crée composant React avec sliders
- Climax : Déplace un slider → Recalcul en < 100ms, expérience fluide
- 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 :
- Installation : Découvre l'API Graphe RustThermoCycle
- Modélisation : Instancie
Ejector,FlashTank,Compressor, connecte avecsystem.connect() - Debug : Active mode "Verbose" pour voir les résidus
- Climax : Newton-Raphson diverge → Fallback auto en Substitution Séquentielle → stabilisation → retour Newton → Convergé en 450ms
- 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 :
- Setup : Compile RustThermoCycle en
.dll/.soavec FFI C - Configuration : Modèle reçoit ouverture vanne (Input), renvoie Pression (Output) toutes les 100ms
- Test : Lancement banc d'essai
- Climax : Calcul état thermodynamique en 12ms (< 100ms limite), mémoire stable (Rust ownership), 48h sans interruption
- 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 :
- Architecture : Utilise RustThermoCycle via CLI
- Parallélisation : Exploite
Send + Syncpour utiliser 100% des cœurs CPU - Exécution : Batch de millions de scénarios
- Climax : Throughput maximum, zero contention, résultats cohérents
- 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
Référence littérature HVAC (EnergyPlus, TRNSYS, Modelica) :
- ASHRAE Standard 140 : Méthode de test pour évaluer les logiciels de simulation énergétique bâtiment
- BESTEST / Airside HVAC : Cas AE101–AE445 pour validation équipements HVAC
- Calibration : Paramètres Calib (f_m, f_dp, f_ua, f_power) alignés sur Buildings Modelica, EnergyPlus, TRNSYS
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
- Benchmark vs tespy/CoolProp : Même cycle, mesurer speedup (objectif 100x)
- HIL Validation : Connecter à PLC réel, mesurer latence (objectif < 20ms)
- Convergence Stress Test : Cycles CO2 proches point critique
- Memory Safety Audit : Valgrind + Miri (interpréteur MIR Rust) sur 48h
- ASHRAE 140 / BESTEST (post-MVP) : Cas de test standardisés pour crédibilité industrielle
- Calibration inverse : Ajustement paramètres depuis données fabricant ou banc d'essai
Risk Mitigation
Si le solveur ne converge pas dans le budget temps (HIL) :
Stratégie de Dégradation Gracieuse :
- Time-Budgeted Solving : Vérification horloge système à chaque itération, arrêt si
elapsed > max_time - Zero-Order Hold (ZOH) avec Flag : Retour du résultat précédent avec
ComputationStatus::Timeout - 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 tespyparimport rust_thermo_cyclesans 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
.hpour 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
-
"Benchmark Demo" (Le Vendeur) :
1000 simulations PAC simple Temps total : 450ms (Est. Python : 45s) Speedup : 100x -
"Inverse Control" :
- Définir
Superheat_Target = 5K - Laisser le solveur trouver l'ouverture de vanne
- Définir
-
"Hybrid PyO3" :
- Python appelle Rust pour calcul lourd
- Matplotlib pour tracer diagramme P-h
DevEx & Qualité
CI/CD Pipeline (GitHub Actions) :
cargo test: Unit testscargo bench: Performance regressionvalgrind: Memory leaks (FFI)cargo clippy -- -D warnings: Tolérance zéro sur le stylemiri test: Undefined behavior detection
Qualité Code :
#![deny(warnings)]danslib.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
- FR48 : Le système permet de définir des sous-systèmes hiérarchiques (MacroComponents/Blocks) comme dans Modelica, encapsulant une topologie interne et exposant uniquement des ports (ex: raccorder deux Chillers en parallèle).
- FR49 : Le système fournit des composants de jonction fluidique (
FlowSplitter1→N etFlowMergerN→1) pour fluides compressibles (réfrigérant, CO₂) et incompressibles (eau, glycol, saumure), avec équations de bilan de masse, isobare et enthalpie de mélange pondérée (with_mass_flows). - FR50 : Le système fournit des composants de condition aux limites (
FlowSourceetFlowSink) pour fixer les états de pression et d'enthalpie aux bornes d'un circuit, pour fluides compressibles et incompressibles.
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
- FR47 : Chaque composant frigorifique doit exposer nativement un état thermodynamique complet (Pression, Température, T_sat, Titre massique, Surchauffe, Sous-refroidissement, Débit massique, Reynolds, Enthalpie, Entropie) accessible facilement sans recalcul complexe par l'utilisateur.
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)
- FR43 : Les composants supportent des paramètres de calibration (Calib) pour rapprocher la simulation des données machines réelles
- FR44 : Le système peut valider ses résultats contre des cas de test ASHRAE 140 / BESTEST (post-MVP)
- FR45 : Le système supporte la calibration inverse (estimation des paramètres depuis données banc d'essai)
- FR46 : Composants Coils air explicites (EvaporatorCoil, CondenserCoil) pour batteries à ailettes (post-MVP)
- FR51 : Le système permet d'échanger les coefficients de calibration (f_m, f_ua, f_power, etc.) en inconnues du solveur et les valeurs mesurées (Tsat, capacité, puissance) en contraintes, pour une calibration inverse en One-Shot sans optimiseur externe
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 : 51
Total NFRs : 17
Personas : 5
Innovations : 5
Last Updated : 2026-02-21
Status : ✅ Complete & Ready for Implementation
Changelog :
2026-02-21: Ajout FR51 (Swappable Calibration Variables) — calibration inverse One-Shot via échange f_ ↔ contraintes (Story 5.5).2026-02-20: Ajout FR49 (FlowSplitter/FlowMerger) et FR50 (FlowSource/FlowSink) — composants de jonction et conditions aux limites pour fluides compressibles et incompressibles (Story 1.11 et 1.12).
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.