当前位置: 首页 > news >正文

【golang】量化开发学习(一)

均值回归策略简介

均值回归(Mean Reversion)假设价格会围绕均值波动,当价格偏离均值一定程度后,会回归到均值。
基本逻辑

  1. 计算一段时间内的移动均值(如 20 天均线)。
  2. 当当前价格高于均值一定比例,做空;当低于均值一定比例,做多。
  3. 持仓等待价格回归后平仓。


官网下载DOLGPHINDB 


总结

Docker 运行 DolphinDB
创建模拟股票数据表
Golang 连接 DolphinDB 进行查询

这样,Golang 代码就可以直接获取数据并进行回测了 🚀!如果需要更复杂的 数据流实时计算,可以考虑 DolphinDB 的 流式表(stream table)

📝 Golang 实现均值回归策略

📌 主要步骤

  • 从 DolphinDB 获取历史数据(收盘价)
  • 计算 n 日移动均值
  • 生成交易信号
  • 计算策略回测收益

🔧 代码

以下 Golang 代码:

  1. 连接 DolphinDB 获取数据
  2. 计算 20 日均线
  3. 执行简单的回测
 
package mainimport ("fmt""log""math""net/http""strings""encoding/json""io/ioutil"
)// DolphinDB 查询 URL(根据你的服务器 IP 修改)
const ddbURL = "http://your-dolphindb-server:8848/execute"var (n       = 20 // 均线周期threshold = 0.02 // 2% 偏差阈值capital   = 100000.0 // 初始资金
)// 查询 DolphinDB 数据
func fetchDolphinDBData(symbol string) ([]float64, error) {query := fmt.Sprintf(`select close from stock_data where symbol="%s" order by date;`, symbol)resp, err := http.Post(ddbURL, "text/plain", strings.NewReader(query))if err != nil {return nil, err}defer resp.Body.Close()body, _ := ioutil.ReadAll(resp.Body)var result map[string]interface{}json.Unmarshal(body, &result)closePrices := []float64{}if values, ok := result["close"].([]interface{}); ok {for _, v := range values {closePrices = append(closePrices, v.(float64))}}return closePrices, nil
}// 计算 n 日均线
func movingAverage(prices []float64, period int) []float64 {ma := make([]float64, len(prices))var sum float64for i := range prices {if i < period {ma[i] = math.NaN()} else {sum = 0for j := 0; j < period; j++ {sum += prices[i-j]}ma[i] = sum / float64(period)}}return ma
}// 进行回测
func backtest(prices, ma []float64) float64 {position := 0balance := capitalfor i := n; i < len(prices); i++ {price := prices[i]if math.IsNaN(ma[i]) {continue}// 交易信号if price < ma[i]*(1-threshold) && position == 0 { // 买入position = int(balance / price)balance -= float64(position) * pricefmt.Printf("买入 %d 股, 价格: %.2f, 资金: %.2f\n", position, price, balance)} else if price > ma[i]*(1+threshold) && position > 0 { // 卖出balance += float64(position) * pricefmt.Printf("卖出 %d 股, 价格: %.2f, 资金: %.2f\n", position, price, balance)position = 0}}// 最后清仓if position > 0 {balance += float64(position) * prices[len(prices)-1]}return balance
}func main() {symbol := "AAPL"prices, err := fetchDolphinDBData(symbol)if err != nil {log.Fatalf("获取数据失败: %v", err)}ma := movingAverage(prices, n)finalBalance := backtest(prices, ma)fmt.Printf("策略最终资金: %.2f\n", finalBalance)
}

📌 代码解析

  1. 连接 DolphinDB
    • fetchDolphinDBData() 发送 HTTP 请求获取数据(你需要修改数据库 IP)
    • DolphinDB 返回 close 价格数据
  2. 计算移动均线
    • movingAverage() 计算 n 天均线
  3. 交易逻辑
    • 当价格比均线低 2%,买入
    • 当价格比均线高 2%,卖出
    • backtest() 模拟资金变化
  4. 打印回测结果
    • 资金增减情况
    • 最终资金
http://www.lryc.cn/news/536026.html

相关文章:

  • AI前端开发:跨领域合作的新引擎
  • 数组练习(深入理解、实践数组)
  • Bigemap Pro如何进行面裁剪
  • acwing算法全总结-数学知识
  • SpringMVC学习使用
  • 10、《文件上传与下载:MultipartFile与断点续传设计》
  • DeepSeek 本地部署(电脑安装)
  • DeepSeek、Kimi、文心一言、通义千问:AI 大语言模型的对比分析
  • Docker compose 以及镜像使用
  • HCIA项目实践--RIP相关原理知识面试问题总结回答
  • 使用Python进行云计算:AWS、Azure、和Google Cloud的比较
  • c++ 实现矩阵乘法
  • 无线4G多联机分户计费集中控制系统
  • 文字转语音(一)各种实现说明
  • 大语言模型多代理协作(MACNET)
  • 【笛卡尔树】
  • Java堆外内存的高效利用与性能优化
  • 【Unity3D优化】使用ASTC压缩格式优化内存
  • iptables网络安全服务详细使用
  • MiC建筑引领未来:中建海龙的探索与实践
  • 清华精品资料:DeepSeek从入门到精通、DeepSeek赋能职场
  • Nginx进阶篇 - nginx多进程架构详解
  • SpringBoot初始化8个常用方法
  • boolen盲注和时间盲注
  • CTF-web:java-h2 堆叠注入rec -- N1ctf Junior EasyDB
  • TUSB422 MCU 软件用户指南
  • BUU37 [DASCTF X GFCTF 2024|四月开启第一局]web1234100
  • 常见的排序算法:插入排序、选择排序、冒泡排序、快速排序
  • vue学习9
  • TDengine 性能测试工具 taosBenchmark