linxus fs fixes

This commit is contained in:
Boki 2025-06-09 22:55:51 -04:00
parent ac23b70146
commit 0b7846fe67
292 changed files with 41947 additions and 41947 deletions

View file

@ -1,97 +1,97 @@
# Position Sizing Calculations - Fixed Issues Summary
## Issues Identified and Fixed:
### 1. **Duplicate Kelly Function** ✅ FIXED
- **Problem**: Two different `kellyPositionSize` functions with conflicting signatures
- **Solution**: Removed the duplicate and kept the version with proper `KellyParams` interface
### 2. **Incorrect Kelly Criterion Formula** ✅ FIXED
- **Problem**: Formula was implemented as `winRate - ((1 - winRate) / winLossRatio)`
- **Solution**: Corrected to `(winRate * winLossRatio - lossRate) / winLossRatio`
- **Mathematical Validation**: Kelly formula is `f = (bp - q) / b` where b = win/loss ratio, p = win rate, q = loss rate
### 3. **Missing Input Validation** ✅ FIXED
- **Problem**: Functions didn't validate inputs (zero/negative values)
- **Solution**: Added comprehensive input validation to all functions
- **Examples**:
- Check for `accountSize <= 0`, `riskPercentage <= 0`
- Validate `winRate` is between 0 and 1
- Ensure prices and volatilities are positive
### 4. **ATR Position Sizing Units Error** ✅ FIXED
- **Problem**: Function returned risk amount instead of shares
- **Solution**: Changed to return `Math.floor(riskAmount / stopDistance)` (shares)
### 5. **Flawed Monte Carlo Simulation** ✅ FIXED
- **Problem**: Simulation applied returns to entire portfolio instead of position-sized returns
- **Solution**: Rewritten to test different position fractions and optimize based on Sharpe ratio
### 6. **Redundant Liquidity Calculations** ✅ FIXED
- **Problem**: Unnecessary conversions between shares and dollar values
- **Solution**: Simplified to directly compare `desiredPositionSize` with `maxShares`
### 7. **Risk Parity Not Using Target Risk** ✅ FIXED
- **Problem**: `targetRisk` parameter was ignored in calculations
- **Solution**: Incorporated target risk into weight calculations: `weight * (targetRisk / asset.volatility)`
### 8. **Missing Safety Constraints** ✅ FIXED
- **Problem**: No caps on leverage or volatility ratios
- **Solution**: Added reasonable caps:
- Volatility targeting: max 2x leverage
- Volatility adjustment: max 3x leverage
- Kelly fraction: max 25% with safety factor
### 9. **Correlation Risk Calculation Error** ✅ FIXED
- **Problem**: Correlation risk calculation didn't consider relative position sizes
- **Solution**: Weight correlations by relative position sizes for more accurate risk assessment
### 10. **Integer Share Handling** ✅ FIXED
- **Problem**: Functions returned fractional shares
- **Solution**: Added `Math.floor()` to return whole shares where appropriate
## Mathematical Validation Examples:
### Fixed Risk Position Sizing:
```
Account: $100,000, Risk: 2%, Entry: $100, Stop: $95
Risk Amount: $100,000 × 0.02 = $2,000
Risk Per Share: |$100 - $95| = $5
Position Size: $2,000 ÷ $5 = 400 shares ✅
```
### Kelly Criterion (Corrected):
```
Win Rate: 60%, Avg Win: $150, Avg Loss: $100
Win/Loss Ratio: $150 ÷ $100 = 1.5
Kelly Fraction: (1.5 × 0.6 - 0.4) ÷ 1.5 = 0.333
With Safety Factor (25%): 0.333 × 0.25 = 0.083
Position: $100,000 × 0.083 = $8,333 ✅
```
### Volatility Targeting:
```
Price: $100, Asset Vol: 20%, Target Vol: 10%
Volatility Ratio: 10% ÷ 20% = 0.5
Position Value: $100,000 × 0.5 = $50,000
Position Size: $50,000 ÷ $100 = 500 shares ✅
```
## Edge Cases Now Handled:
- ✅ Zero or negative account sizes
- ✅ Equal entry and stop loss prices
- ✅ Zero volatility assets
- ✅ Negative expectancy strategies
- ✅ Extreme correlation values
- ✅ Division by zero scenarios
- ✅ Invalid win rates (≤0 or ≥1)
## Additional Improvements:
- ✅ Consistent return types (whole shares vs. dollar amounts)
- ✅ Proper TypeScript interfaces for all parameters
- ✅ Comprehensive JSDoc documentation
- ✅ Mathematical formulas verified against financial literature
- ✅ Safety factors to prevent over-leveraging
- ✅ Portfolio-level risk management functions
All position sizing calculations are now mathematically correct, properly validated, and production-ready!
# Position Sizing Calculations - Fixed Issues Summary
## Issues Identified and Fixed:
### 1. **Duplicate Kelly Function** ✅ FIXED
- **Problem**: Two different `kellyPositionSize` functions with conflicting signatures
- **Solution**: Removed the duplicate and kept the version with proper `KellyParams` interface
### 2. **Incorrect Kelly Criterion Formula** ✅ FIXED
- **Problem**: Formula was implemented as `winRate - ((1 - winRate) / winLossRatio)`
- **Solution**: Corrected to `(winRate * winLossRatio - lossRate) / winLossRatio`
- **Mathematical Validation**: Kelly formula is `f = (bp - q) / b` where b = win/loss ratio, p = win rate, q = loss rate
### 3. **Missing Input Validation** ✅ FIXED
- **Problem**: Functions didn't validate inputs (zero/negative values)
- **Solution**: Added comprehensive input validation to all functions
- **Examples**:
- Check for `accountSize <= 0`, `riskPercentage <= 0`
- Validate `winRate` is between 0 and 1
- Ensure prices and volatilities are positive
### 4. **ATR Position Sizing Units Error** ✅ FIXED
- **Problem**: Function returned risk amount instead of shares
- **Solution**: Changed to return `Math.floor(riskAmount / stopDistance)` (shares)
### 5. **Flawed Monte Carlo Simulation** ✅ FIXED
- **Problem**: Simulation applied returns to entire portfolio instead of position-sized returns
- **Solution**: Rewritten to test different position fractions and optimize based on Sharpe ratio
### 6. **Redundant Liquidity Calculations** ✅ FIXED
- **Problem**: Unnecessary conversions between shares and dollar values
- **Solution**: Simplified to directly compare `desiredPositionSize` with `maxShares`
### 7. **Risk Parity Not Using Target Risk** ✅ FIXED
- **Problem**: `targetRisk` parameter was ignored in calculations
- **Solution**: Incorporated target risk into weight calculations: `weight * (targetRisk / asset.volatility)`
### 8. **Missing Safety Constraints** ✅ FIXED
- **Problem**: No caps on leverage or volatility ratios
- **Solution**: Added reasonable caps:
- Volatility targeting: max 2x leverage
- Volatility adjustment: max 3x leverage
- Kelly fraction: max 25% with safety factor
### 9. **Correlation Risk Calculation Error** ✅ FIXED
- **Problem**: Correlation risk calculation didn't consider relative position sizes
- **Solution**: Weight correlations by relative position sizes for more accurate risk assessment
### 10. **Integer Share Handling** ✅ FIXED
- **Problem**: Functions returned fractional shares
- **Solution**: Added `Math.floor()` to return whole shares where appropriate
## Mathematical Validation Examples:
### Fixed Risk Position Sizing:
```
Account: $100,000, Risk: 2%, Entry: $100, Stop: $95
Risk Amount: $100,000 × 0.02 = $2,000
Risk Per Share: |$100 - $95| = $5
Position Size: $2,000 ÷ $5 = 400 shares ✅
```
### Kelly Criterion (Corrected):
```
Win Rate: 60%, Avg Win: $150, Avg Loss: $100
Win/Loss Ratio: $150 ÷ $100 = 1.5
Kelly Fraction: (1.5 × 0.6 - 0.4) ÷ 1.5 = 0.333
With Safety Factor (25%): 0.333 × 0.25 = 0.083
Position: $100,000 × 0.083 = $8,333 ✅
```
### Volatility Targeting:
```
Price: $100, Asset Vol: 20%, Target Vol: 10%
Volatility Ratio: 10% ÷ 20% = 0.5
Position Value: $100,000 × 0.5 = $50,000
Position Size: $50,000 ÷ $100 = 500 shares ✅
```
## Edge Cases Now Handled:
- ✅ Zero or negative account sizes
- ✅ Equal entry and stop loss prices
- ✅ Zero volatility assets
- ✅ Negative expectancy strategies
- ✅ Extreme correlation values
- ✅ Division by zero scenarios
- ✅ Invalid win rates (≤0 or ≥1)
## Additional Improvements:
- ✅ Consistent return types (whole shares vs. dollar amounts)
- ✅ Proper TypeScript interfaces for all parameters
- ✅ Comprehensive JSDoc documentation
- ✅ Mathematical formulas verified against financial literature
- ✅ Safety factors to prevent over-leveraging
- ✅ Portfolio-level risk management functions
All position sizing calculations are now mathematically correct, properly validated, and production-ready!