আমি অনলাইনে এই সূচকটির জন্য কিছু সূত্র খুঁজে পেয়েছি।
/*
LC := REF(CLOSE,1); //REF(C,1) 上一周期的收盘价
RSI:=SMA(MAX(CLOSE-LC,0),N,1)/SMA(ABS(CLOSE-LC),N,1) *100;
%K: MA(RSI-LLV(RSI,M),P1)/MA(HHV(RSI,M)-LLV(RSI,M),P1)*100; LLV(l,60)表示:检索60天内的最低价,可适应于检索任何股票
%D:MA(%K,P2);
LC := REF(CLOSE,1);
RSI:=SMA(MAX(CLOSE-LC,0),N,1)/SMA(ABS(CLOSE-LC),N,1) *100;
STOCHRSI:MA(RSI-LLV(RSI,M),P1)/MA(HHV(RSI,M)-LLV(RSI,M),P1)*100;
*/
ওহ মাই গড! আমি ধৈর্য ধরে দেখলাম। এই বর্ণনাটি সাধারণ সূত্র। কিন্তু আমার সামান্য প্রোগ্রামিং অভিজ্ঞতা আছে, আমি শুধু অনুমান করতে পারি! অনুমান! অনুমান!
তিনি আরও বলেন, 'এটা আমার জীবনের সবচেয়ে কঠিন লড়াই। সংক্ষিপ্তসারঃ
সবুজ হল ফাস্টলাইন %K, কমলা হল %D।
function LLV(array,period){
if(!array || array.length - period < 0){
throw "error:" + array;
}
var min = array[array.length - period];
for(var i = array.length - period; i < array.length; i++){
if( array[i] < min ){
min = array[i];
}
}
return min;
}
function HHV(array,period){
if(!array || array.length - period < 0){
throw "error:" + array;
}
var max = array[array.length - period];
for(var i = array.length - period; i < array.length; i++){
if( array[i] > max){
max = array[i];
}
}
return max;
}
function DeleteNullEle(initArr){
var dealArr = [];
var initArrLen = initArr.length;
for(var i = 0,j = 0 ; i < initArrLen ; i++,j++){
if(initArr[i] === null || isNaN(initArr[i]) ){
j--;
continue;
}
dealArr[j] = initArr[i];
}
return dealArr;
}
/*
LC := REF(CLOSE,1); //REF(C,1) 上一周期的收盘价
RSI:=SMA(MAX(CLOSE-LC,0),N,1)/SMA(ABS(CLOSE-LC),N,1) *100;
%K: MA(RSI-LLV(RSI,M),P1)/MA(HHV(RSI,M)-LLV(RSI,M),P1)*100; LLV(l,60)表示:检索60天内的最低价,可适应于检索任何股票
%D:MA(%K,P2);
LC := REF(CLOSE,1);
RSI:=SMA(MAX(CLOSE-LC,0),N,1)/SMA(ABS(CLOSE-LC),N,1) *100;
STOCHRSI:MA(RSI-LLV(RSI,M),P1)/MA(HHV(RSI,M)-LLV(RSI,M),P1)*100;
*/
function FstochRSI(records,n,m,p1,p2){
var len = records.length;
//var LC = records[len-2];//上一周期收盘价
//var rsi = TA.RSI(records,n);// RSI 数组 ,talib
var rsi = talib.RSI(records,n);
rsi = DeleteNullEle(rsi);//ceshi
var arr1 = [];
var arr2 = [];
var arr3 = [];
var arr4 = [];
var rsi_a = [];
var rsi_b = [];
var k = [];
var d = null;
/*不包含当前柱
for(var a = 0 ;a < rsi.length ; a++ ){//改造 不用 LLV
for(var aa = 0 ; aa <= a; aa++ ){
rsi_a.push(rsi[aa]);
}
arr1.push(rsi[a] - TA.Lowest(rsi_a,m));
}
for(var b = 0 ;b < rsi.length ; b++ ){//改造 不用 HHV
for(var bb = 0 ; bb <= b; bb++ ){
rsi_b.push(rsi[bb]);
}
arr2.push(TA.Highest(rsi_b,m) - TA.Lowest(rsi_b,m));
}
*/
for(var a = 0 ;a < rsi.length ; a++ ){//改造 不用 LLV
if(a < m){
continue;
}
for(var aa = 0 ; aa <= a; aa++ ){
rsi_a.push(rsi[aa]);
}
arr1.push(rsi[a] - LLV(rsi_a,m));
}
for(var b = 0 ;b < rsi.length ; b++ ){//改造 不用 HHV
if(b < m){
continue;
}
for(var bb = 0 ; bb <= b; bb++ ){
rsi_b.push(rsi[bb]);
}
arr2.push(HHV(rsi_b,m) - LLV(rsi_b,m));
}
arr1 = DeleteNullEle(arr1);
arr2 = DeleteNullEle(arr2);
//Log("arr1:",arr1.length,"-",arr1);//ceshi
//Log("arr2:",arr2.length,"-",arr2);//ceshi
arr3 = talib.MA(arr1,p1);
arr4 = talib.MA(arr2,p1);
arr3 = DeleteNullEle(arr3);
arr4 = DeleteNullEle(arr4);
//Log("ceshi");//ceshi
var c = 0;
var diff = 0;
if(arr3.length !== arr4.length){//实测 长度不相等
throw "error: !=" + arr3.length + "----" + arr4.length;
diff = arr4.length - arr3.length; //example diff = 10 - 6
}else{
//throw "error:" + arr3.length + "----" + arr4.length;
}
for( ;c < arr3.length ; c++ ){
k.push(arr3[c] / arr4[c + diff] * 100);
}
d = talib.MA(k,p2);
return [k,d,rsi];
}
লিজিংএক্সএফডিজেfunction main (()) { exchange.SetContractType (("swap") // স্থায়ী চুক্তির জন্য সেট করা var records = exchange.GetRecords ((PERIOD_M15)) let [k, d, rsi] = FstochRSI ((records, 14, 14, 3, 3); Log (("K", k[k.length-2]) Log (("D",d[d.length-2]) } --- আমি এই ফাংশনটি কল করেছি, এবং মুদ্রিত তথ্যটি Bitcoin এর StochRsi এর সাথে সামঞ্জস্যপূর্ণ নয়।
Jরিটেস্টের সময় দেখা গেছে যে এই ফাংশনটি খুব ধীর গতির এবং উন্নতির জন্য।
Jআপনি কি জানেন যে, টালিব.স্টোকআরএসআই (STOCHRSI) এর মাধ্যমে বিটকয়েন জ্ঞানের তথ্যগুলি ঠিক করা যায় না?
উদ্ভাবকগণ - ক্যোটিফিকেশন - ছোট্ট স্বপ্নএটি একটি তুলনামূলক সমস্যা হতে পারে, যা নির্ধারণ করে যে তুলনার ডেটা একই জাত, সময়কাল, পরামিতি, BAR অবস্থান। এটি আগে পরীক্ষা করা হয়েছে, এটি একই হওয়া উচিত।
উদ্ভাবকগণ - ক্যোটিফিকেশন - ছোট্ট স্বপ্নtalib হল একটি সূচক সংগ্রহস্থল। এটি উন্মুক্ত উৎস। BotVS এ এটি ব্যবহার করা হয়, উদাহরণস্বরূপ, সমতল তালিব.MA ((records, 10); // records দ্বারা সমতল ডায়েরির সময়কালের জন্য K-লাইন ডেটা। এটি রেকর্ডস কে লাইনের 10 বারের গড় রেখা হিসাবে গণনা করা হয়। আপনি BotVS QQ গ্রুপঃ 608262365 এ যেতে পারেন।
উদ্ভাবকগণ - ক্যোটিফিকেশন - ছোট্ট স্বপ্নFstochRSI ((records,n,m,p1,p2) এর সাথে OKCoin এর প্যারামিটারগুলি একই, তবে প্রথম records এটি K-line ডেটা, অর্থাৎ গণনার সূচকের ডেটা উত্স, যা আমি OK এর চার্টের সাথে তুলনা করেছি, এটি একই, কারণ এই অ্যালগরিদমটি পুনরাবৃত্তি করা কিছুটা ধীর।
উদ্ভাবকগণ - ক্যোটিফিকেশন - ছোট্ট স্বপ্নহয়তো অ্যালগরিদম বা কোড অপ্টিমাইজ করা প্রয়োজন।
Jখুব ভালো, এখন স্বাভাবিক। ধন্যবাদ!
উদ্ভাবকগণ - ক্যোটিফিকেশন - ছোট্ট স্বপ্নএই পোস্টের কোডটি ইতিমধ্যে পোস্ট করা আছে, আপনি নীচে একটি তুলনা দেখতে পারেন।
Jআমরা প্রথমে STOCH ফাংশন ব্যবহার করি।
উদ্ভাবকগণ - ক্যোটিফিকেশন - ছোট্ট স্বপ্নতালেব এর বিপরীত, অভ্যন্তরীণ গণনা, কিছুটা আলাদা। আমি নিজে STOCHRSI লিখেছি, পরে পোস্ট করব।