-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlib.rs
More file actions
89 lines (75 loc) · 2.81 KB
/
lib.rs
File metadata and controls
89 lines (75 loc) · 2.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
//! # RustKernel Clearing
//!
//! GPU-accelerated clearing and settlement kernels.
//!
//! ## Kernels
//! - `ClearingValidation` - Trade validation for clearing eligibility
//! - `DVPMatching` - Delivery vs payment matching
//! - `NettingCalculation` - Multilateral netting calculation
//! - `SettlementExecution` - Settlement instruction execution
//! - `ZeroBalanceFrequency` - Settlement efficiency metrics
//!
//! ## Features
//! - Trade validation with counterparty/security eligibility checks
//! - DVP instruction matching with tolerance-based scoring
//! - Multilateral netting to reduce gross obligations
//! - Settlement execution with priority and partial settlement support
//! - Zero balance frequency and efficiency metrics
#![warn(missing_docs)]
pub mod dvp;
pub mod efficiency;
pub mod netting;
pub mod settlement;
pub mod types;
pub mod validation;
/// Prelude for convenient imports.
pub mod prelude {
pub use crate::dvp::*;
pub use crate::efficiency::*;
pub use crate::netting::*;
pub use crate::settlement::*;
pub use crate::types::*;
pub use crate::validation::*;
}
// Re-export main kernels
pub use dvp::DVPMatching;
pub use efficiency::ZeroBalanceFrequency;
pub use netting::NettingCalculation;
pub use settlement::SettlementExecution;
pub use validation::ClearingValidation;
// Re-export key types
pub use types::{
DVPInstruction, DVPMatchResult, DVPStatus, ErrorSeverity, InstructionType, NetPosition,
NettingConfig, NettingResult, SettlementEfficiency, SettlementExecutionResult,
SettlementInstruction, SettlementStatus, Trade, TradeStatus, TradeType, ValidationConfig,
ValidationError, ValidationResult, ZeroBalanceMetrics,
};
/// Register all clearing kernels with a registry.
pub fn register_all(
registry: &rustkernel_core::registry::KernelRegistry,
) -> rustkernel_core::error::Result<()> {
tracing::info!("Registering clearing kernels");
// Validation kernel (1) — Batch
registry.register_ring_metadata_from(validation::ClearingValidation::new)?;
// DVP kernel (1) — Ring
registry.register_ring_metadata_from(dvp::DVPMatching::new)?;
// Netting kernel (1) — Batch
registry.register_ring_metadata_from(netting::NettingCalculation::new)?;
// Settlement kernel (1) — Ring
registry.register_ring_metadata_from(settlement::SettlementExecution::new)?;
// Efficiency kernel (1) — Batch
registry.register_ring_metadata_from(efficiency::ZeroBalanceFrequency::new)?;
tracing::info!("Registered 5 clearing kernels");
Ok(())
}
#[cfg(test)]
mod tests {
use super::*;
use rustkernel_core::registry::KernelRegistry;
#[test]
fn test_register_all() {
let registry = KernelRegistry::new();
register_all(®istry).expect("Failed to register clearing kernels");
assert_eq!(registry.total_count(), 5);
}
}