build(agent): new-agents-2#7e3bbc iteration

This commit is contained in:
agent-7e3bbc424e07835b 2026-04-20 14:08:17 +02:00
parent c224415d56
commit 6994b86f6e
3 changed files with 93 additions and 2 deletions

View File

@ -6,15 +6,20 @@ federated arbitrage engine; here we only provide deterministic, testable
behaviors. behaviors.
""" """
from .primitives import LocalArbProblem, SharedSignals # noqa: F401 from .primitives import LocalArbProblem, SharedSignals, DualVariables, AuditLog, PrivacyBudget # noqa: F401
from .coordinator import admm_lite_step # noqa: F401 from .coordinator import admm_lite_step # noqa: F401
from .ir import map_to_ir # noqa: F401 from .ir import map_to_ir # noqa: F401
from .go_registry import GoCRegistry # noqa: F401 from .go_registry import GoCRegistry # noqa: F401
from .two_venue_demo import run_demo # noqa: F401
__all__ = [ __all__ = [
"LocalArbProblem", "LocalArbProblem",
"SharedSignals", "SharedSignals",
"DualVariables",
"AuditLog",
"PrivacyBudget",
"admm_lite_step", "admm_lite_step",
"map_to_ir", "map_to_ir",
"GoCRegistry", "GoCRegistry",
"run_demo",
] ]

View File

@ -1,5 +1,5 @@
from dataclasses import dataclass from dataclasses import dataclass
from typing import List, Tuple, Dict from typing import List, Tuple, Dict, Any
@dataclass(frozen=True) @dataclass(frozen=True)
@ -16,3 +16,32 @@ class SharedSignals:
cross_venue_corr: float cross_venue_corr: float
liquidity_availability: Dict[str, float] liquidity_availability: Dict[str, float]
latency_proxy: float latency_proxy: float
@dataclass
class DualVariables:
"""Federated optimization dual variables (shadow prices per asset pair).
This is a lightweight stand-in for the real project's duals used by the
ADMM-like coordinator to balance cross-venue objectives.
"""
shadow_prices: Dict[str, float]
@dataclass
class AuditLogEntry:
ts: float
event: str
details: Dict[str, Any]
signature: str
@dataclass
class AuditLog:
entries: List[AuditLogEntry]
@dataclass
class PrivacyBudget:
"""Simple privacy budget per signal source or metric."""
budgets: Dict[str, float]

View File

@ -0,0 +1,57 @@
from __future__ import annotations
"""Toy two-venue ArbSphere demo.
This module wires two toy adapters (price feed and broker) from two venues
and demonstrates a minimal federated compute step using the existing ADMM-lite
coordinator API.
"""
import time
from typing import List
from arbsphere.primitives import LocalArbProblem, SharedSignals
from arbsphere.coordinator import admm_lite_step
from arbsphere.adapters.price_feed_adapter import PriceFeedAdapter
from arbsphere.adapters.broker_adapter import BrokerAdapter
def run_demo() -> None:
# Define two toy venues with simple, deterministic budgets
lp1 = LocalArbProblem(asset_pair=("AAPL", "MSFT"), target_mispricing=0.5, liquidity_budget=1000.0, latency_budget=5.0)
lp2 = LocalArbProblem(asset_pair=("GOOG", "AMZN"), target_mispricing=0.7, liquidity_budget=800.0, latency_budget=6.0)
shared = SharedSignals(
deltas=[0.1, -0.05],
cross_venue_corr=0.25,
liquidity_availability={"venue-1": 0.8, "venue-2": 0.75},
latency_proxy=0.9,
)
# Step 1: compute a delta (toy) via admm_lite_step
delta = admm_lite_step([lp1, lp2], shared)
print("Generated PlanDelta:")
print(delta)
# Step 2: route using toy broker adapters (two venues)
broker_a = BrokerAdapter(venue_name="venue-1")
broker_b = BrokerAdapter(venue_name="venue-2")
# Create simple per-venue plan deltas; in a real system this would be split by venue
plan_for_venue_a = {"legs": delta.legs, "total_size": delta.total_size}
plan_for_venue_b = {"legs": delta.legs, "total_size": delta.total_size}
broker_a.route(plan_for_venue_a)
broker_b.route(plan_for_venue_b)
print("Venue-1 execution history:", broker_a.history())
print("Venue-2 execution history:", broker_b.history())
def main() -> None:
print("Starting ArbSphere two-venue demo...")
run_demo()
if __name__ == "__main__":
main()