[TOC]

यह लेख हैव्यावहारिक व्यापार के लिए वेवलेट ट्रांसफ़ॉर्म पर एक लोकप्रिय विज्ञानयह कोड एक सरलीकृत शिक्षण संस्करण है (जिसमें बहु-स्तरीय अपघटन, थ्रेशोल्ड डीनोइजिंग और मानक वेवलेट्स के व्युत्क्रम रूपांतरण पुनर्निर्माण जैसे जटिल चरणों को छोड़ दिया गया है), और इसमें केवल मुख्य अवधारणाओं को ही रखा गया है:रुझान संबंधी जानकारी निकालने के लिए कीमतों पर मल्टी-स्केल स्मूथिंग करने हेतु वेवलेट गुणांकों का उपयोग करें।यह रणनीति विकास और त्वरित सत्यापन के लिए उपयुक्त है, लेकिन अकादमिक अनुसंधान या शोध पत्र प्रकाशन के लिए नहीं।
जो लोग ज़ीहू पर वित्तीय और मात्रात्मक विषयों को नियमित रूप से ब्राउज़ करते हैं, उन्होंने निश्चित रूप से यह परिदृश्य देखा होगा:
कुछ “विशेषज्ञ” लगातार कहते रहते हैं:
उन्होंने सबको स्तब्ध कर दिया, मानो उन्होंने मात्रात्मक व्यापार के परमाणु हथियार में महारत हासिल कर ली हो।
लेकिन आप चाहते हैं कि वह आपको कोड दिखाए?
“यह… एक व्यापारिक रहस्य है, और मैं इसका खुलासा नहीं कर सकता।”
उनसे इस सिद्धांत को समझाने के लिए कहें।
“इसमें उन्नत गणित शामिल है, अगर मैं आपको समझा भी दूं तो भी आप इसे नहीं समझ पाएंगे।”
आज हम उन विषयों पर चर्चा करेंगे जिनका जिक्र अक्सर इन “ज़िहू विशेषज्ञों” द्वारा किया जाता है, वित्तीय बाजार में वेवलेट ट्रांसफॉर्म के व्यावहारिक अनुप्रयोगों का परिचय देंगे और सभी को इस तकनीक की सही समझ विकसित करने में मदद करेंगे।
कल्पना कीजिए कि आप कोई गाना सुन रहे हैं, लेकिन रिकॉर्डिंग में बैकग्राउंड शोर है:
मूल रिकॉर्डिंग = मानव आवाज + पृष्ठभूमि शोर + स्टैटिक
वेवलेट ट्रांसफॉर्म एक प्रकार का होता है।स्मार्ट फ़िल्टर:
वित्तीय बाजार की ओर रुख करें:
मूल कीमत = वास्तविक रुझान + अल्पकालिक उतार-चढ़ाव + यादृच्छिक शोर
वेवलेट ट्रांसफॉर्म आपकी मदद कर सकता है:
वेवलेट ट्रांसफॉर्म का सार यह है किमूल सिग्नल को “आधार कार्यों” (वेवलेट्स) के एक विशिष्ट सेट का उपयोग करके विघटित करें।。
मान लीजिए आप किसी व्यक्ति की दिखावट का वर्णन करना चाहते हैं:
वित्तीय कीमतों में:
मूल मूल्य श्रृंखला = आधार फ़ंक्शन 1 × भार 1 + आधार फ़ंक्शन 2 × भार 2 + … + शोर
आधार फलन, तरंग गुणांकों के अनुरूप “टेम्प्लेट” होते हैं।विभिन्न प्रकार के वेवलेट (हेयर, डाउबेचीज़, मैक्सिकन हैट, आदि) अलग-अलग टेम्पलेट का उपयोग करते हैं, ठीक उसी तरह जैसे कीमतों को विघटित करने के लिए विभिन्न “फीचर एक्सट्रैक्टर” का उपयोग किया जाता है।
वेवलेट ट्रांसफॉर्म मूल रूप से एक…मल्टीस्केल फ़िल्टर बैंक:
उच्च आवृत्ति फ़िल्टर → तीव्र उतार-चढ़ाव (दैनिक शोर, टिक-स्तर के उतार-चढ़ाव) को पकड़ता है मध्यवर्ती आवृत्ति फ़िल्टर → मध्यम अवधि के रुझानों को कैप्चर करता है (कुछ घंटों से लेकर कुछ दिनों तक की अवधि)। कम आवृत्ति वाले फ़िल्टर → दीर्घकालिक रुझानों (साप्ताहिक और मासिक रुझान) को कैप्चर करते हैं।
इसे “वेवलेट” क्यों कहा जाता है?
वित्तीय कीमतों का विश्लेषण करने के लिए साइन तरंगों का उपयोग करने में समस्या यह है: साइन तरंगें यह मानती हैं कि संकेत आवधिक रूप से दोहराया जाता है, लेकिन वित्तीय बाजार ऐसा नहीं करते! बीटीसी आज 10% बढ़ सकता है और कल 8% गिर सकता है, इसमें किसी भी प्रकार की चक्रीयता नहीं होती।
वेवलेट्स के लाभ:स्थानीयकरण विश्लेषणयह आपको बता सकता है कि “20 दिसंबर, 2025 को दोपहर 3 बजे से शाम 5 बजे के बीच कीमतों का रुझान मुख्य रूप से ऊपर की ओर था”, न कि “समग्र बाजार में उतार-चढ़ाव हो रहा था” जैसे सामान्य निष्कर्ष के बारे में।
वेवलेट ट्रांसफॉर्म हैप्रतिवर्तीयह बहुत महत्वपूर्ण है!
मूल मूल्य —> वेवलेट अपघटन —> प्रवृत्ति घटक + अस्थिरता घटक + शोर घटक ट्रेंड घटक + अस्थिरता घटक + शोर घटक —> वेवलेट पुनर्निर्माण —> मूल मूल्य
रिफैक्टरिंग प्रक्रियाइसका उद्देश्य अलग-अलग घटकों को विघटित करना है।चुनिंदा रूप से वापस संयोजित करें:
पुनर्निर्माण के दौरान केवल ट्रेंड घटकों का उपयोग करें
अपघटन के बाद, निम्नलिखित प्राप्त हुआ
वास्तविक लेन-देन में, हम आमतौर परकेवल निम्न-आवृत्ति वाले भाग का पुनर्निर्माण करें(प्रवृत्ति) उच्च आवृत्ति वाले घटक (शोर) सीधे हटा दिए जाते हैं। यही वेवलेट “शोर न्यूनीकरण” का सिद्धांत है।
चलिए जटिल समाकलन सूत्रों को छोड़ देते हैं और इसे सरल शब्दों में समझाते हैं:
वेवलेट ट्रांसफॉर्म = “वेवलेट गुणांकों” के एक सेट का उपयोग करके मूल्य श्रृंखला का भारित औसत।
मूल सूत्र:
कीमतों को सुचारू बनाना[i] = Σ(मूल कीमत)[i-j] × वेवलेट गुणांक[j]) / Σ(तरंगिका गुणांक)[j])
फ़िल्टर परिप्रेक्ष्य:
मूल मूल्य को वेवलेट फिल्टर के माध्यम से फ़िल्टर किया जाता है → विभिन्न आवृत्तियों के घटकों का चयन किया जाता है।
कुंजी यह हैवेवलेट गुणांकों का चयन:
उदाहरण के लिए:
यदि आप डाउबेची के 4 वेवलेट का उपयोग करते हैं, तो गुणांक इस प्रकार हैं:[0.483, 0.837, 0.224, -0.129]:
गुणांकों का यह समूह एक फ़िल्टर को परिभाषित करता है:
वेवलेट ट्रांसफॉर्म तब पूरा होता है जब आप इस फ़िल्टर को पूरी मूल्य श्रृंखला पर “स्लाइड” करते हैं। प्रत्येक स्लाइड में गणनाएँ शामिल होती हैं।वर्तमान अवधि के भीतर कीमतों का भारित औसतभार तरंग गुणांक हैं।
यह संकेतों को “विघटित” क्यों कर सकता है?
क्योंकि गणितीय रूप से यह सिद्ध किया जा सकता है कि:किसी भी सिग्नल को वेवलेट बेसिस फंक्शन के रैखिक संयोजन के रूप में दर्शाया जा सकता है।जिस प्रकार RGB के तीन प्राथमिक रंगों को मिलाकर कोई भी रंग बनाया जा सकता है, उसी प्रकार वेवलेट बेसिस फंक्शन को मिलाकर किसी भी मूल्य श्रृंखला को प्राप्त किया जा सकता है। विभिन्न प्रकार के वेवलेट अलग-अलग “बेसिस फंक्शन लाइब्रेरी” प्रदान करते हैं, जो विभिन्न प्रकार के सिग्नल विश्लेषण के लिए उपयुक्त होते हैं।
सिग्नल प्रोसेसिंग की पाठ्यपुस्तकों में, वेवलेट ट्रांसफॉर्म में आमतौर पर जटिल प्रक्रियाएं शामिल होती हैं…बहुस्तरीय अपघटन, पुनर्निर्माण और थ्रेशोल्ड डीनोइज़िंगचरण:
संपूर्ण वेवलेट विश्लेषण कार्यप्रणाली:
लेकिनवित्तीय लेन-देन के व्यावहारिक अनुप्रयोगचीन में हमें इसे इतना जटिल बनाने की आवश्यकता नहीं है। क्योंकि:
1. ट्रेडिंग के लिए केवल ट्रेंड की दिशा जानना आवश्यक है; सटीक पुनर्निर्माण आवश्यक नहीं है।
अकादमिक शोध में पुनर्निर्माण त्रुटि 0.01% से कम होनी चाहिए, लेकिन व्यापार में, यह निर्धारित करने के लिए पर्याप्त है कि कीमत बढ़ेगी या घटेगी। यहां तक कि अगर पुनर्निर्माण में 5% की त्रुटि भी हो, तब भी रणनीति लाभदायक हो सकती है, बशर्ते रुझान की दिशा सही हो।
2. वास्तविक समय की आवश्यकताएं गणनाओं को सरल बनाती हैं।
वेवलेट डीकंपोज़िशन की संपूर्ण प्रक्रिया में गुणांकों की कई परतों की पुनरावर्ती गणना की आवश्यकता होती है, जिससे उच्च-आवृत्ति ट्रेडिंग में विलंब हो सकता है। दूसरी ओर, प्रत्यक्ष कनवोल्यूशन को मिलीसेकंड में पूरा किया जा सकता है, जो लाइव ट्रेडिंग की आवश्यकताओं को पूरा करता है।
3. वित्तीय संकेतों की विशेष विशेषताएं
वित्तीय मूल्य स्थिर संकेत नहीं होते और उनमें कोई निश्चित चक्रीयता नहीं पाई जाती। यहाँ जटिल आवृत्ति विश्लेषण का कोई विशेष महत्व नहीं है; सरल प्रवृत्ति विश्लेषण अधिक व्यावहारिक है।
इसलिए, यह लेखवेवलेट ट्रांसफॉर्म के सार को निकालनावित्तीय बाजारों के सबसे व्यावहारिक पहलुओं पर ध्यान केंद्रित करना:
मुख्य सरलीकरण 1: केवल अनुमानित गुणांकों (निम्न-आवृत्ति प्रवृत्तियों) का उपयोग करें
परंपरागत वेवलेट अपघटन → सन्निकटन गुणांक + विवरण गुणांक (बहु-परत) यह अनुप्रयोग: केवल अनुमानित गुणांकों को बनाए रखना → सीधे सुव्यवस्थित प्रवृत्ति प्राप्त करना।
कोर सिंपलीफिकेशन 2: थ्रेशोल्डिंग डीनोइजिंग के बिना डायरेक्ट कनवोल्यूशन
परंपरागत वेवलेट अपघटन → विवरण गुणांकों का थ्रेशोल्डिंग → पुनर्निर्माण यह अनुप्रयोग: प्रत्यक्ष कनवोल्यूशन → सुचारू मूल्य प्राप्त करने के लिए
कोर सरलीकरण 3: सीमा प्रसंस्करण को अनदेखा करें
परंपरागत वेवलेट के लिए सिग्नल सीमाओं के सममित विस्तार और आवधिक विस्तार जैसी प्रक्रियाओं की आवश्यकता होती है। यह एप्लिकेशन केवल मध्य भाग पर केंद्रित है; सीमा संबंधी त्रुटियां स्वीकार्य हैं।
कार्यान्वयन विधि: फ़िल्टर कनवोल्यूशन
def convolve(src, coeffs, step):
"""
核心算法:用小波系数对价格序列做加权平均
src: 价格序列 [100000, 101000, 99000, ...]
coeffs: 小波系数 [0.483, 0.837, 0.224, -0.129]
step: 采样步长(用于多层级)
"""
sum_val = 0.0 # 加权和
sum_w = 0.0 # 权重和
for i, weight in enumerate(coeffs):
idx = i * step
if idx < len(src):
sum_val += src[idx] * weight
sum_w += weight
return sum_val / sum_w # 归一化
यह फ़ंक्शन है…वेवलेट फिल्टर का मूल:
stepपैरामीटर बहु-स्तरीय स्मूथिंग (स्तर 1/2/3…) को सक्षम बनाते हैं।यह सरलीकरण उचित क्यों है?
क्योंकि लेन-देन की मूलभूत आवश्यकता यह है:शोर में रुझान खोजनावेवलेट ट्रांसफॉर्म के सन्निकटन गुणांक स्वयं सिग्नल के लिए एक “लो-पास फिल्टर” होते हैं, जो निम्न-आवृत्ति प्रवृत्ति घटकों को संरक्षित करते हैं, और यही हमें चाहिए।
हालांकि संपूर्ण वेवलेट विश्लेषण अधिक सटीक है, लेकिन वित्तीय व्यापार में:
उपयोगइन्वेंटर क्वांटाइजेशन (FMZ) प्लेटफॉर्म का स्थानीय बैकटेस्टिंग इंजनडेटा प्राप्त करना बहुत सुविधाजनक है!
'''backtest
start: 2025-12-17 00:00:00
end: 2025-12-23 08:00:00
period: 1h
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT","fee":[0,0]}]
'''
from fmz import *
task = VCtx(__doc__)
def main():
exchange.SetCurrency("BTC_USDT")
exchange.SetContractType("swap")
records = exchange.GetRecords(PERIOD_H1, 500)
return records
records = main()
किसी जटिल एपीआई एकीकरण या डेटा सफाई की आवश्यकता नहीं है; मानकीकृत कैंडलस्टिक डेटा सीधे प्राप्त किया जा सकता है। इससे हमें डेटा प्रोसेसिंग में उलझने के बजाय सात प्रकार के वेवलेट के वास्तविक प्रभावों को शीघ्रता से सत्यापित करने में मदद मिलती है।
क्रिप्टोकरेंसी की कीमतों पर सात सामान्य वेवलेट प्रकारों (हेयर, डाउबेचीज़ 4, सिम्लेट 4, बायोरथोगोनल 3.3, मैक्सिकन हैट, मोर्लेट और डिस्क्रीट मेयर) के प्रदर्शन की तुलना करके, निम्नलिखित दृश्य प्रदर्शन प्रदान किया गया है:
इसमें गणितीय व्युत्पत्ति की सटीकता पर नहीं, बल्कि व्यावहारिक परिणामों की दृश्य तुलना पर ध्यान केंद्रित किया गया है।इससे व्यापारियों को सहज समझ विकसित करने और अपनी रणनीति के अनुरूप वेवलेट प्रकार चुनने में मदद मिलती है।
हार वेवलेट सबसे बुनियादी प्रकार का वेवलेट है, जिसमें केवल दो गुणांक होते हैं:[0.5, 0.5]असल में, यह दो आसन्न कीमतों का एक साधारण औसत है।
कोर कोड:
coeffs = [0.5, 0.5]
# 对价格序列 [100000, 101000, 99000, 102000, 98000] 处理
def smooth(prices, i):
return (prices[i] * 0.5 + prices[i-1] * 0.5) / 1.0
# 结果:[100000, 100500, 100000, 100500, 100000]
जैसा कि आप देख सकते हैं, शुरुआत में अत्यधिक उतार-चढ़ाव वाली कीमत (99,000 से 102,000 तक) हार प्रोसेसिंग के बाद अपेक्षाकृत स्थिर हो जाती है। यह वेवलेट “डीनोइज़िंग” का प्रभाव है - जो अल्पकालिक, तीव्र उतार-चढ़ाव को कम करता है, जिससे आपको एक सहज मूल्य प्रवृत्ति दिखाई देती है।

Daubechies 4 (संक्षेप में db4) इंजीनियरिंग में सबसे अधिक उपयोग किए जाने वाले वेवलेट्स में से एक है। इसके गुणांक इस प्रकार हैं:[0.483, 0.837, 0.224, -0.129]ध्यान दें कि अंतिम गुणांक…ऋणात्मक संख्यायही बात इसे अद्वितीय बनाती है।
कोर कोड:
coeffs = [0.483, 0.837, 0.224, -0.129]
# 处理第i个价格点
def smooth(prices, i):
weighted_sum = (prices[i] * 0.483 + # 当前价格
prices[i-1] * 0.837 + # 前1根,权重最大!
prices[i-2] * 0.224 + # 前2根
prices[i-3] * (-0.129)) # 前3根,负权重
weight_sum = 0.483 + 0.837 + 0.224 + (-0.129) # = 1.415
return weighted_sum / weight_sum
# 示例:smooth([100000, 101000, 99000, 102000], 3) ≈ 100251
प्रमुख विशेषताऐं:पिछली कैंडलस्टिक का भार (0.837) वर्तमान मूल्य (0.483) से अधिक है! इसका अर्थ है कि db4 “अभी घटित हुए मूल्य” पर अधिक जोर देता है, और नकारात्मक भार गुणांक पिछली कीमत पर “संतुलन” प्रभाव डालेगा, जिससे सुगमता और भी बढ़ जाएगी।

सिम्लेट 4, बेहतर समरूपता के उद्देश्य से बनाया गया डाउबेचीज़ का उन्नत संस्करण है। गुणांक:[-0.076, -0.030, 0.498, 0.804, 0.298, -0.099, -0.013, 0.032]。
कोर कोड:
coeffs = [-0.076, -0.030, 0.498, 0.804, 0.298, -0.099, -0.013, 0.032]
# 向前看8根K线
def smooth(prices, i):
weighted_sum = sum(prices[i-j] * coeffs[j] for j in range(8))
weight_sum = sum(coeffs)
return weighted_sum / weight_sum
# 平滑效果比Haar和db4都强,但反应速度更慢
प्रमुख विशेषताऐं:आठ कैंडलस्टिक की विंडो लेंथ कीमतों की लंबी “मेमोरी” प्रदान करती है। एक चिकने वक्र पर वास्तविक ट्रेंड रिवर्सल आठ कैंडलस्टिक बीतने के बाद ही दिखाई दे सकता है।

बायोऑर्थोगोनल 3.3 (संक्षेप में bior3.3) एक पूर्णतः सममित तरंग है जिसके गुणांक इस प्रकार हैं:[-0.066, 0.283, 0.637, 0.283, -0.066]。
कोर कोड:
coeffs = [-0.066, 0.283, 0.637, 0.283, -0.066]
# ↑ 中心↑ ↑
# 完全对称的两端
# 处理中间价格点
def smooth(prices, i):
# 实际应用:只向前看,不使用未来数据
weighted_sum = (prices[i-4] * (-0.066) + # 前4根
prices[i-3] * 0.283 + # 前3根
prices[i-2] * 0.637 + # 前2根,权重最大
prices[i-1] * 0.283 + # 前1根
prices[i] * (-0.066)) # 当前
weight_sum = sum(coeffs) # = 1.071
return weighted_sum / weight_sum
प्रमुख विशेषताऐं:समरूपता यह सुनिश्चित करती है कि कोई “चरण विरूपण” न हो - चिकना वक्र अस्पष्ट रूप से बाईं या दाईं ओर नहीं खिसकेगा।

मेक्सिकन हैट (जिसे रिकर वेवलेट भी कहा जाता है) गुणांक:[-0.1, 0.0, 0.4, 0.8, 0.4, 0.0, -0.1]इसका आकार मैक्सिकन सोम्ब्रेरो (टोपी) जैसा है।
कोर कोड:
coeffs = [-0.1, 0.0, 0.4, 0.8, 0.4, 0.0, -0.1]
# 负值 零 正值 最大 正值 零 负值
# ↓ ↓
# "惩罚"两端,增强拐点检测能力
def smooth(prices, i):
weighted_sum = (prices[i-6] * (-0.1) + # 左3,负权重
prices[i-5] * 0.0 + # 左2
prices[i-4] * 0.4 + # 左1
prices[i-3] * 0.8 + # 中心,权重最大
prices[i-2] * 0.4 + # 右1
prices[i-1] * 0.0 + # 右2
prices[i] * (-0.1)) # 右3,负权重
weight_sum = sum(coeffs)
return weighted_sum / weight_sum
प्रमुख विशेषताऐं:इसकी “बीच में चौड़ी और दोनों सिरों पर ऋणात्मक” संरचना इसे पता लगाने में विशेष रूप से सक्षम बनाती है।मोड़ बिंदु- वह महत्वपूर्ण क्षण जब कीमतें ऊपर की ओर रुझान से नीचे की ओर रुझान में बदल जाती हैं (या इसके विपरीत)। नकारात्मक भार गुणांक दूर की कीमतों को “दंडित” करता है, जिससे रुझान में बदलाव को तुरंत पकड़ा जा सकता है।

मोर्लेट वेवलेट गॉसियन (सामान्य) वितरण पर आधारित है, जिसके गुणांक इस प्रकार हैं:[0.0625, 0.25, 0.375, 0.25, 0.0625]。
कोर कोड:
coeffs = [0.0625, 0.25, 0.375, 0.25, 0.0625]
# ↓ ↓ ↓中心 ↓ ↓
# 远端 近端 最高 近端 远端
# 完美的高斯钟形曲线
def smooth(prices, i):
weighted_sum = (prices[i-4] * 0.0625 + # 左2,6.25%
prices[i-3] * 0.25 + # 左1,25%
prices[i-2] * 0.375 + # 中心,37.5%
prices[i-1] * 0.25 + # 右1,25%
prices[i] * 0.0625) # 右2,6.25%
# 权重和正好 = 1.0,无需除法
return weighted_sum
प्रमुख विशेषताऐं:सभी वेवलेट्स में सबसे “सौम्य” होने के कारण, इसमें कोई नकारात्मक भार नहीं होता है, और सभी कीमतों को गणना में सहजता से शामिल किया जाता है। परिणामस्वरूप वक्र अत्यंत चिकना होता है, लेकिन इसकी कीमत धीमी प्रतिक्रिया है - कीमतों में अचानक परिवर्तन कई कैंडलस्टिक्स के बाद ही दिखाई दे सकते हैं।

डिस्क्रीट मेयर वेवलेट सबसे जटिल वेवलेट है, जिसके गुणांक इस प्रकार हैं:[-0.015, -0.025, 0.0, 0.28, 0.52, 0.28, 0.0, -0.025, -0.015]。
कोर कोड:
coeffs = [-0.015, -0.025, 0.0, 0.28, 0.52, 0.28, 0.0, -0.025, -0.015]
# ↑ ↑ ↑ ↑中心↑ ↑ ↑ ↑
# 完全对称,中心权重超过50%
def smooth(prices, i):
# 向前看9根K线
weighted_sum = sum(prices[i-j] * coeffs[j] for j in range(9))
weight_sum = sum(coeffs) # = 1.0
return weighted_sum
# 注意:第4根之前的K线权重是0.52,超过50%!
# 实际上在告诉你"4根K线之前的中期趋势"
प्रमुख विशेषताऐं:इसमें सबसे अधिक गुणांक (9), सबसे लंबा ऐतिहासिक डेटा और सबसे मजबूत स्मूथिंग प्रभाव है। यह “साप्ताहिक रुझानों” को निकालने के लिए उपयुक्त है, लेकिन इसमें बहुत अधिक विलंब होता है - भले ही कीमत 10% गिर गई हो, इसका वक्र अभी भी “लगातार वृद्धि” दिखा सकता है।

सात प्रकार के वेवलेट्स की समीक्षा करने के बाद, आपको एक पैटर्न दिखाई देना चाहिए:
अधिक गुणांक = अधिक दृश्यता = बेहतर स्मूथिंग = अधिक विलंबता
हार (2 गुणांक) → केवल 1 बार देखें → लगभग चिकना नहीं डाउबेचीज़ 4 (4 टुकड़े) → पहले 3 देखें → थोड़ा चिकना मेक्सिकन टोपी (7) → इससे पहले 6 देखें → मध्यम स्मूथिंग डिस्क्रीट मेयर (9) → 8 बार देखने से पहले → भारी स्मूथिंग
नकारात्मक भार का प्रभाव संवेदनशीलता को बढ़ाना और परिवर्तनों का पता लगाना आसान बनाना है।
हार/मोरलेट (कोई नकारात्मक भार नहीं) → कोमल और चिकना, असंवेदनशील मेक्सिकन हैट (दोनों सिरों पर नकारात्मक) → परिवर्तन बिंदुओं के प्रति संवेदनशील डाउबेचीज़ 4 (नकारात्मक) → प्रवृत्ति परिवर्तनों के प्रति संवेदनशील
समरूपता की भूमिका = कोई विकृति नहीं = मूल आकार को बनाए रखना
विषमता (डाउबेचीज़) → बाएँ/दाएँ खिसक सकती है समरूपता (बायोऑर्थोगोनल/मेयर) → केंद्रीय स्थिति को बनाए रखना
वेवलेट ट्रांसफ़ॉर्म को एक के ऊपर एक रखी गुड़ियों की तरह पुनरावर्ती रूप से लागू किया जा सकता है। पहले अनुप्रयोग को लेवल 1 कहा जाता है, लेवल 1 के परिणाम पर इसे दोबारा लागू करने को लेवल 2 कहा जाता है, और इसी तरह आगे भी।
विभिन्न स्तरों पर देखी जाने वाली समय सीमाएँ:
मान लीजिए कि हम बीटीसी ट्रेडिंग के लिए 1-घंटे के कैंडलस्टिक चार्ट का उपयोग करते हैं:
स्तर 1 → 2-4 घंटों में होने वाले अल्पकालिक उतार-चढ़ावों का अवलोकन करें स्तर 2 → 4-8 घंटों में रुझान का अवलोकन करें स्तर 3 → 1-2 दिनों में मध्यम अवधि के रुझान का अवलोकन करें (आमतौर पर इस्तेमाल की जाने वाली रणनीति) स्तर 4 → 2-4 दिनों की मूल्य सीमा का अवलोकन करें स्तर 5 → 4-8 दिनों में प्रमुख रुझानों का अवलोकन करें
वास्तविक परिणामों की तुलना:
मूल बीटीसी मूल्य (1-घंटे का चार्ट):99500, 99800, 99200, 100200, 99800, 100500, 100100, ...
लेवल 1 प्रोसेसिंग: 99600, 99650, 99500, 99900, 99950, 100200, 100250, … (थोड़ा समतल किया गया है, लेकिन उतार-चढ़ाव अभी भी दिखाई दे रहे हैं)
लेवल 3 प्रोसेसिंग: 99620, 99650, 99700, 99800, 99950, 100100, 100200, … (सरलीकृत किया गया, जो मध्यम अवधि के रुझान को दर्शाता है)
लेवल 5 प्रोसेसिंग: 99630, 99640, 99660, 99700, 99760, 99840, 99930, … (बेहद सहज, केवल सामान्य दिशा दर्शा रहा है)

चयन का सिद्धांत सरल है: अपनी होल्डिंग अवधि के आधार पर संबंधित स्तर का उपयोग करें।
15 मिनट की स्कैल्पिंग → स्तर 1-2
इंट्राडे ट्रेडिंग → स्तर 2-3
कुछ दिनों तक स्विंग डांस करें → लेवल 3-4
दीर्घकालिक प्रवृत्ति विश्लेषण → स्तर 4-5
ट्रेडिंग में वेवलेट ट्रांसफॉर्म का उपयोग बहुत सीधा है: इससे उत्पन्न स्मूथेड प्राइस कर्व का उपयोग करके ट्रेंड की दिशा निर्धारित करें और ट्रेंड बदलने पर ट्रेड करें। विशेष रूप से, यदि स्मूथेड क्लोजिंग प्राइस पिछले क्लोजिंग प्राइस से अधिक है, तो यह ऊपर की ओर ट्रेंड का संकेत देता है, इसलिए लॉन्ग पोजीशन लें; यदि स्मूथेड क्लोजिंग प्राइस पिछले क्लोजिंग प्राइस से कम है, तो यह नीचे की ओर ट्रेंड का संकेत देता है, इसलिए पोजीशन बंद करें या शॉर्ट पोजीशन लें। यह तर्क प्रभावी है क्योंकि वेवलेट्स ने अल्पकालिक यादृच्छिक उतार-चढ़ाव को फ़िल्टर कर दिया है, जिससे “ऊपर” या “नीचे” की स्थिति शोर के कारण उत्पन्न गलत संकेत के बजाय वास्तविक ट्रेंड परिवर्तन की उच्च संभावना के रूप में रह जाती है।
# 执行小波变换
transformed = transformer.transform_ohlc(df)
# 获取最近两根K线的平滑收盘价
w_close_current = transformed['w_close'].values[-1] # 当前平滑收盘价
w_close_prev = transformed['w_close'].values[-2] # 前一根平滑收盘价
# 判断趋势方向
signal = 0
if w_close_current > w_close_prev:
signal = 1 # 平滑价格向上 → 做多
elif w_close_current < w_close_prev:
signal = -1 # 平滑价格向下 → 做空
# 获取账户信息
account = exchange.GetAccount()
ticker = exchange.GetTicker()
if not account or not ticker:
Log("[Warning] Failed to get account/ticker info")
Sleep(5000)
continue
current_price = ticker['Last']
Log(f"[Price] 原始: {df['Close'].values[-1]:.2f}, "
f"平滑当前: {w_close_current:.2f}, 平滑前值: {w_close_prev:.2f}")
Log(f"[Trend] {'↑ 向上' if signal == 1 else '↓ 向下' if signal == -1 else '→ 横盘'}")
# 执行交易逻辑
if signal == 1 and position != 1:
# 平滑价格向上 → 做多
Log(f"[信号] 趋势向上,开多 @ {current_price:.2f}")
if position == -1:
# 先平空仓
exchange.SetDirection("closesell")
exchange.Buy(current_price, 1)
Log(f"[平仓] 平空仓")
# 开多仓
exchange.SetDirection("buy")
exchange.Buy(current_price, 1)
Log(f"[开仓] 开多仓")
position = 1
elif signal == -1 and position != -1:
# 平滑价格向下 → 做空
Log(f"[信号] 趋势向下,开空 @ {current_price:.2f}")
if position == 1:
# 先平多仓
exchange.SetDirection("closebuy")
exchange.Sell(current_price, 1)
Log(f"[平仓] 平多仓")
# 开空仓
exchange.SetDirection("sell")
exchange.Sell(current_price, 1)
Log(f"[开仓] 开空仓")
position = -1
else:
Log(f"[持仓] 当前{'多头' if position == 1 else '空头' if position == -1 else '空仓'},无需操作")

बेशक, व्यवहार में यह इतना आसान नहीं है। आप एक साथ कई वेवलेट स्तरों का उपयोग कर सकते हैं, जैसे कि स्तर 2 अल्पकालिक प्रवृत्ति को दर्शाता है और स्तर 4 दीर्घकालिक प्रवृत्ति को। पोजीशन तभी खोलें जब दोनों एक ही दिशा में आगे बढ़ रहे हों, जिससे गलत संकेतों की संभ�