avatar of 发明者量化-小小梦 发明者量化-小小梦
fokus pada Pesan pribadi
4
fokus pada
1271
Pengikut

Gunakan fungsi KLineChart untuk mempermudah desain gambar strategi

Dibuat di: 2022-07-01 15:54:06, diperbarui pada: 2023-09-18 20:11:05
comments   3
hits   2617

Gunakan fungsi KLineChart untuk mempermudah desain gambar strategi

Gunakan fungsi KLineChart untuk mempermudah desain gambar strategi

Saat merancang strategi, sering kali perlu merancang tampilan bagan strategi saat menggunakan JavaScript atau Python untuk menulis strategi. Pengguna yang tidak familier dengan pemrograman atau pustaka grafik yang digunakan oleh platform FMZ kerap kali kesulitan dengan desain kode untuk menggambar grafik khusus. Jadi bagaimana kita bisa menggambar bagan strategi dengan konten yang kaya dengan hanya menulis sedikit kode?

Metode menggambar yang sederhana tetapi ampuh ini dapat dilihat dalam bahasa Pine, yang terkenal karena fungsi menggambarnya yang kaya. Jika antarmuka gambar bahasa Pine dapat dihubungkan dengan strategi bahasa JavaScript dan Python, itu akan sangat memudahkan pengembang untuk merancang fungsi gambar strategi. Berdasarkan permintaan ini, platform FMZ meningkatkan fungsi gambar kustom dan memperluas penggunaannya.KLineChartFungsi ini melakukan penggambaran bagan khusus. Anda dapat merujuk ke dokumentasi API: https://www.fmz.com/api#klinechart

Mari gunakan JavaScript untuk menulis contoh sederhana untuk membuat transisi.

Contoh Sederhana

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 30m
basePeriod: 15m
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

function main() {
    var c = KLineChart()
    while (true) {
        var bars = _C(exchange.GetRecords)
        for (var i = 0 ; i < bars.length ; i++) {
            var bar = bars[i]
            c.begin(bar)
            c.plot(bar.Volume, "volume")
            c.close()
        }
        Sleep(1000)
    }
}

Contoh ini sangat sederhana. Ia hanya menggambar grafik candlestick di area gambar kustom strategi, dan menggambar kurva volume yang sesuai dengan setiap candlestick BAR di posisi sub-grafik grafik.

Gunakan fungsi KLineChart untuk mempermudah desain gambar strategi

Dalam kode pertama kita menggunakanvar c = KLineChart()Buat objek bagan lalu panggil metodenya untuk menggambar. Kemudian dalam loop kita mendapatkan data K-line (struktur array) dan melintasi array K-line. Anda dapat menggunakan perulangan for sederhana untuk melintasi seperti pada contoh, atau Anda dapat menggunakan metode lain untuk melintasi.

Operasi menggambar harus dilakukan daric.begin(bar)Fungsinya dimulai,c.close()Fungsinya berakhir.begincloseFungsi adalah metode objek bagan c. Selanjutnya, gunakan fungsi menggambar yang paling umum digunakanplotGambarkan kurva volume pada setiap BAR.

Contoh yang lebih kompleks

Misalkan kita ingin merancang grafik dengan indikator Bollinger. Oh ya! Perlu juga melampirkan bagan volume untuk setiap BAR, yang dapat dirancang seperti ini:

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

function main() {
    var c = KLineChart()

    // 策略主循环
    while(true) {
        // 轮询间隔
        Sleep(500)
        
        // 获取K线数据
        let bars = exchange.GetRecords()
        if (!bars || bars.length <= 20) {
            continue
        }
        
        // 计算布林指标
        var boll = TA.BOLL(bars)
        
        bars.forEach(function(bar, index) {
            c.begin(bar)
            // 画图操作
            c.plot(boll[0][index], "Boll_Up", {overlay: true})     // 画在图表主图
            c.plot(boll[1][index], "Boll_Mid", {overlay: true})    // 画在图表主图
            c.plot(boll[2][index], "Boll_Down", {overlay: true})   // 画在图表主图
            c.plot(bar.Volume, "volume")                           // 画在图表副图
            c.close()
        })
    
        // 策略交易逻辑
        // ...
        // ..
    }
}

Anda dapat melihat dalam kode bahwa informasi konfigurasi backtest kami pada platform FMZ adalah:

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

Konfigurasi ini diuji ulang menggunakan objek bursa spot Binance. Hasil pengujian ulang ditunjukkan pada gambar:

Gunakan fungsi KLineChart untuk mempermudah desain gambar strategi

Dapat dilihat bahwa kami menggunakan metode menggambar Pine untuk menyederhanakan kode gambar dalam bahasa JavaScript.

Tulis indikator dan data lain untuk menggambar gambar

Operasi seperti memperoleh data K-line dan menghitung indikator adalah hal yang umum dan sangat sederhana dalam contoh strategi dan dokumen API dari kotak strategi platform.

        // 获取K线数据
        let bars = exchange.GetRecords()
        if (!bars || bars.length <= 20) {   
            // 如果获取K线失败,即!bar为真则执行continue,忽略之后的代码,重新执行循环
            // 如果bars.length小于等于20,即K线BAR(柱)数量小于20,无法计算指标,也执行continue
            continue
        }
        
        // 计算布林指标
        var boll = TA.BOLL(bars)

Fungsi perhitungan indikator Bollinger TA.BOLL, jika Anda tidak menentukan parameter indikator Bollinger, parameter default digunakanBOLL(20, 2). Indikator Bollinger memiliki tiga garis, sehingga data yang dikembalikan oleh fungsi TA.BOLL adalah array dua dimensi. buah kapas[0]、boll[1]、boll[2] adalah tiga elemen array boll, yang masing-masing mewakili garis dan merupakan array.

  • boll[[0]: Pita Bollinger Online
  • boll[1]: Garis Tengah Bollinger Bands
  • boll[2]: Bollinger Bands Turun

Kemudian kita akan melihat cara menggambar volume data garis K, yaitu volume perdagangan, dan data indikator Bollinger yang dihitung pada grafik.

Kita menggambar data garis K batang demi batang, jadi kita perlu melintasi seluruh larik garis K, yaitu melintasi larik batang dalam kode. Di sini kita menggunakanforEachTraversal metode juga dapat dilintasi menggunakan for loop.

        bars.forEach(function(bar, index) {
            c.begin(bar)
            // 画图操作
            c.plot(boll[0][index], "Boll_Up", {overlay: true})     // {overlay: true}参数控制,画在图表主图
            c.plot(boll[1][index], "Boll_Mid", {overlay: true})    // 画在图表主图
            c.plot(boll[2][index], "Boll_Down", {overlay: true})   // 画在图表主图
            c.plot(bar.Volume, "volume")                           // 画在图表副图
            c.close()
        })

Perlu dicatat bahwa setiap kali Anda mulai menggambar grafik pada batang, Anda harus terlebih dahuluc.begin(bar)Panggilan fungsi,beginFungsi adalah metode objek bagan kita c. Di akhir operasi menggambar, Anda perlu memanggilc.close(). adabeginFungsi dancloseDi antara fungsi-fungsi tersebut terdapat fungsi-fungsi menggambar yang kami sebut mirip dengan metode menggambar bahasa Pine. mendukung:barcolor bgcolor plot fill hline plotarrow plotshape plotchar plotcandle signal, Anda dapat menggambar garis, panah, menandai informasi, dll. Parameter fungsi ini konsisten dengan parameter fungsi terkait bahasa Pine, dan fungsi gambar juga konsisten.

Menambahkan panah sinyal perdagangan, penanda, garis horizontal, dan gambar lainnya

Tambahkan beberapa panah sinyal perdagangan, penanda, dan garis horizontal ke contoh gambar indikator Bollinger di atas.

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

function main() {
    var c = KLineChart()

    // 策略主循环
    while(true) {
        // 轮询间隔
        Sleep(500)
        
        // 获取K线数据
        let bars = exchange.GetRecords()
        if (!bars || bars.length <= 20) {
            continue
        }
        
        // 计算布林指标
        var boll = TA.BOLL(bars)
        
        bars.forEach(function(bar, index) {
            c.begin(bar)
            // 画图操作
            c.plot(boll[0][index], "Boll_Up", {overlay: true})     // 画在图表主图
            c.plot(boll[1][index], "Boll_Mid", {overlay: true})    // 画在图表主图
            c.plot(boll[2][index], "Boll_Down", {overlay: true})   // 画在图表主图
            c.plot(bar.Volume, "volume")                           // 画在图表副图
            
            c.hline(bar.Open, {overlay: true})                                         // 水平线
            c.plotarrow(bar.Close - bar.Open, {overlay: true})                         // 箭头
            c.plotshape(bar.Close - bar.Open > 0, {style: 'square', overlay: true})    // 画方块标记
            c.plotchar(bar.Close - bar.Open < 0, {char: '❄', size: "20px", overlay: true})           // 画出字符❄
            if (boll[0][index] && bar.Close > boll[0][index]) {
                c.signal("long", bar.Close, 1.5)
            } else if (boll[2][index] && bar.Close < boll[2][index]) {
                c.signal("closelong", bar.Close, 1.5)
            }
            
            c.close()
        })
    
        // 策略交易逻辑
        // ...
        // ..
    }
}

Gunakan fungsi KLineChart untuk mempermudah desain gambar strategi

Karena operasi order strategi bahasa Pine akan secara otomatis menandai sinyal pada grafik,KLineChartObjek grafik yang dibuat oleh fungsi ini juga diperluas dengan fungsi untuk menggambar penanda sinyal beli dan jual:c.signal

Objek konfigurasi grafik

Anda dapat mendeklarasikan struktur untuk mengonfigurasi gaya bagan. Misalnya, variabel chartCfg berikut mewakili informasi konfigurasi garis kisi.

    var chartCfg = {
        grid: {
            show: true,
            // 网格水平线
            horizontal: {
                show: true,
                size: 2,
                color: '#FF0000',    // 水平网格线的颜色
                // 'solid'|'dash'
                style: 'dash',       // 线的类型
                dashValue: [2, 2]
            },
   	        // 网格垂直线
            vertical: {
                show: true,
                size: 2,
                color: '#32CD32',
                // 'solid'|'dash'
                style: 'solid',
                dashValue: [2, 2]
            }
        },
    }

Objek konfigurasi bagan adalah struktur data yang mengatur beberapa properti dan tampilan bagan. Misalnya, contoh ini menggunakan konfigurasi gaya garis kisi. Ada juga banyak opsi yang dapat dikonfigurasi dan dimodifikasi, seperti pengaturan terkait sumbu X dan sumbu Y, pengaturan garis kursor, pengaturan informasi prompt, pengaturan gaya indikator teknis, pengaturan gaya K-line BAR, dll.

Tentu saja, jika Anda tidak terbiasa dengan hal ini,KLineChartFungsi tersebut tidak perlu meneruskan objek konfigurasi bagan saat membuat objek bagan. Bagan yang dibuat memiliki gaya default. Menggunakan fungsi API platform FMZKLineChartFungsi untuk membuat objek grafik:

var c = KLineChart(chartCfg)

Kode uji untuk menggambar garis kisi:

/*backtest
start: 2022-03-21 09:00:00
end: 2022-06-21 15:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/

function main() {
    var chartCfg = {
        grid: {
            show: true,
            // 网格水平线
            horizontal: {
                show: true,
                size: 2,
                color: '#FF0000',
                // 'solid'|'dash'
                style: 'dash',
                dashValue: [2, 2]
            },
   	        // 网格垂直线
            vertical: {
                show: true,
                size: 2,
                color: '#32CD32',
                // 'solid'|'dash'
                style: 'solid',
                dashValue: [2, 2]
            }
        },
    }

    var c = KLineChart(chartCfg)

    // 策略主循环
    while(true) {
        // 轮询间隔
        Sleep(500)
        
        // 获取K线数据
        var bars = _C(exchange.GetRecords)
        bars.forEach(function(bar, index) {
            c.begin(bar)
            c.close()
        })
    
        // 策略交易逻辑
        // ...
        // ..
    }
}

Gunakan fungsi KLineChart untuk mempermudah desain gambar strategi

Contoh Gaya Konfigurasi Bagan

Dapat digunakan untuk mereferensikan pengaturan gaya konfigurasi grafik.

{
    // 网格线
    grid: {
        show: true,
        // 网格水平线
        horizontal: {
            show: true,
            size: 1,
            color: '#393939',
            // 'solid'|'dash'
            style: 'dash',
            dashValue: [2, 2]
        },
        // 网格垂直线
        vertical: {
            show: false,
            size: 1,
            color: '#393939',
            // 'solid'|'dash'
            style: 'dash',
            dashValue: [2, 2]
        }
    },
    // 蜡烛图
    candle: {
        // 蜡烛图上下间距,大于1为绝对值,大于0小余1则为比例
        margin: {
            top: 0.2,
            bottom: 0.1
        },
        // 蜡烛图类型 'candle_solid'|'candle_stroke'|'candle_up_stroke'|'candle_down_stroke'|'ohlc'|'area'
        type: 'candle_solid',
        // 蜡烛柱
        bar: {
            upColor: '#26A69A',
            downColor: '#EF5350',
            noChangeColor: '#888888'
        },
        // 面积图
        area: {
            lineSize: 2,
            lineColor: '#2196F3',
            value: 'close',
            backgroundColor: [{
                offset: 0,
                color: 'rgba(33, 150, 243, 0.01)'
            }, {
                offset: 1,
                color: 'rgba(33, 150, 243, 0.2)'
            }]
        },
        priceMark: {
            show: true,
            // 最高价标记
            high: {
                show: true,
                color: '#D9D9D9',
                textMargin: 5,
                textSize: 10,
                textFamily: 'Helvetica Neue',
                textWeight: 'normal'
            },
            // 最低价标记
            low: {
                show: true,
                color: '#D9D9D9',
                textMargin: 5,
                textSize: 10,
                textFamily: 'Helvetica Neue',
                textWeight: 'normal',
            },
            // 最新价标记
            last: {
                show: true,
                upColor: '#26A69A',
                downColor: '#EF5350',
                noChangeColor: '#888888',
                line: {
                    show: true,
                    // 'solid'|'dash'
                    style: 'dash',
                    dashValue: [4, 4],
                    size: 1
                },
                text: {
                    show: true,
                    size: 12,
                    paddingLeft: 2,
                    paddingTop: 2,
                    paddingRight: 2,
                    paddingBottom: 2,
                    color: '#FFFFFF',
                    family: 'Helvetica Neue',
                    weight: 'normal',
                    borderRadius: 2
                }
            }
        },
        // 提示
        tooltip: {
            // 'always' | 'follow_cross' | 'none'
            showRule: 'always',
            // 'standard' | 'rect'
            showType: 'standard',
            labels: ['时间', '开', '收', '高', '低', '成交量'],
            values: null,
            defaultValue: 'n/a',
            rect: {
                paddingLeft: 0,
                paddingRight: 0,
                paddingTop: 0,
                paddingBottom: 6,
                offsetLeft: 8,
                offsetTop: 8,
                offsetRight: 8,
                borderRadius: 4,
                borderSize: 1,
                borderColor: '#3f4254',
                backgroundColor: 'rgba(17, 17, 17, .3)'
            },
            text: {
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                color: '#D9D9D9',
                marginLeft: 8,
                marginTop: 6,
                marginRight: 8,
                marginBottom: 0
            }
        }
    },
    // 技术指标
    technicalIndicator: {
        margin: {
            top: 0.2,
            bottom: 0.1
        },
        bar: {
            upColor: '#26A69A',
            downColor: '#EF5350',
            noChangeColor: '#888888'
        },
        line: {
            size: 1,
            colors: ['#FF9600', '#9D65C9', '#2196F3', '#E11D74', '#01C5C4']
        },
        circle: {
            upColor: '#26A69A',
            downColor: '#EF5350',
            noChangeColor: '#888888'
        },
        // 最新值标记
        lastValueMark: {
            show: false,
            text: {
                show: false,
                color: '#ffffff',
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                paddingLeft: 3,
                paddingTop: 2,
                paddingRight: 3,
                paddingBottom: 2,
                borderRadius: 2
            }
        },
        // 提示
        tooltip: {
            // 'always' | 'follow_cross' | 'none'
            showRule: 'always',
            // 'standard' | 'rect'
            showType: 'standard',
            showName: true,
            showParams: true,
            defaultValue: 'n/a',
            text: {
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                color: '#D9D9D9',
                marginTop: 6,
                marginRight: 8,
                marginBottom: 0,
                marginLeft: 8
            }
        }
    },
    // x轴
    xAxis: {
        show: true,
        height: null,
        // x轴线
        axisLine: {
            show: true,
            color: '#888888',
            size: 1
        },
        // x轴分割文字
        tickText: {
            show: true,
            color: '#D9D9D9',
            family: 'Helvetica Neue',
            weight: 'normal',
            size: 12,
            paddingTop: 3,
            paddingBottom: 6
        },
        // x轴分割线
        tickLine: {
            show: true,
            size: 1,
            length: 3,
            color: '#888888'
        }
    },
    // y轴
    yAxis: {
        show: true,
        width: null,
        // 'left' | 'right'
        position: 'right',
        // 'normal' | 'percentage' | 'log'
        type: 'normal',
        inside: false,
        reverse: false,
        // y轴线
        axisLine: {
            show: true,
            color: '#888888',
            size: 1
        },
        // y轴分割文字
        tickText: {
            show: true,
            color: '#D9D9D9',
            family: 'Helvetica Neue',
            weight: 'normal',
            size: 12,
            paddingLeft: 3,
            paddingRight: 6
        },
        // y轴分割线
        tickLine: {
            show: true,
            size: 1,
            length: 3,
            color: '#888888'
        }
    },
    // 图表之间的分割线
    separator: {
        size: 1,
        color: '#888888',
        fill: true,
        activeBackgroundColor: 'rgba(230, 230, 230, .15)'
    },
    // 十字光标
    crosshair: {
        show: true,
        // 十字光标水平线及文字
        horizontal: {
            show: true,
            line: {
                show: true,
                // 'solid'|'dash'
                style: 'dash',
                dashValue: [4, 2],
                size: 1,
                color: '#888888'
            },
            text: {
                show: true,
                color: '#D9D9D9',
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                paddingLeft: 2,
                paddingRight: 2,
                paddingTop: 2,
                paddingBottom: 2,
                borderSize: 1,
                borderColor: '#505050',
                borderRadius: 2,
                backgroundColor: '#505050'
            }
        },
        // 十字光标垂直线及文字
        vertical: {
            show: true,
            line: {
                show: true,
                // 'solid'|'dash'
                style: 'dash',
                dashValue: [4, 2],
                size: 1,
                color: '#888888'
            },
            text: {
                show: true,
                color: '#D9D9D9',
                size: 12,
                family: 'Helvetica Neue',
                weight: 'normal',
                paddingLeft: 2,
                paddingRight: 2,
                paddingTop: 2,
                paddingBottom: 2,
                borderSize: 1,
                borderColor: '#505050',
                borderRadius: 2,
                backgroundColor: '#505050'
            }
        }
    },
    // 图形
    shape: {
        point: {
            backgroundColor: '#2196F3',
            borderColor: '#2196F3',
            borderSize: 1,
            radius: 4,
            activeBackgroundColor: '#2196F3',
            activeBorderColor: '#2196F3',
            activeBorderSize: 1,
            activeRadius: 6
        },
        line: {
            // 'solid'|'dash'
            style: 'solid'
            color: '#2196F3',
            size: 1,
            dashValue: [2, 2]
        },
        polygon: {
            // 'stroke'|'fill'
            style: 'stroke',
            stroke: {
                // 'solid'|'dash'
                style: 'solid',
                size: 1,
                color: '#2196F3',
                dashValue: [2, 2]
            },
            fill: {
                color: 'rgba(33, 150, 243, 0.1)'
            }
        },
        arc: {
            // 'stroke'|'fill'
            style: 'stroke',
            stroke: {
                // 'solid'|'dash'
                style: 'solid',
                size: 1,
                color: '#2196F3',
                dashValue: [2, 2]
            },
            fill: {
                color: '#2196F3'
            }
        },
        text: {
            style: 'fill',
            color: '#2196F3',
            size: 12,
            family: 'Helvetica Neue',
            weight: 'normal',
            offset: [0, 0]
        }
    },
    annotation: {
        // 'top' | 'bottom' | 'point'
        position: 'top',
        offset: [20, 0]
        symbol: {
            // 'diamond' | 'circle' | 'rect' | 'triangle' | 'custom' | 'none'
            type: 'diamond',
            size: 8,
            color: '#2196F3',
            activeSize: 10,
            activeColor: '#FF9600'
        }
    },
    tag: {
        // 'top' | 'bottom' | 'point'
        position: 'point',
        offset: 0,
        line: {
            show: true,
            style: LineStyle.DASH,
            dashValue: [4, 2],
            size: 1,
            color: '#2196F3'
        },
        text: {
            color: '#FFFFFF',
            backgroundColor: '#2196F3',
            size: 12,
            family: 'Helvetica Neue',
            weight: 'normal',
            paddingLeft: 2,
            paddingRight: 2,
            paddingTop: 2,
            paddingBottom: 2,
            borderRadius: 2,
            borderSize: 1,
            borderColor: '#2196F3'
        },
        mark: {
            offset: 0,
            color: '#FFFFFF',
            backgroundColor: '#2196F3',
            size: 12,
            family: 'Helvetica Neue',
            weight: 'normal',
            paddingLeft: 2,
            paddingRight: 2,
            paddingTop: 2,
            paddingBottom: 2,
            borderRadius: 2,
            borderSize: 1,
            borderColor: '#2196F3'
        }
    }
}

Bukankah ini membuat penggambaran strategi dan desain menjadi lebih mudah?