# ๐ค NOFX - Agentic Trading OS
[](https://golang.org/)
[](https://reactjs.org/)
[](https://www.typescriptlang.org/)
[](LICENSE)
[](https://amber.ac)
**Languages:** [English](README.md) | [ไธญๆ](README.zh-CN.md) | [ะฃะบัะฐัะฝััะบะฐ](README.uk.md) | [ะ ัััะบะธะน](README.ru.md)
---
## ๐ Universal AI Trading Operating System
**NOFX** is a **universal Agentic Trading OS** built on a unified architecture. We've successfully closed the loop in crypto markets: **"Multi-Agent Decision โ Unified Risk Control โ Low-Latency Execution โ Live/Paper Account Backtesting"**, and are now expanding this same technology stack to **stocks, futures, options, forex, and all financial markets**.
### ๐ฏ Core Features
- **Universal Data & Backtesting Layer**: Cross-market, cross-timeframe, cross-exchange unified representation and factor library, accumulating transferable "strategy memory"
- **Multi-Agent Self-Play & Self-Evolution**: Strategies automatically compete and select the best, continuously iterating based on account-level PnL and risk constraints
- **Integrated Execution & Risk Control**: Low-latency routing, slippage/risk control sandbox, account-level limits, one-click market switching
### ๐ข Backed by [Amber.ac](https://amber.ac)
### ๐ฅ Core Team
- **Tinkle** - Technology & Developer Relations
- Leading all technical development and architecture
- Building the developer community
- Twitter/X: [@Web3Tinkle](https://x.com/Web3Tinkle)
- **Zack** - Market & Fundraising
- Leading market strategy and business development
- Managing fundraising and investor relations
- Twitter/X: [@0x_ZackH](https://x.com/0x_ZackH)
### ๐ผ Seed Funding Round Open
We are currently raising our **seed round**.
**For investment inquiries, please contact Zack** via Twitter DM.
---
> โ ๏ธ **Risk Warning**: This system is experimental. AI auto-trading carries significant risks. Strongly recommended for learning/research purposes or testing with small amounts only!
## ๐ฅ Developer Community
Join our Telegram developer community to discuss, share ideas, and get support:
**๐ฌ [NOFX Developer Community](https://t.me/nofx_dev_community)**
---
## ๐ What's New (Latest Update)
### ๐ Multi-Exchange Support!
NOFX now supports **three major exchanges**: Binance, Hyperliquid, and Aster DEX!
#### **Hyperliquid Exchange**
A high-performance decentralized perpetual futures exchange!
**Key Features:**
- โ
Full trading support (long/short, leverage, stop-loss/take-profit)
- โ
Automatic precision handling (order size & price)
- โ
Unified trader interface (seamless exchange switching)
- โ
Support for both mainnet and testnet
- โ
No API keys needed - just your Ethereum private key
**Why Hyperliquid?**
- ๐ฅ Lower fees than centralized exchanges
- ๐ Non-custodial - you control your funds
- โก Fast execution with on-chain settlement
- ๐ No KYC required
**Quick Start:**
1. Get your MetaMask private key (remove `0x` prefix)
2. Set `"exchange": "hyperliquid"` in config.json
3. Add `"hyperliquid_private_key": "your_key"`
4. Start trading!
See [Configuration Guide](#-alternative-using-hyperliquid-exchange) for details.
#### **Aster DEX Exchange** (NEW! v2.0.2)
A Binance-compatible decentralized perpetual futures exchange!
**Key Features:**
- โ
Binance-style API (easy migration from Binance)
- โ
Web3 wallet authentication (secure and decentralized)
- โ
Full trading support with automatic precision handling
- โ
Lower trading fees than CEX
- โ
EVM-compatible (Ethereum, BSC, Polygon, etc.)
**Why Aster?**
- ๐ฏ **Binance-compatible API** - minimal code changes required
- ๐ **API Wallet System** - separate trading wallet for security
- ๐ฐ **Competitive fees** - lower than most centralized exchanges
- ๐ **Multi-chain support** - trade on your preferred EVM chain
**Quick Start:**
1. Visit [Aster API Wallet](https://www.asterdex.com/en/api-wallet)
2. Connect your main wallet and create an API wallet
3. Copy the API Signer address and Private Key
4. Set `"exchange": "aster"` in config.json
5. Add `"aster_user"`, `"aster_signer"`, and `"aster_private_key"`
---
## ๐ธ Screenshots
### ๐ Competition Mode - Real-time AI Battle

*Multi-AI leaderboard with real-time performance comparison charts showing Qwen vs DeepSeek live trading battle*
### ๐ Trader Details - Complete Trading Dashboard

*Professional trading interface with equity curves, live positions, and AI decision logs with expandable input prompts & chain-of-thought reasoning*
---
## โจ Current Implementation - Crypto Markets
NOFX is currently **fully operational in cryptocurrency markets** with the following proven capabilities:
### ๐ Multi-Agent Competition Framework
- **Live Agent Battle**: Qwen vs DeepSeek models compete in real-time trading
- **Independent Account Management**: Each agent maintains its own decision logs and performance metrics
- **Real-time Performance Comparison**: Live ROI tracking, win rate statistics, and head-to-head analysis
- **Self-Evolution Loop**: Agents learn from their historical performance and continuously improve
### ๐ง AI Self-Learning & Optimization
- **Historical Feedback System**: Analyzes last 20 trading cycles before each decision
- **Smart Performance Analysis**:
- Identifies best/worst performing assets
- Calculates win rate, profit/loss ratio, average profit in real USDT terms
- Avoids repeating mistakes (consecutive losing patterns)
- Reinforces successful strategies (high win rate patterns)
- **Dynamic Strategy Adjustment**: AI autonomously adapts trading style based on backtest results
### ๐ Universal Market Data Layer (Crypto Implementation)
- **Multi-Timeframe Analysis**: 3-minute real-time + 4-hour trend data
- **Technical Indicators**: EMA20/50, MACD, RSI(7/14), ATR
- **Open Interest Tracking**: Market sentiment, capital flow analysis
- **Liquidity Filtering**: Auto-filters low liquidity assets (<15M USD)
- **Cross-Exchange Support**: Binance, Hyperliquid, Aster DEX with unified data interface
### ๐ฏ Unified Risk Control System
- **Position Limits**: Per-asset limits (Altcoins โค1.5x equity, BTC/ETH โค10x equity)
- **Configurable Leverage**: Dynamic leverage from 1x to 50x based on asset class and account type
- **Margin Management**: Total usage โค90%, AI-controlled allocation
- **Risk-Reward Enforcement**: Mandatory โฅ1:2 stop-loss to take-profit ratio
- **Anti-Stacking Protection**: Prevents duplicate positions in same asset/direction
### โก Low-Latency Execution Engine
- **Multi-Exchange API Integration**: Binance Futures, Hyperliquid DEX, Aster DEX
- **Automatic Precision Handling**: Smart order size & price formatting per exchange
- **Priority Execution**: Close existing positions first, then open new ones
- **Slippage Control**: Pre-execution validation, real-time precision checks
### ๐จ Professional Monitoring Interface
- **Binance-Style Dashboard**: Professional dark theme with real-time updates
- **Equity Curves**: Historical account value tracking (USD/percentage toggle)
- **Performance Charts**: Multi-agent ROI comparison with live updates
- **Complete Decision Logs**: Full Chain of Thought (CoT) reasoning for every trade
- **5-Second Data Refresh**: Real-time account, position, and P/L updates
---
## ๐ฎ Roadmap - Universal Market Expansion
Our proven crypto infrastructure is being extended to:
- **๐ Stock Markets**: US equities, A-shares, Hong Kong stocks
- **๐ Futures Markets**: Commodity futures, index futures
- **๐ฏ Options Trading**: Equity options, crypto options
- **๐ฑ Forex Markets**: Major currency pairs, cross rates
**Same architecture. Same agent framework. All markets.**
---
## ๐๏ธ Technical Architecture
```
nofx/
โโโ main.go # Program entry (multi-trader manager)
โโโ config.json # Configuration file (API keys, multi-trader config)
โ
โโโ api/ # HTTP API service
โ โโโ server.go # Gin framework, RESTful API
โ
โโโ trader/ # Trading core
โ โโโ auto_trader.go # Auto trading main controller (single trader)
โ โโโ binance_futures.go # Binance futures API wrapper
โ
โโโ manager/ # Multi-trader management
โ โโโ trader_manager.go # Manages multiple trader instances
โ
โโโ mcp/ # Model Context Protocol - AI communication
โ โโโ client.go # AI API client (DeepSeek/Qwen integration)
โ
โโโ decision/ # AI decision engine
โ โโโ engine.go # Decision logic with historical feedback
โ
โโโ market/ # Market data fetching
โ โโโ data.go # Market data & technical indicators (K-line, RSI, MACD)
โ
โโโ pool/ # Coin pool management
โ โโโ coin_pool.go # AI500 + OI Top merged pool
โ
โโโ logger/ # Logging system
โ โโโ decision_logger.go # Decision recording + performance analysis
โ
โโโ decision_logs/ # Decision log storage
โ โโโ qwen_trader/ # Qwen trader logs
โ โโโ deepseek_trader/ # DeepSeek trader logs
โ
โโโ web/ # React frontend
โโโ src/
โ โโโ components/ # React components
โ โ โโโ EquityChart.tsx # Equity curve chart
โ โ โโโ ComparisonChart.tsx # Multi-AI comparison chart
โ โ โโโ CompetitionPage.tsx # Competition leaderboard
โ โโโ lib/api.ts # API call wrapper
โ โโโ types/index.ts # TypeScript types
โ โโโ index.css # Binance-style CSS
โ โโโ App.tsx # Main app
โโโ package.json
```
### Core Dependencies
**Backend (Go)**
- `github.com/adshao/go-binance/v2` - Binance API client
- `github.com/markcheno/go-talib` - Technical indicator calculation (TA-Lib)
- `github.com/gin-gonic/gin` - HTTP API framework
**Frontend (React + TypeScript)**
- `react` + `react-dom` - UI framework
- `recharts` - Chart library (equity curve, comparison charts)
- `swr` - Data fetching and caching
- `tailwindcss` - CSS framework
---
## ๐ฐ Register Binance Account (Save on Fees!)
Before using this system, you need a Binance Futures account. **Use our referral link to save on trading fees:**
**๐ [Register Binance - Get Fee Discount](https://www.binance.com/join?ref=TINKLEVIP)**
### Registration Steps:
1. **Click the link above** to visit Binance registration page
2. **Complete registration** with email/phone number
3. **Complete KYC verification** (required for futures trading)
4. **Enable Futures account**:
- Go to Binance homepage โ Derivatives โ USD-M Futures
- Click "Open Now" to activate futures trading
5. **Create API Key**:
- Go to Account โ API Management
- Create new API key, **enable "Futures" permission**
- Save API Key and Secret Key (needed for config.json)
- **Important**: Whitelist your IP address for security
### Fee Discount Benefits:
- โ
**Spot trading**: Up to 30% fee discount
- โ
**Futures trading**: Up to 30% fee discount
- โ
**Lifetime validity**: Permanent discount on all trades
---
## ๐ Quick Start
### ๐ณ Option A: Docker One-Click Deployment (EASIEST - Recommended for Beginners!)
**โก Start trading in 3 simple steps with Docker - No installation needed!**
Docker automatically handles all dependencies (Go, Node.js, TA-Lib) and environment setup. Perfect for beginners!
#### Step 1: Prepare Configuration
```bash
# Copy configuration template
cp config.json.example config.json
# Edit and fill in your API keys
nano config.json # or use any editor
```
#### Step 2: One-Click Start
```bash
# Option 1: Use convenience script (Recommended)
chmod +x start.sh
./start.sh start --build
> #### Docker Compose Version Notes
>
> **This project uses Docker Compose V2 syntax (with spaces)**
>
> If you have the older standalone `docker-compose` installed, please upgrade to Docker Desktop or Docker 20.10+
# Option 2: Use docker compose directly
docker compose up -d --build
```
#### Step 3: Access Dashboard
Open your browser and visit: **http://localhost:3000**
**That's it! ๐** Your AI trading system is now running!
#### Manage Your System
```bash
./start.sh logs # View logs
./start.sh status # Check status
./start.sh stop # Stop services
./start.sh restart # Restart services
```
**๐ For detailed Docker deployment guide, troubleshooting, and advanced configuration:**
- **English**: See [DOCKER_DEPLOY.en.md](DOCKER_DEPLOY.en.md)
- **ไธญๆ**: ๆฅ็ [DOCKER_DEPLOY.md](DOCKER_DEPLOY.md)
---
### ๐ฆ Option B: Manual Installation (For Developers)
**Note**: If you used Docker deployment above, skip this section. Manual installation is only needed if you want to modify the code or run without Docker.
### 1. Environment Requirements
- **Go 1.21+**
- **Node.js 18+**
- **TA-Lib** library (technical indicator calculation)
#### Installing TA-Lib
**macOS:**
```bash
brew install ta-lib
```
**Ubuntu/Debian:**
```bash
sudo apt-get install libta-lib0-dev
```
**Other systems**: Refer to [TA-Lib Official Documentation](https://github.com/markcheno/go-talib)
### 2. Clone the Project
```bash
git clone https://github.com/tinkle-community/nofx.git
cd nofx
```
### 3. Install Dependencies
**Backend:**
```bash
go mod download
```
**Frontend:**
```bash
cd web
npm install
cd ..
```
### 4. Get AI API Keys
Before configuring the system, you need to obtain AI API keys. Choose one of the following AI providers:
#### Option 1: DeepSeek (Recommended for Beginners)
**Why DeepSeek?**
- ๐ฐ Cheaper than GPT-4 (about 1/10 the cost)
- ๐ Fast response time
- ๐ฏ Excellent trading decision quality
- ๐ Works globally without VPN
**How to get DeepSeek API Key:**
1. **Visit**: [https://platform.deepseek.com](https://platform.deepseek.com)
2. **Register**: Sign up with email/phone number
3. **Verify**: Complete email/phone verification
4. **Top-up**: Add credits to your account
- Minimum: ~$5 USD
- Recommended: $20-50 USD for testing
5. **Create API Key**:
- Go to API Keys section
- Click "Create New Key"
- Copy and save the key (starts with `sk-`)
- โ ๏ธ **Important**: Save it immediately - you can't see it again!
**Pricing**: ~$0.14 per 1M tokens (very cheap!)
#### Option 2: Qwen (Alibaba Cloud)
**How to get Qwen API Key:**
1. **Visit**: [https://dashscope.aliyuncs.com](https://dashscope.aliyuncs.com)
2. **Register**: Sign up with Alibaba Cloud account
3. **Enable Service**: Activate DashScope service
4. **Create API Key**:
- Go to API Key Management
- Create new key
- Copy and save (starts with `sk-`)
**Note**: May require Chinese phone number for registration
---
### 5. System Configuration
**Two configuration modes available:**
- **๐ Beginner Mode**: Single trader + default coins (recommended!)
- **โ๏ธ Expert Mode**: Multiple traders competition
#### ๐ Beginner Mode Configuration (Recommended)
**Step 1**: Copy and rename the example config file
```bash
cp config.json.example config.json
```
**Step 2**: Edit `config.json` with your API keys
```json
{
"traders": [
{
"id": "my_trader",
"name": "My AI Trader",
"ai_model": "deepseek",
"binance_api_key": "YOUR_BINANCE_API_KEY",
"binance_secret_key": "YOUR_BINANCE_SECRET_KEY",
"use_qwen": false,
"deepseek_key": "sk-xxxxxxxxxxxxx",
"qwen_key": "",
"initial_balance": 1000.0,
"scan_interval_minutes": 3
}
],
"leverage": {
"btc_eth_leverage": 5,
"altcoin_leverage": 5
},
"use_default_coins": true,
"coin_pool_api_url": "",
"oi_top_api_url": "",
"api_server_port": 8080
}
```
**Step 3**: Replace placeholders with your actual keys
| Placeholder | Replace With | Where to Get |
|------------|--------------|--------------|
| `YOUR_BINANCE_API_KEY` | Your Binance API Key | Binance โ Account โ API Management |
| `YOUR_BINANCE_SECRET_KEY` | Your Binance Secret Key | Same as above |
| `sk-xxxxxxxxxxxxx` | Your DeepSeek API Key | [platform.deepseek.com](https://platform.deepseek.com) |
**Step 4**: Adjust initial balance (optional)
- `initial_balance`: Set to your actual Binance futures account balance
- Used to calculate profit/loss percentage
- Example: If you have 500 USDT, set `"initial_balance": 500.0`
**โ
Configuration Checklist:**
- [ ] Binance API key filled in (no quotes issues)
- [ ] Binance Secret key filled in (no quotes issues)
- [ ] DeepSeek API key filled in (starts with `sk-`)
- [ ] `use_default_coins` set to `true` (for beginners)
- [ ] `initial_balance` matches your account balance
- [ ] File saved as `config.json` (not `.example`)
---
#### ๐ท Alternative: Using Hyperliquid Exchange
**NOFX also supports Hyperliquid** - a decentralized perpetual futures exchange. To use Hyperliquid instead of Binance:
**Step 1**: Get your Ethereum private key (for Hyperliquid authentication)
1. Open **MetaMask** (or any Ethereum wallet)
2. Export your private key
3. **Remove the `0x` prefix** from the key
4. Fund your wallet on [Hyperliquid](https://hyperliquid.xyz)
**Step 2**: Configure `config.json` for Hyperliquid
```json
{
"traders": [
{
"id": "hyperliquid_trader",
"name": "My Hyperliquid Trader",
"enabled": true,
"ai_model": "deepseek",
"exchange": "hyperliquid",
"hyperliquid_private_key": "your_private_key_without_0x",
"hyperliquid_wallet_addr": "your_ethereum_address",
"hyperliquid_testnet": false,
"deepseek_key": "sk-xxxxxxxxxxxxx",
"initial_balance": 1000.0,
"scan_interval_minutes": 3
}
],
"use_default_coins": true,
"api_server_port": 8080
}
```
**Key Differences from Binance Config:**
- Replace `binance_api_key` + `binance_secret_key` with `hyperliquid_private_key`
- Add `"exchange": "hyperliquid"` field
- Set `hyperliquid_testnet: false` for mainnet (or `true` for testnet)
**โ ๏ธ Security Warning**: Never share your private key! Use a dedicated wallet for trading, not your main wallet.
---
#### ๐ถ Alternative: Using Aster DEX Exchange
**NOFX also supports Aster DEX** - a Binance-compatible decentralized perpetual futures exchange!
**Why Choose Aster?**
- ๐ฏ Binance-compatible API (easy migration)
- ๐ API Wallet security system
- ๐ฐ Lower trading fees
- ๐ Multi-chain support (ETH, BSC, Polygon)
- ๐ No KYC required
**Step 1**: Create Aster API Wallet
1. Visit [Aster API Wallet](https://www.asterdex.com/en/api-wallet)
2. Connect your main wallet (MetaMask, WalletConnect, etc.)
3. Click "Create API Wallet"
4. **Save these 3 items immediately:**
- Main Wallet address (User)
- API Wallet address (Signer)
- API Wallet Private Key (โ ๏ธ shown only once!)
**Step 2**: Configure `config.json` for Aster
```json
{
"traders": [
{
"id": "aster_deepseek",
"name": "Aster DeepSeek Trader",
"enabled": true,
"ai_model": "deepseek",
"exchange": "aster",
"aster_user": "0x63DD5aCC6b1aa0f563956C0e534DD30B6dcF7C4e",
"aster_signer": "0x21cF8Ae13Bb72632562c6Fff438652Ba1a151bb0",
"aster_private_key": "4fd0a42218f3eae43a6ce26d22544e986139a01e5b34a62db53757ffca81bae1",
"deepseek_key": "sk-xxxxxxxxxxxxx",
"initial_balance": 1000.0,
"scan_interval_minutes": 3
}
],
"use_default_coins": true,
"api_server_port": 8080,
"leverage": {
"btc_eth_leverage": 5,
"altcoin_leverage": 5
}
}
```
**Key Configuration Fields:**
- `"exchange": "aster"` - Set exchange to Aster
- `aster_user` - Your main wallet address
- `aster_signer` - API wallet address (from Step 1)
- `aster_private_key` - API wallet private key (without `0x` prefix)
**๐ For detailed setup instructions, see**: [Aster Integration Guide](ASTER_INTEGRATION.md)
**โ ๏ธ Security Notes**:
- API wallet is separate from your main wallet (extra security layer)
- Never share your API private key
- You can revoke API wallet access anytime at [asterdex.com](https://www.asterdex.com/en/api-wallet)
---
#### โ๏ธ Expert Mode: Multi-Trader Competition
For running multiple AI traders competing against each other:
```json
{
"traders": [
{
"id": "qwen_trader",
"name": "Qwen AI Trader",
"ai_model": "qwen",
"binance_api_key": "YOUR_BINANCE_API_KEY_1",
"binance_secret_key": "YOUR_BINANCE_SECRET_KEY_1",
"use_qwen": true,
"qwen_key": "sk-xxxxx",
"deepseek_key": "",
"initial_balance": 1000.0,
"scan_interval_minutes": 3
},
{
"id": "deepseek_trader",
"name": "DeepSeek AI Trader",
"ai_model": "deepseek",
"binance_api_key": "YOUR_BINANCE_API_KEY_2",
"binance_secret_key": "YOUR_BINANCE_SECRET_KEY_2",
"use_qwen": false,
"qwen_key": "",
"deepseek_key": "sk-xxxxx",
"initial_balance": 1000.0,
"scan_interval_minutes": 3
}
],
"use_default_coins": true,
"coin_pool_api_url": "",
"oi_top_api_url": "",
"api_server_port": 8080
}
```
**Requirements for Competition Mode:**
- 2 separate Binance futures accounts (different API keys)
- Both AI API keys (Qwen + DeepSeek)
- More capital for testing (recommended: 500+ USDT per account)
---
#### ๐ Configuration Field Explanations
| Field | Description | Example Value | Required? |
|-------|-------------|---------------|-----------|
| `id` | Unique identifier for this trader | `"my_trader"` | โ
Yes |
| `name` | Display name | `"My AI Trader"` | โ
Yes |
| `enabled` | Whether this trader is enabled
Set to `false` to skip startup | `true` or `false` | โ
Yes |
| `ai_model` | AI provider to use | `"deepseek"` or `"qwen"` or `"custom"` | โ
Yes |
| `exchange` | Exchange to use | `"binance"` or `"hyperliquid"` or `"aster"` | โ
Yes |
| `binance_api_key` | Binance API key | `"abc123..."` | Required when using Binance |
| `binance_secret_key` | Binance Secret key | `"xyz789..."` | Required when using Binance |
| `hyperliquid_private_key` | Hyperliquid private key
โ ๏ธ Remove `0x` prefix | `"your_key..."` | Required when using Hyperliquid |
| `hyperliquid_wallet_addr` | Hyperliquid wallet address | `"0xabc..."` | Required when using Hyperliquid |
| `hyperliquid_testnet` | Use testnet | `true` or `false` | โ No (defaults to false) |
| `use_qwen` | Whether to use Qwen | `true` or `false` | โ
Yes |
| `deepseek_key` | DeepSeek API key | `"sk-xxx"` | If using DeepSeek |
| `qwen_key` | Qwen API key | `"sk-xxx"` | If using Qwen |
| `initial_balance` | Starting balance for P/L calculation | `1000.0` | โ
Yes |
| `scan_interval_minutes` | How often to make decisions | `3` (3-5 recommended) | โ
Yes |
| **`leverage`** | **Leverage configuration (v2.0.3+)** | See below | โ
Yes |
| `btc_eth_leverage` | Maximum leverage for BTC/ETH
โ ๏ธ Subaccounts: โค5x | `5` (default, safe)
`50` (main account max) | โ
Yes |
| `altcoin_leverage` | Maximum leverage for altcoins
โ ๏ธ Subaccounts: โค5x | `5` (default, safe)
`20` (main account max) | โ
Yes |
| `use_default_coins` | Use built-in coin list
**โจ Smart Default: `true`** (v2.0.2+)
Auto-enabled if no API URL provided | `true` or omit | โ No
(Optional, auto-defaults) |
| `coin_pool_api_url` | Custom coin pool API
*Only needed when `use_default_coins: false`* | `""` (empty) | โ No |
| `oi_top_api_url` | Open interest API
*Optional supplement data* | `""` (empty) | โ No |
| `api_server_port` | Web dashboard port | `8080` | โ
Yes |
**Default Trading Coins** (when `use_default_coins: true`):
- BTC, ETH, SOL, BNB, XRP, DOGE, ADA, HYPE
---
#### โ๏ธ Leverage Configuration (v2.0.3+)
**What is leverage configuration?**
The leverage settings control the maximum leverage the AI can use for each trade. This is crucial for risk management, especially for Binance subaccounts which have leverage restrictions.
**Configuration format:**
```json
"leverage": {
"btc_eth_leverage": 5, // Maximum leverage for BTC and ETH
"altcoin_leverage": 5 // Maximum leverage for all other coins
}
```
**โ ๏ธ Important: Binance Subaccount Restrictions**
- **Subaccounts**: Limited to **โค5x leverage** by Binance
- **Main accounts**: Can use up to 20x (altcoins) or 50x (BTC/ETH)
- If you're using a subaccount and set leverage >5x, trades will **fail** with error: `Subaccounts are restricted from using leverage greater than 5x`
**Recommended settings:**
| Account Type | BTC/ETH Leverage | Altcoin Leverage | Risk Level |
|-------------|------------------|------------------|------------|
| **Subaccount** | `5` | `5` | โ
Safe (default) |
| **Main (Conservative)** | `10` | `10` | ๐ก Medium |
| **Main (Aggressive)** | `20` | `15` | ๐ด High |
| **Main (Maximum)** | `50` | `20` | ๐ด๐ด Very High |
**Examples:**
**Safe configuration (subaccount or conservative):**
```json
"leverage": {
"btc_eth_leverage": 5,
"altcoin_leverage": 5
}
```
**Aggressive configuration (main account only):**
```json
"leverage": {
"btc_eth_leverage": 20,
"altcoin_leverage": 15
}
```
**How AI uses leverage:**
- AI can choose **any leverage from 1x up to your configured maximum**
- For example, with `altcoin_leverage: 20`, AI might decide to use 5x, 10x, or 20x based on market conditions
- The configuration sets the **upper limit**, not a fixed value
- AI considers volatility, risk-reward ratio, and account balance when choosing leverage
---
#### โ ๏ธ Important: `use_default_coins` Field
**Smart Default Behavior (v2.0.2+):**
The system now automatically defaults to `use_default_coins: true` if:
- You don't include this field in config.json, OR
- You set it to `false` but don't provide `coin_pool_api_url`
This makes it beginner-friendly! You can even omit this field entirely.
**Configuration Examples:**
โ
**Option 1: Explicitly set (Recommended for clarity)**
```json
"use_default_coins": true,
"coin_pool_api_url": "",
"oi_top_api_url": ""
```
โ
**Option 2: Omit the field (uses default coins automatically)**
```json
// Just don't include "use_default_coins" at all
"coin_pool_api_url": "",
"oi_top_api_url": ""
```
โ๏ธ **Advanced: Use external API**
```json
"use_default_coins": false,
"coin_pool_api_url": "http://your-api.com/coins",
"oi_top_api_url": "http://your-api.com/oi"
```
---
### 6. Run the System
#### ๐ Starting the System (2 steps)
The system has **2 parts** that run separately:
1. **Backend** (AI trading brain + API)
2. **Frontend** (Web dashboard for monitoring)
---
#### **Step 1: Start the Backend**
Open a terminal and run:
```bash
# Build the program (first time only, or after code changes)
go build -o nofx
# Start the backend
./nofx
```
**What you should see:**
```
๐ ๅฏๅจ่ชๅจไบคๆ็ณป็ป...
โ Trader [my_trader] ๅทฒๅๅงๅ
โ APIๆๅกๅจๅฏๅจๅจ็ซฏๅฃ 8080
๐ ๅผๅงไบคๆ็ๆง...
```
**โ ๏ธ If you see errors:**
| Error Message | Solution |
|--------------|----------|
| `invalid API key` | Check your Binance API key in config.json |
| `TA-Lib not found` | Run `brew install ta-lib` (macOS) |
| `port 8080 already in use` | Change `api_server_port` in config.json |
| `DeepSeek API error` | Verify your DeepSeek API key and balance |
**โ
Backend is running correctly when you see:**
- No error messages
- "ๅผๅงไบคๆ็ๆง..." appears
- System shows account balance
- Keep this terminal window open!
---
#### **Step 2: Start the Frontend**
Open a **NEW terminal window** (keep the first one running!), then:
```bash
cd web
npm run dev
```
**What you should see:**
```
VITE v5.x.x ready in xxx ms
โ Local: http://localhost:3000/
โ Network: use --host to expose
```
**โ
Frontend is running when you see:**
- "Local: http://localhost:3000/" message
- No error messages
- Keep this terminal window open too!
---
#### **Step 3: Access the Dashboard**
Open your web browser and visit:
**๐ http://localhost:3000**
**What you'll see:**
- ๐ Real-time account balance
- ๐ Open positions (if any)
- ๐ค AI decision logs
- ๐ Equity curve chart
**First-time tips:**
- It may take 3-5 minutes for the first AI decision
- Initial decisions might say "่งๆ" (wait) - this is normal
- AI needs to analyze market conditions first
---
### 7. Monitor the System
**What to watch:**
โ
**Healthy System Signs:**
- Backend terminal shows decision cycles every 3-5 minutes
- No continuous error messages
- Account balance updates
- Web dashboard refreshes automatically
โ ๏ธ **Warning Signs:**
- Repeated API errors
- No decisions for 10+ minutes
- Balance decreasing rapidly
**Checking System Status:**
```bash
# In a new terminal window
curl http://localhost:8080/health
```
Should return: `{"status":"ok"}`
---
### 8. Stop the System
**Graceful Shutdown (Recommended):**
1. Go to the **backend terminal** (the first one)
2. Press `Ctrl+C`
3. Wait for "็ณป็ปๅทฒๅๆญข" message
4. Go to the **frontend terminal** (the second one)
5. Press `Ctrl+C`
**โ ๏ธ Important:**
- Always stop the backend first
- Wait for confirmation before closing terminals
- Don't force quit (don't close terminal directly)
---
## ๐ AI Decision Flow
Each decision cycle (default 3 minutes), the system executes the following intelligent process:
```
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ 1. ๐ Analyze Historical Performance (last 20 cycles) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ โ Calculate overall win rate, avg profit, P/L ratio โ
โ โ Per-coin statistics (win rate, avg P/L in USDT) โ
โ โ Identify best/worst performing coins โ
โ โ List last 5 trade details with accurate PnL โ
โ โ Calculate Sharpe ratio for risk-adjusted performance โ
โ ๐ NEW (v2.0.2): Accurate USDT PnL with leverage โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ 2. ๐ฐ Get Account Status โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ โข Total equity & available balance โ
โ โข Number of open positions & unrealized P/L โ
โ โข Margin usage rate (AI manages up to 90%) โ
โ โข Daily P/L tracking & drawdown monitoring โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ 3. ๐ Analyze Existing Positions (if any) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ โข For each position, fetch latest market data โ
โ โข Calculate real-time technical indicators: โ
โ - 3min K-line: RSI(7), MACD, EMA20 โ
โ - 4hour K-line: RSI(14), EMA20/50, ATR โ
โ โข Track position holding duration (e.g., "2h 15min") โ
โ ๐ NEW (v2.0.2): Shows how long each position held โ
โ โข Display: Entry price, current price, P/L%, duration โ
โ โข AI evaluates: Should hold or close? โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ 4. ๐ฏ Evaluate New Opportunities (candidate coins) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ โข Fetch coin pool (2 modes): โ
โ ๐ Default Mode: BTC, ETH, SOL, BNB, XRP, etc. โ
โ โ๏ธ Advanced Mode: AI500 (top 20) + OI Top (top 20) โ
โ โข Merge & deduplicate candidate coins โ
โ โข Filter: Remove low liquidity (<15M USD OI value) โ
โ โข Batch fetch market data + technical indicators โ
โ โข Calculate volatility, trend strength, volume surge โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ 5. ๐ง AI Comprehensive Decision (DeepSeek/Qwen) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ โข Review historical feedback: โ
โ - Recent win rate & profit factor โ
โ - Best/worst coins performance โ
โ - Avoid repeating mistakes โ
โ โข Analyze all raw sequence data: โ
โ - 3min priceๅบๅ, 4hour K-lineๅบๅ โ
โ - Complete indicator sequences (not just latest) โ
โ ๐ NEW (v2.0.2): AI has full freedom to analyze โ
โ โข Chain of Thought (CoT) reasoning process โ
โ โข Output structured decisions: โ
โ - Action: close_long/close_short/open_long/open_shortโ
โ - Coin symbol, quantity, leverage โ
โ - Stop-loss & take-profit levels (โฅ1:2 ratio) โ
โ โข Decision: Wait/Hold/Close/Open โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ 6. โก Execute Trades โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ โข Priority order: Close existing โ Then open new โ
โ โข Risk checks before execution: โ
โ - Position size limits (1.5x for altcoins, 10x BTC) โ
โ - No duplicate positions (same coin + direction) โ
โ - Margin usage within 90% limit โ
โ โข Auto-fetch & apply Binance LOT_SIZE precision โ
โ โข Execute orders via Binance Futures API โ
โ โข After closing: Auto-cancel all pending orders โ
โ โข Record actual execution price & order ID โ
โ ๐ Track position open time for duration calculation โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ 7. ๐ Record Complete Logs & Update Performance โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโค
โ โข Save decision log to decision_logs/{trader_id}/ โ
โ โข Log includes: โ
โ - Complete Chain of Thought (CoT) โ
โ - Input prompt with all market data โ
โ - Structured decision JSON โ
โ - Account snapshot (balance, positions, margin) โ
โ - Execution results (success/failure, prices) โ
โ โข Update performance database: โ
โ - Match open/close pairs by symbol_side key โ
โ ๐ NEW: Prevents long/short conflicts โ
โ - Calculate accurate USDT PnL: โ
โ PnL = Position Value ร Price ฮ% ร Leverage โ
โ ๐ NEW: Considers quantity + leverage โ
โ - Store: quantity, leverage, open time, close time โ
โ - Update win rate, profit factor, Sharpe ratio โ
โ โข Performance data feeds back into next cycle โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
(Repeat every 3-5 min)
```
### Key Improvements in v2.0.2
**๐ Position Duration Tracking:**
- System now tracks how long each position has been held
- Displayed in user prompt: "ๆไปๆถ้ฟ2ๅฐๆถ15ๅ้"
- Helps AI make better decisions on when to exit
**๐ Accurate PnL Calculation:**
- Previously: Only percentage (100U@5% = 1000U@5% = both showed "5.0")
- Now: Real USDT profit = Position Value ร Price Change ร Leverage
- Example: 1000 USDT ร 5% ร 20x = 1000 USDT actual profit
**๐ Enhanced AI Freedom:**
- AI can freely analyze all raw sequence data
- No longer restricted to predefined indicator combinations
- Can perform own trend analysis, support/resistance calculation
**๐ Improved Position Tracking:**
- Uses `symbol_side` key (e.g., "BTCUSDT_long")
- Prevents conflicts when holding both long & short
- Stores complete data: quantity, leverage, open/close times
---
## ๐ง AI Self-Learning Example
### Historical Feedback (Auto-added to Prompt)
```markdown
## ๐ Historical Performance Feedback
### Overall Performance
- **Total Trades**: 15 (Profit: 8 | Loss: 7)
- **Win Rate**: 53.3%
- **Average Profit**: +3.2% | Average Loss: -2.1%
- **Profit/Loss Ratio**: 1.52:1
### Recent Trades
1. BTCUSDT LONG: 95000.0000 โ 97500.0000 = +2.63% โ
2. ETHUSDT SHORT: 3500.0000 โ 3450.0000 = +1.43% โ
3. SOLUSDT LONG: 185.0000 โ 180.0000 = -2.70% โ
4. BNBUSDT LONG: 610.0000 โ 625.0000 = +2.46% โ
5. ADAUSDT LONG: 0.8500 โ 0.8300 = -2.35% โ
### Coin Performance
- **Best**: BTCUSDT (Win rate 75%, avg +2.5%)
- **Worst**: SOLUSDT (Win rate 25%, avg -1.8%)
```
### How AI Uses Feedback
1. **Avoid consecutive losers**: Seeing SOLUSDT with 3 consecutive stop-losses, AI avoids or is more cautious
2. **Reinforce successful strategies**: BTC breakout long with 75% win rate, AI continues this pattern
3. **Dynamic style adjustment**: Win rate <40% โ conservative; P/L ratio >2 โ maintain aggressive
4. **Identify market conditions**: Consecutive losses may indicate choppy market, reduce trading frequency
---
## ๐ Web Interface Features
### 1. Competition Page
- **๐ Leaderboard**: Real-time ROI ranking, golden border highlights leader
- **๐ Performance Comparison**: Dual AI ROI curve comparison (purple vs blue)
- **โ๏ธ Head-to-Head**: Direct comparison showing lead margin
- **Real-time Data**: Total equity, P/L%, position count, margin usage
### 2. Details Page
- **Equity Curve**: Historical trend chart (USD/percentage toggle)
- **Statistics**: Total cycles, success/fail, open/close stats
- **Position Table**: All position details (entry price, current price, P/L%, liquidation price)
- **AI Decision Logs**: Recent decision records (expandable CoT)
### 3. Real-time Updates
- System status, account info, position list: **5-second refresh**
- Decision logs, statistics: **10-second refresh**
- Equity charts: **10-second refresh**
---
## ๐๏ธ API Endpoints
### Competition Related
```bash
GET /api/competition # Competition leaderboard (all traders)
GET /api/traders # Trader list
```
### Single Trader Related
```bash
GET /api/status?trader_id=xxx # System status
GET /api/account?trader_id=xxx # Account info
GET /api/positions?trader_id=xxx # Position list
GET /api/equity-history?trader_id=xxx # Equity history (chart data)
GET /api/decisions/latest?trader_id=xxx # Latest 5 decisions
GET /api/statistics?trader_id=xxx # Statistics
```
### System Endpoints
```bash
GET /health # Health check
GET /api/config # System configuration
```
---
## โ ๏ธ Important Risk Warnings
### Trading Risks
1. **Cryptocurrency markets are extremely volatile**, AI decisions don't guarantee profit
2. **Futures trading uses leverage**, losses may exceed principal
3. **Extreme market conditions** may lead to liquidation risk
4. **Funding rates** may affect holding costs
5. **Liquidity risk**: Some coins may experience slippage
### Technical Risks
1. **Network latency** may cause price slippage
2. **API rate limits** may affect trade execution
3. **AI API timeouts** may cause decision failures
4. **System bugs** may trigger unexpected behavior
### Usage Recommendations
โ
**Recommended**
- Use only funds you can afford to lose for testing
- Start with small amounts (recommended 100-500 USDT)
- Regularly check system operation status
- Monitor account balance changes
- Analyze AI decision logs to understand strategy
โ **Not Recommended**
- Invest all funds or borrowed money
- Run unsupervised for long periods
- Blindly trust AI decisions
- Use without understanding the system
- Run during extreme market volatility
---
## ๐ ๏ธ Common Issues
### 1. Compilation error: TA-Lib not found
**Solution**: Install TA-Lib library
```bash
# macOS
brew install ta-lib
# Ubuntu
sudo apt-get install libta-lib0-dev
```
### 2. Precision error: Precision is over the maximum
**Solution**: System auto-handles precision from Binance LOT_SIZE. If error persists, check network connection.
### 3. AI API timeout
**Solution**:
- Check if API key is correct
- Check network connection (may need proxy)
- System timeout is set to 120 seconds
### 4. Frontend can't connect to backend
**Solution**:
- Ensure backend is running (http://localhost:8080)
- Check if port 8080 is occupied
- Check browser console for errors
### 5. Coin pool API failure
**Solution**:
- Coin pool API is optional
- If API fails, system uses default mainstream coins (BTC, ETH, etc.)
- Check API URL and auth parameter in config.json
---
## ๐ Performance Optimization Tips
1. **Set reasonable decision cycle**: Recommended 3-5 minutes, avoid over-trading
2. **Control candidate coin count**: System defaults to AI500 top 20 + OI Top top 20
3. **Regularly clean logs**: Avoid excessive disk usage
4. **Monitor API call count**: Avoid triggering Binance rate limits
5. **Test with small capital**: First test with 100-500 USDT for strategy validation
---
## ๐ Changelog
### v2.0.2 (2025-10-29)
**Critical Bug Fixes - Trade History & Performance Analysis:**
This version fixes **critical calculation errors** in the historical trade record and performance analysis system that significantly affected profitability statistics.
**1. PnL Calculation - Major Error Fixed** (logger/decision_logger.go)
- **Problem**: Previously calculated PnL as percentage only, completely ignoring position size and leverage
- Example: 100 USDT position earning 5% and 1000 USDT position earning 5% both showed `5.0` as profit
- This made performance analysis completely inaccurate
- **Solution**: Now calculates actual USDT profit amount
```
PnL (USDT) = Position Value ร Price Change % ร Leverage
Example: 1000 USDT ร 5% ร 20x = 1000 USDT actual profit
```
- **Impact**: Win rate, profit factor, and Sharpe ratio now based on accurate USDT amounts
**2. Position Tracking - Missing Critical Data**
- **Problem**: Open position records only stored price and time, missing quantity and leverage
- **Solution**: Now stores complete trade data:
- `quantity`: Position size (in coins)
- `leverage`: Leverage multiplier (e.g., 20x)
- These are essential for accurate PnL calculations
**3. Position Key Logic - Long/Short Conflict**
- **Problem**: Used `symbol` as position key, causing data conflicts when holding both long and short
- Example: BTCUSDT long and BTCUSDT short would overwrite each other
- **Solution**: Changed to `symbol_side` format (e.g., `BTCUSDT_long`, `BTCUSDT_short`)
- Now properly distinguishes between long and short positions
**4. Sharpe Ratio Calculation - Code Optimization**
- **Problem**: Used custom Newton's method for square root calculation
- **Solution**: Replaced with standard library `math.Sqrt`
- More reliable, maintainable, and efficient
**Why This Update Matters:**
- โ
Historical trade statistics now show **real USDT profit/loss** instead of meaningless percentages
- โ
Performance comparison between different leverage trades is now accurate
- โ
AI self-learning mechanism receives correct historical feedback
- โ
Profit factor and Sharpe ratio calculations are now meaningful
- โ
Multi-position tracking (long + short simultaneously) works correctly
**Recommendation**: If you were running the system before this update, your historical statistics were inaccurate. After updating to v2.0.2, new trades will be calculated correctly.
### v2.0.2 (2025-10-29)
**Bug Fixes:**
- โ
Fixed Aster exchange precision error (code -1111: "Precision is over the maximum defined for this asset")
- โ
Improved price and quantity formatting to match exchange precision requirements
- โ
Added detailed precision processing logs for debugging
- โ
Enhanced all order functions (OpenLong, OpenShort, CloseLong, CloseShort, SetStopLoss, SetTakeProfit) with proper precision handling
**Technical Details:**
- Added `formatFloatWithPrecision` function to convert float64 to strings with correct precision
- Price and quantity parameters are now formatted according to exchange's `pricePrecision` and `quantityPrecision` specifications
- Trailing zeros are removed from formatted values to optimize API requests
### v2.0.1 (2025-10-29)
**Bug Fixes:**
- โ
Fixed ComparisonChart data processing logic - switched from cycle_number to timestamp grouping
- โ
Resolved chart freezing issue when backend restarts and cycle_number resets
- โ
Improved chart data display - now shows all historical data points chronologically
- โ
Enhanced debugging logs for better troubleshooting
### v2.0.0 (2025-10-28)
**Major Updates:**
- โ
AI self-learning mechanism (historical feedback, performance analysis)
- โ
Multi-trader competition mode (Qwen vs DeepSeek)
- โ
Binance-style UI (complete Binance interface imitation)
- โ
Performance comparison charts (real-time ROI comparison)
- โ
Risk control optimization (per-coin position limit adjustment)
**Bug Fixes:**
- Fixed hardcoded initial balance issue
- Fixed multi-trader data sync issue
- Optimized chart data alignment (using cycle_number)
### v1.0.0 (2025-10-27)
- Initial release
- Basic AI trading functionality
- Decision logging system
- Simple Web interface
---
## ๐ License
MIT License - See [LICENSE](LICENSE) file for details
---
## ๐ค Contributing
Issues and Pull Requests are welcome!
### Development Guide
1. Fork the project
2. Create feature branch (`git checkout -b feature/AmazingFeature`)
3. Commit changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to branch (`git push origin feature/AmazingFeature`)
5. Open Pull Request
---
## ๐ฌ Contact & Business Inquiries
### ๐ผ Investment & Fundraising
We are currently raising our **seed round**. For investment opportunities:
- **Contact**: Zack (Market & Fundraising Lead)
- **Twitter/X**: *[To be filled]*
### ๐ค Business Partnerships & Technical Collaborations
For strategic partnerships and developer collaborations:
- **Contact**: Tinkle (Technology Lead)
- **Twitter/X**: [@Web3Tinkle](https://x.com/Web3Tinkle)
### ๐ Technical Support
- **GitHub Issues**: [Submit an Issue](https://github.com/tinkle-community/nofx/issues)
- **Developer Community**: [Telegram Group](https://t.me/nofx_dev_community)
---
## ๐ Acknowledgments
- [Binance API](https://binance-docs.github.io/apidocs/futures/en/) - Binance Futures API
- [DeepSeek](https://platform.deepseek.com/) - DeepSeek AI API
- [Qwen](https://dashscope.aliyuncs.com/) - Alibaba Cloud Qwen
- [TA-Lib](https://ta-lib.org/) - Technical indicator library
- [Recharts](https://recharts.org/) - React chart library
---
**Last Updated**: 2025-10-29 (v2.0.3)
**โก Explore the possibilities of quantitative trading with the power of AI!**
---
## โญ Star History
[](https://star-history.com/#tinkle-community/nofx&Date)