찾다
Javajava지도 시간Java는 활성 자금 흐름을 기반으로 거래 전략을 어떻게 구현합니까?

1. 요약

가격은 장기적으로 상승하거나 하락할 확률이 각각 50%여야 합니다. 따라서 미래 가격을 정확하게 예측하려면 가격에 영향을 미치는 모든 요소를 ​​얻어야 합니다. 실시간으로 각 요소에 정확한 가중치를 부여하고 마지막으로 객관적이고 합리적인 분석을 수행합니다. 가격에 영향을 미치는 모든 요소를 ​​나열하면 전체 화면이 채워집니다.

요약: 글로벌 경제 환경, 국가 거시 정책, 관련 산업 정책, 수급 관계, 국제 이벤트, 금리 및 환율, 인플레이션 및 디플레이션, 시장 심리, 알 수 없는 요인 등 예측은 거대하고 불가능한 작업이 되었습니다. 그래서 아주 일찍부터 저는 시장이 예측 불가능하다는 것을 깨달았습니다. 그러면 시장의 모든 예측은 가정이 되었고, 거래는 확률 게임이 되었는데, 이는 흥미롭습니다.

2. 자본 흐름을 이용하는 이유

시장을 예측할 수 없으니 정말 무관심한 걸까요? 아니요. 모든 거시적, 미시적 요인이 가격에 반영되었습니다. 즉, 가격은 모든 요인의 상호작용의 결과라는 의미입니다. 완전한 거래 전략을 세우려면 가격만 분석하면 됩니다. Java는 활성 자금 흐름을 기반으로 거래 전략을 어떻게 구현합니까?

먼저 잘 생각해보세요. 왜 가격이 오르나요?

국가의 관련 산업에 대한 정책 지원, 원산지의 폭우, 국제 무역 전쟁, MACD 골든 크로스, 다른 사람들의 구매 등 때문이라고 말할 수 있습니다. 물론 이것이 맞을 수도 있습니다. 돌이켜보면 가격이 상승한 이유를 항상 알 수 있습니다.

사실 가격의 등락은 모든 배를 들어올리는 밀물과 비슷합니다. 가격 상승은 자금 홍보와 분리될 수 없습니다. 시장에 판매자보다 구매자가 많으면 가격이 상승하게 됩니다. 반면, 구매자보다 판매자가 많으면 가격이 하락합니다. 이 개념을 통해 우리는 순자금 흐름에 반영된 수요와 공급 관계를 기반으로 미래 가격 추세에 대한 합리적인 예측을 제공할 수 있습니다.

3. 자금 흐름의 원리

자금 흐름 분석은 기존 분석과 달리 일정 기간 동안의 일련의 거래 데이터를 기반으로 어떤 거래가 적극적 자금 유입이고 어떤 거래가 적극적 자금 유출인지 분석합니다. 그런 다음 해당 기간 동안의 활성 유입량에서 활성 유출량을 빼면 해당 기간 동안의 순자본 유입을 알 수 있습니다. 자금의 순유입이 양수이면 제품의 공급이 수요를 초과한다는 의미이고, 자금의 순유출이 있으면 제품의 공급이 수요를 초과한다는 의미입니다.

Java는 활성 자금 흐름을 기반으로 거래 전략을 어떻게 구현합니까?

이 글을 읽고 나면 실제 거래에서는 누군가가 사고 누군가가 팔아야 거래가 완료되는 것이 아닐까 궁금해하시는 분들이 계실 겁니다. 거래 주문에는 구매만큼의 판매가 이루어져야 하며, 자금 유입과 유출이 동일해야 합니다. 자본의 유입과 유출은 어디서 오는가? 실제로 엄밀히 말하면 각 매수 주문은 해당 매도 주문과 일치해야 하며 자본 유입과 자본 유출이 동일해야 합니다. 어떤 주문이 ​​적극적으로 매수되고 어떤 주문이 ​​적극적으로 매도되었는지 계산하려면 막대 데이터를 사용하고 거래량과 가격을 기반으로 하는 절충 방법만 사용할 수 있습니다.

4. 자본 흐름 계산 방법

자본 흐름의 변화는 막대 데이터를 통합하여 실시간으로 계산됩니다. 활성 자금 흐름을 계산하는 알고리즘에는 두 가지가 있습니다.

  • 첫 번째는 현재 주문의 거래 가격이 상대방 가격 또는 초과 가격으로 실행되는 경우 구매 거래 가격 >= 판매 가격입니다. 구매자가 더 높은 가격으로 거래를 완료하려는 의지가 적극적인 자금 유입에 포함됩니다.

  • 둘째, 현재 거래 가격 > 최종 거래 가격이면 현재 거래량이 가격 상승을 적극적으로 밀어올리는, 즉 적극적인 자금 유입이 포함된 것으로 이해할 수 있습니다.

Java는 활성 자금 흐름을 기반으로 거래 전략을 어떻게 구현합니까?

위의 두 번째 알고리즘을 예로 들어보겠습니다.

특정 품종의 10:00 종가는 3450이고 11:00 종가는 3455이므로 10:00을 사용합니다~ 11 : 00의 거래량이 활성 자금 유입에 포함됩니다. 그렇지 않으면 활성 자금 유출에 포함됩니다. 본 글은 두 번째 방법을 기반으로 가격변동 요인을 추가하여 이전봉과 이전봉의 종가를 비교하여 거래량 * 상승 또는 하락봉의 변동폭을 순차적으로 포함시킨 후, 이를 기반으로 합니다. 이 순서에 따라 자금의 활성 유입 비율을 계산합니다.

5. 트레이딩 로직

이 글에서는 선물시장의 자본 흐름을 '거래량'의 관점에서 설명하고, 바 데이터를 실시간으로 분석하여 단기 가격 추세를 판단하는 트레이딩 모델을 구축합니다. 정상적인 상황에서 자본 흐름과 가격 추세는 네 가지 기본 상황으로 나눌 수 있습니다.

  • 가격이 상승하고 동시에 단위 시간당 순 자본 유입이 있습니다. 이 경우 강한 것으로 간주됩니다. 그리고 앞으로도 가격이 계속 상승할 확률은 더 큽니다.

  • 주가가 상승하고 동시에 단위 시간당 활성 자금의 순유출이 발생합니다. 중간 정도의 힘이 있고 향후 지속적인 가격 상승률이 크게 약화됩니다.

  • 주가가 하락하고 동시에 단위 시간당 자금이 순 유입됩니다. 이 경우 약점으로 간주되며 앞으로도 가격이 계속 하락할 확률이 더 큽니다

  • 주가가 하락함과 동시에 단위 시간당 활성 자금의 순유출이 발생합니다. 이 경우에는 중간 정도의 약세 상황이며 가격이 계속 하락하는 속도는 Java는 활성 자금 흐름을 기반으로 거래 전략을 어떻게 구현합니까?

주요 변수는 다음과 같습니다.

  • 예비 기간 저점(ll)

  • 이전 고점(hh)

  • 적극 매수(barIn)

  • 활성 판매(barOut)

  • 활성 유입 대 활성 유출 비율(barRatio)

  • 개방 임계값(openValve)

  • 현재 위치(myAmount)

  • L ast K 라인 종가 (닫기)

출구 및 진입 조건 좋은 양적 거래 전략에는 안정적인 수익뿐만 아니라 위험을 제어하고 작은 확률이 발생할 때 큰 손실을 피하는 능력도 필요합니다. 여기에서는 활성 자본 흐름을 추적하는 전략을 사용하고 단기 가격 예측을 통해 상품 선물의 시장 방향을 분석하여 높은 수익과 낮은 위험을 달성합니다. 전략 단계는 다음과 같습니다. Java는 활성 자금 흐름을 기반으로 거래 전략을 어떻게 구현합니까?

  • 롱 포지션 열기: 현재 포지션이 없고 barRatio > openValve인 경우 매수 포지션을 오픈합니다.

  • 숏 포지션 열기: 현재 포지션이 있는 경우 포지션이 없고 barRatio

  • 롱 포지션을 청산하고

  • 6. 전략 소스 코드 작성

데이터 획득 및 계산
function data() {
    var self = {};
    var barVol = [];
    var bars = _C(exchange.GetRecords); //获取bar数据
    if (bars.length  0; i--) {
        var barSub_1 = bars[bars.length - (i + 1)].Close - bars[bars.length - (i + 2)].Close; //计算当前收盘价与上个bar收盘价的价差
        if (barSub_1 > 0) { //如果价格涨了,就在数组里面添加正数
            barVol.push(bars[bars.length - (i + 1)].Volume * (bars[bars.length - (i + 1)].High - bars[bars.length - (i + 1)].Low));
        } else if (barSub_1  len) {
        barVol.shift(); //释放多余的数据
    }
    self.barIn = 0;
    self.barOut = 0;
    for (var v = 0; v  0) {
            self.barIn += barVol[v]; //合并全部主动流入的资金
        } else {
            self.barOut -= barVol[v]; //合并全部主动流出的资金
        }
    }
    self.barRatio = self.barIn / Math.abs(self.barOut); //计算主动流入资金与主动流出资金的比值
    bars.pop(); //删除未结束的bar数据
    self.close = bars[bars.length - 1].Close; //获取上根K线的收盘价
    self.hh = TA.Highest(bars, hgLen, 'High'); //获取前高
    self.ll = TA.Lowest(bars, hgLen, 'Low'); //获取前低
    return self;
}

GetRecords 메소드를 통해 막대 데이터 직접 획득 발명가의 정량화 API에서. 최고가, 최저가, 시가, 종가, 거래량, 표준 타임스탬프가 포함됩니다. 최신 거래 가격이 최종 거래 가격보다 큰 경우 최신 거래량*(최고 가격 - 최저 가격)이 활성 구매에 포함됩니다. 최신 거래 가격이 마지막 거래 가격보다 낮으면 최신 거래량이 포함됩니다. 거래량*(최고가 - 최저가)은 활성 매수에 포함됩니다. 거래량*(최고가 - 최저가)은 활성 매도에 포함됩니다.

포지션 데이터 가져오기

function positions(name) {
    var self = {};
    var mp = _C(exchange.GetPosition); //获取持仓
    if (mp.length == 0) {
        self.amount = 0;
    }
    for (var i = 0; i <p>기본 위치 데이터 가져오기 발명가의 정량적 API에 있는 GetPosition 메소드를 사용하여 이러한 기본 데이터를 추가로 처리합니다. 현재 매수 주문을 보유하고 있는 경우 플러스 포지션 수량을 반환하고, 현재 단기 주문을 보유하고 있다면 마이너스 포지션 수량을 반환합니다. 이는 포지션 개시 및 청산 로직의 계산을 용이하게 하기 위한 것입니다. <strong></strong></p>주문하고 거래하세요<p></p><pre class="brush:php;toolbar:false">function trade() {
    var myData = data(); //执行data函数
    if (!myData) {
        return;
    }
    var mp = positions(contractType); //获取持仓信息
    var myAmount = mp.amount; //获取持仓数量
    var myProfit = mp.profit; //获取持仓浮动盈亏
    if (myAmount > 0 && myData.close  myData.hh) {
        p.Cover(contractType, unit); //空头平仓
    }
    if (myAmount == 0) {
        if (myData.barRatio > openValve) {
            p.OpenLong(contractType, unit); //多头开仓
        } else if (myData.barRatio <p> 7. 전략 특징<strong></strong></p>특징: <h5></h5><p>몇 가지 핵심 매개변수: 모델 설계 아이디어가 명확하고 핵심 매개변수가 3개뿐입니다. 최적화를 위한 공간은 작고 과적합을 효과적으로 피할 수 있습니다. 강력한 보편성 : 전략논리가 단순하고 보편성이 높으며 농산물을 제외한 대부분의 품종에 적합하며 여러 품종과의 결합이 가능합니다. <strong></strong></p>개선: <p></p><p>추가된 포지션 조건: 일방향(주식) 시장 자본 흐름은 가격 상승 및 하락, 거래량 및 기타 요인을 기반으로 자본의 유입 또는 유출을 정의할 수 있습니다. 그러나 이 전략에는 포지션 조건이 포함되지 않기 때문에 액티브 자금 흐름 통계가 왜곡될 수 있습니다. <strong></strong>표준편차 조건 추가: 포지션 개설 조건이 자금 흐름에만 의존하면 잘못된 신호가 자주 발생하여 포지션이 자주 개설되고 청산될 수 있습니다. 지정된 기간 내 순 자금 유출의 평균과 표준 편차를 계산하여 잘못된 신호를 필터링합니다. </p><p>전체 전략 소스 코드: </p><pre class="brush:php;toolbar:false">/*backtest
start: 2016-01-01 09:00:00
end: 2019-12-31 15:00:00
period: 1h
exchanges: [{"eid":"Futures_CTP","currency":"FUTURES"}]
*/

var p = $.NewPositionManager(); //调用商品期货交易类库

//持仓数据处理
function positions(name) {
    var self = {};
    var mp = _C(exchange.GetPosition); //获取持仓
    if (mp.length == 0) {
        self.amount = 0;
    }
    for (var i = 0; i  0; i--) {
        var barSub_1 = bars[bars.length - (i + 1)].Close - bars[bars.length - (i + 2)].Close; //计算当前收盘价与上个bar收盘价的价差
        if (barSub_1 > 0) { //如果价格涨了,就在数组里面添加正数
            barVol.push(bars[bars.length - (i + 1)].Volume * (bars[bars.length - (i + 1)].High - bars[bars.length - (i + 1)].Low));
        } else if (barSub_1  len) {
        barVol.shift(); //释放多余的数据
    }
    self.barIn = 0;
    self.barOut = 0;
    for (var v = 0; v  0) {
            self.barIn += barVol[v]; //合并全部主动流入的资金
        } else {
            self.barOut -= barVol[v]; //合并全部主动流出的资金
        }
    }
    self.barRatio = self.barIn / Math.abs(self.barOut); //计算主动流入资金与主动流出资金的比值
    bars.pop(); //删除未结束的bar数据
    self.close = bars[bars.length - 1].Close; //获取上根K线的收盘价
    self.hh = TA.Highest(bars, hgLen, 'High'); //获取前高
    self.ll = TA.Lowest(bars, hgLen, 'Low'); //获取前低
    return self;
}

//交易函数
function trade() {
    var myData = data(); //执行data函数
    if (!myData) {
        return;
    }
    var mp = positions(contractType); //获取持仓信息
    var myAmount = mp.amount; //获取持仓数量
    var myProfit = mp.profit; //获取持仓浮动盈亏
    if (myAmount > 0 && myData.close  myData.hh) {
        p.Cover(contractType, unit); //空头平仓
    }
    if (myAmount == 0) {
        if (myData.barRatio > openValve) {
            p.OpenLong(contractType, unit); //多头开仓
        } else if (myData.barRatio <p> 8. 전략 백테스트 </p><h5></h5>전략 구성: <h5> </h5> <p>백테스트 성능: <strong> </strong> <img  src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/465/014/168181406915986.png?x-oss-process=image/resize,p_40" class="lazy" alt="Java는 활성 자금 흐름을 기반으로 거래 전략을 어떻게 구현합니까?" ><strong></strong></p>

위 내용은 Java는 활성 자금 흐름을 기반으로 거래 전략을 어떻게 구현합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?Mar 17, 2025 pm 05:46 PM

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:45 PM

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?Mar 17, 2025 pm 05:44 PM

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:43 PM

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Mar 17, 2025 pm 05:35 PM

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.