원수 대역 백테스트 전략은 가격 주위에서 가장 높고 가장 낮은 원수를 식별하고 이 두 원수 대열을 대역으로 그래프화하여 시장 추세를 판단합니다. 이 전략은 Modulus Financial Engineering Inc.에 의해 개발되었습니다.
위험은 매개 변수를 적절히 조정하고 다른 지표와 결합함으로써 피할 수 있습니다.
소수 대역 백테스트 전략은 전반적으로 실용적인 가치를 가진 매우 혁신적인 전략이다. 시장의 무작위성을 포착하기 위해 소수의 특성을 사용하면서 추세를 식별하는 가격 차이를 고려하여 연구를 위해 매우 가치가 있습니다. 다음 단계는 신호 품질을 향상시키는 측면에서 최적화하고, 무작위 숫자 유형을 확장하고, 자동 최적화 등을 통해 전략 효과를 더 주목할 수 있습니다.
/*backtest start: 2023-12-08 00:00:00 end: 2024-01-07 00:00:00 period: 3h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=2 //////////////////////////////////////////////////////////// // Copyright by HPotter v1.0 27/03/2018 // Determining market trends has become a science even though a high number // or people still believe it’s a gambling game. Mathematicians, technicians, // brokers and investors have worked together in developing quite several // indicators to help them better understand and forecast market movements. // The Prime Number Bands indicator was developed by Modulus Financial Engineering // Inc. This indicator is charted by indentifying the highest and lowest prime number // in the neighborhood and plotting the two series as a band. // // You can change long to short in the Input Settings // WARNING: // - For purpose educate only // - This script to change bars colors. //////////////////////////////////////////////////////////// PrimeNumberUpBand(price, percent) => res = 0 res1 = 0 for j = price to price + (price * percent / 100) res1 := j for i = 2 to sqrt(price) res1 := iff(j % i == 0 , 0, j) if res1 == 0 break if res1 > 0 break res := iff(res1 == 0, res[1], res1) res PrimeNumberDnBand(price, percent) => res = 0 res2 = 0 for j = price to price - (price * percent / 100) res2 := j for i = 2 to sqrt(price) res2 := iff(j % i == 0 , 0, j) if res2 == 0 break if res2 > 0 break res := iff(res2 == 0, res[1], res2) res strategy(title="Prime Number Bands Backtest", overlay = true) percent = input(5, minval=0.01, step = 0.01, title="Tolerance Percentage") Length = input(5, minval=1) srcUp = input(title="Source Up Band", defval=high) srcDn = input(title="Source Down Band", defval=low) reverse = input(false, title="Trade reverse") xPNUB = PrimeNumberUpBand(srcUp, percent) xPNDB = PrimeNumberDnBand(srcDn, percent) xHighestPNUB = highest(xPNUB, Length) xLowestPNUB = lowest(xPNDB, Length) pos = iff(close > xHighestPNUB[1], 1, iff(close < xLowestPNUB[1], -1, nz(pos[1], 0))) possig = iff(reverse and pos == 1, -1, iff(reverse and pos == -1, 1, pos)) if (possig == 1) strategy.entry("Long", strategy.long) if (possig == -1) strategy.entry("Short", strategy.short) barcolor(possig == -1 ? red: possig == 1 ? green : blue ) plot(xHighestPNUB, color=red, title="PNUp") plot(xLowestPNUB, color=green, title="PNDn")