cwicr-risk-calculator
Calculate risk-adjusted cost estimates using CWICR data. Apply contingencies, Monte Carlo simulation, and probability distributions to cost estimates.
git clone --depth 1 https://github.com/datadrivenconstruction/DDC_Skills_for_AI_Agents_in_Construction /tmp/cwicr-risk-calculator && cp -r /tmp/cwicr-risk-calculator/1_DDC_Toolkit/CWICR-Database/cwicr-risk-calculator ~/.claude/skills/cwicr-risk-calculatorSKILL.md
# CWICR Risk Calculator
## Business Case
### Problem Statement
Cost estimates have inherent uncertainty:
- What contingency to apply?
- What is the confidence range?
- Which items have highest risk?
- How to quantify uncertainty?
### Solution
Risk-adjusted cost calculations using contingency analysis, Monte Carlo simulation, and probability distributions based on CWICR cost data.
### Business Value
- **Informed decisions** - Understand estimate uncertainty
- **Appropriate contingency** - Data-driven risk allowance
- **Confidence intervals** - P50, P80, P90 estimates
- **Risk prioritization** - Focus on high-impact items
## Technical Implementation
```python
import pandas as pd
import numpy as np
from typing import Dict, Any, List, Optional, Tuple
from dataclasses import dataclass, field
from datetime import datetime
from enum import Enum
import random
class RiskLevel(Enum):
"""Risk level categories."""
LOW = "low" # Well-defined, standard work
MEDIUM = "medium" # Some uncertainty
HIGH = "high" # Significant uncertainty
VERY_HIGH = "very_high" # Major unknowns
class DistributionType(Enum):
"""Probability distribution types."""
NORMAL = "normal"
TRIANGULAR = "triangular"
UNIFORM = "uniform"
PERT = "pert"
LOGNORMAL = "lognormal"
@dataclass
class RiskParameters:
"""Risk parameters for a work item."""
work_item_code: str
base_cost: float
risk_level: RiskLevel
distribution: DistributionType
min_factor: float # Multiplier for minimum
max_factor: float # Multiplier for maximum
most_likely_factor: float = 1.0
@dataclass
class MonteCarloResult:
"""Results of Monte Carlo simulation."""
iterations: int
mean: float
std_dev: float
p10: float # 10th percentile
p50: float # Median
p80: float # 80th percentile
p90: float # 90th percentile
min_value: float
max_value: float
values: List[float]
@dataclass
class RiskAnalysisResult:
"""Complete risk analysis result."""
base_estimate: float
risk_adjusted_mean: float
contingency_amount: float
contingency_percent: float
p50_estimate: float
p80_estimate: float
p90_estimate: float
high_risk_items: List[Dict[str, Any]]
item_risks: List[RiskParameters]
monte_carlo: Optional[MonteCarloResult] = None
# Default risk parameters by category
DEFAULT_RISK_PARAMS = {
'CONC': {'risk': RiskLevel.LOW, 'min': 0.95, 'max': 1.15},
'EXCV': {'risk': RiskLevel.MEDIUM, 'min': 0.85, 'max': 1.30},
'STRL': {'risk': RiskLevel.LOW, 'min': 0.95, 'max': 1.10},
'MECH': {'risk': RiskLevel.MEDIUM, 'min': 0.90, 'max': 1.25},
'ELEC': {'risk': RiskLevel.MEDIUM, 'min': 0.90, 'max': 1.20},
'FINI': {'risk': RiskLevel.HIGH, 'min': 0.85, 'max': 1.40},
'SITE': {'risk': RiskLevel.HIGH, 'min': 0.80, 'max': 1.50},
'DEFAULT': {'risk': RiskLevel.MEDIUM, 'min': 0.90, 'max': 1.25}
}
class CWICRRiskCalculator:
"""Calculate risk-adjusted estimates using CWICR data."""
def __init__(self, cwicr_data: pd.DataFrame):
self.work_items = cwicr_data
self._index_data()
def _index_data(self):
"""Index work items."""
if 'work_item_code' in self.work_items.columns:
self._code_index = self.work_items.set_index('work_item_code')
else:
self._code_index = None
def _get_risk_params(self, code: str) -> Dict[str, Any]:
"""Get default risk parameters for work item code."""
prefix = code.split('-')[0] if '-' in code else code[:4]
return DEFAULT_RISK_PARAMS.get(prefix, DEFAULT_RISK_PARAMS['DEFAULT'])
def define_item_risk(self,
code: str,
base_cost: float,
risk_level: RiskLevel = None,
distribution: DistributionType = DistributionType.TRIANGULAR,
min_factor: float = None,
max_factor: float = None) -> RiskParameters:
"""Define risk parameters for a work item."""
default_params = self._get_risk_params(code)
if risk_level is None:
risk_level = default_params['risk']
if min_factor is None:
min_factor = default_params['min']
if max_factor is None:
max_factor = default_params['max']
return RiskParameters(
work_item_code=code,
base_cost=base_cost,
risk_level=risk_level,
distribution=distribution,
min_factor=min_factor,
max_factor=max_factor,
most_likely_factor=1.0
)
def calculate_item_risk(self,
items: List[Dict[str, Any]]) -> List[RiskParameters]:
"""Calculate risk parameters for list of work items."""
risk_params = []
for item in items:
code = item.get('work_item_code', item.get('code'))
qty = item.get('quantity', 0)
# Get base cost
base_cost = 0
if self._code_index is not None and code in self._code_index.index:
wi = self._code_index.loc[code]
labor = float(wi.get('labor_cost', 0) or 0)
material = float(wi.get('material_cost', 0) or 0)
equipment = float(wi.get('equipment_cost', 0) or 0)
base_cost = (labor + material + equipment) * qty
# Get risk level from item or default
risk_level = item.get('risk_level')
if risk_level and isinstance(risk_level, str):
risk_level = RiskLevel[risk_level.upper()]
params = self.define_item_risk(
code=code,
base_cost=base_cost,
risk_level=risk_level,
min_factor=item.get('min_factor'),
max_factor=item.get('max_factor')
)
risk_params.append(params)
return risk_paGenerate automated daily progress reports from site data. Track work completed, labor hours, equipment usage, and weather conditions.
Analyze labor productivity from site data. Compare planned vs actual, identify trends, benchmark against industry standards.
Create interactive KPI dashboards for construction projects. Track schedule, cost, quality, and safety metrics in real-time.
Detect and analyze geometric clashes in BIM models. Identify MEP, structural, and architectural conflicts before construction.
Classify BIM elements using AI and standard classification systems. Map elements to UniFormat, MasterFormat, OmniClass, and CWICR codes.
Generate comprehensive BIM model validation reports. Check data quality, completeness, and compliance with standards.
Calculate CO2 emissions and carbon footprint from BIM model data. Analyze embodied carbon by material, element, and building system.
Extract quantities from IFC/Revit models for quantity takeoff. Uses DDC converters to get element counts, areas, volumes, lengths with grouping and reporting.