KR101667697B1 - 네트워크 컴퓨팅 자원에 의한 데이터 동기화 프로세싱 - Google Patents

네트워크 컴퓨팅 자원에 의한 데이터 동기화 프로세싱 Download PDF

Info

Publication number
KR101667697B1
KR101667697B1 KR1020127017789A KR20127017789A KR101667697B1 KR 101667697 B1 KR101667697 B1 KR 101667697B1 KR 1020127017789 A KR1020127017789 A KR 1020127017789A KR 20127017789 A KR20127017789 A KR 20127017789A KR 101667697 B1 KR101667697 B1 KR 101667697B1
Authority
KR
South Korea
Prior art keywords
execution
network computing
computing resources
data
timing parameter
Prior art date
Application number
KR1020127017789A
Other languages
English (en)
Other versions
KR20120101535A (ko
Inventor
대니얼 에이슨
브래들리 카츠야마
로버트 박
존 슈월
리처드 스타이너
앨런 장
토마스 엘 포프조이
Original Assignee
로얄 뱅크 오브 캐나다
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 로얄 뱅크 오브 캐나다 filed Critical 로얄 뱅크 오브 캐나다
Publication of KR20120101535A publication Critical patent/KR20120101535A/ko
Application granted granted Critical
Publication of KR101667697B1 publication Critical patent/KR101667697B1/ko

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/08Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
    • H04L43/0852Delays
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • G06F15/163Interprocessor communication
    • G06F15/173Interprocessor communication using an interconnection network, e.g. matrix, shuffle, pyramid, star, snowflake
    • G06F15/17306Intercommunication techniques
    • G06F15/17325Synchronisation; Hardware support therefor
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/52Program synchronisation; Mutual exclusion, e.g. by means of semaphores
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q40/00Finance; Insurance; Tax strategies; Processing of corporate or income taxes
    • G06Q40/04Trading; Exchange, e.g. stocks, commodities, derivatives or currency exchange
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/08Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
    • H04L43/0852Delays
    • H04L43/0858One way delays
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/08Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
    • H04L43/0852Delays
    • H04L43/0864Round trip delays
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/28Flow control; Congestion control in relation to timing considerations
    • H04L47/283Flow control; Congestion control in relation to timing considerations in response to processing delays, e.g. caused by jitter or round trip time [RTT]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/62Establishing a time schedule for servicing the requests
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/63Routing a service request depending on the request content or context

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Business, Economics & Management (AREA)
  • Accounting & Taxation (AREA)
  • Finance (AREA)
  • Theoretical Computer Science (AREA)
  • Environmental & Geological Engineering (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Marketing (AREA)
  • Strategic Management (AREA)
  • Technology Law (AREA)
  • Economics (AREA)
  • General Business, Economics & Management (AREA)
  • Development Economics (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Mathematical Physics (AREA)
  • Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
  • Multi Processors (AREA)
  • Hardware Redundancy (AREA)
  • Information Transfer Between Computers (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

본 발명은 멀티 네트워크 컴퓨팅 자원(106,1106)에 의한 데이터 프로세스의 관리를 위한 시스템(100,1000), 방법, 및 기계 해석가능한 프로그래밍 또는 데이터 명령어 제품에 관한 것이다. 특히, 본 명세서는 분산형 네트워크 자원을 이용해 데이터의 프로세스를 위한 관련된 요청의 동기화에 관한 것이다.

Description

네트워크 컴퓨팅 자원에 의한 데이터 동기화 프로세싱{Synchronized Processing of Data By Networked Computing Resources}
본 발명의 명세서는 멀티 네트워크 컴퓨팅 자원에 의한 데이터 프로세스의 관리를 위한 시스템, 방법 및 기계해석 프로그래밍 또는 다른 명령 제품들에 관한 것이다. 특히, 본 명세서는 분산 네트워크 자원을 이용해 데이터 프로세스를 위한 관련된 요청들의 동기화에 관한 것이다.
이 출원에 개시된 자료의 태양들은 보안 및 기타 금융 상품들의 보유, 양도, 및/또는 관리에 관한 것이다. 이런 보유, 양도, 및/또는 관리의 태양은 정부 및 기타 기관에 의한 규제를 받을 수 있다. 본 명세서는 법정, 규제 또는 기타 법적 고려 없이 단지 논리적, 프로그래밍 및 통신 가능성 면에서만 다룬다.
본 명세서에 제안되거나 개시된 임의의 시스템, 방법 또는 프로세스 또는 그 사용은 어떤 사법권에서 어떤 정관, 법, 규제 또는 기타 법적 요건과 부합하거나, 그렇게 함으로써 취해지거나 해석되는 진술 또는 표현으로 전혀 의도하고 있지 않다.
다양한 형태의 네트워크 또는 다른 경우 분산데이터 프로세싱 시스템에서, 복잡 및/또는 여러 관련된 프로세스들이 종종 실행을 위해 멀티 컴퓨팅 자원으로 라우팅된다. 가령, 금융 및 기타 거래 시스템에서, 금융 상품의 구매를 위한 주문, 판매, 및 기타 거래들이 종종 실행을 위해 여러 시장 또는 거래소 서버로 라우팅된다. 이러한 경우, 여러 서버들로 라우팅된 주문 또는 기타 데이터 프로세싱 요청들이 동시에 또는 가능한 한 동시에 가깝게 실행되거나 어떤 다른 경우에는 소정의 동기화 형태로 또는 시간 순서대로 실행되는 것이 이점적일 수 있다.
예컨대, 이런 주문들이 여러 시장에서 비동기식으로 주문체결될 경우, 네트워크 전자시장에서 실행되는 금융 상품과 관련된 이런 주문들에 대한 체결률(fill rates)이 상당히 줄어든 것이 관찰되었다. 이런 주문들이 늘어난 전자시장들로 라우팅 됨에 따라 체결률의 저하가 증가되는 것이 또한 관찰되었다. 이는 적어도 부분적으로 주문의 최초 요소들이 체결된 후 이런 주문들의 연이은 부분들의 실행시 지연으로 인한 것이다: 주문이 또 다른 시장에 앞서 한 시장에서 실행되었을 경우, 판매로 인한 단기 수익을 극대화하기 위해 노력하는 당사자들에 의한 가격 조작을 위해 개입 시간주기가 때로 이용된다: 최초 주문부분이 체결될 경우, 병행시장의 매도 또는 입찰에 있어서 자동 변경이 구현될 수 있어, 이전 공개된 입장이 철회되고 후속 거래가 제한되게 한다.
예를 들면, 대량 주문이 (가령, 각 시장에서 가용한 유동성을 기초로 한) 여러 거래소들로 보내지면, 주문은 더 느린 거래소(즉, 고유 지연이 큰 거래소)에 도달하기 전에 가장 빠른 거래소(즉, 고유 지연이 거의 없는 거래소)에 도달하는 경향이 있고, 이에 따라 다른 시간에 다른 거래소들의 명단에 나타난다. 주문이 더 빠른 거래소의 명단에 나타나기 시작하면, 다른 당사자들은 주문을 발견할 수 있고 취소, 변경 및/또는 그렇지 않으면 시가 조작(가령, 입찰 및 매도) 또는 느린 교환소에 대한 다른 시장 파리미터들에 의해 더 느린 교환소에서의 지연을 이용하려고 시도하여 내포된 거래 비용을 효과적으로 높일 수 있다. 그 결과, 그렇지 않고 임의의 단일 교환소에서 높은 체결률로 실행될 수 있는 주문들은 분할 거래(split trade)로서 여러 교환소들로 라우팅되는 경우에 전반적으로 낮은 체결률을 보이는 경향이 있다.
로니 케이(Rony Kay) 논문 "Pragmatic Network Latency Engineering, Fundamental Facts and Analysis"과 같은 종래 기술의 참조문헌들은 일방(one-way) 통신(즉, "패킷") 지연의 제거를 제안함으로써 이런 문제들을 해결하기 위해 시도했다. 이런 시스템들은 멀티 프로세서들이 통신 지연 이외에 (또는 일부로서) 멀티-프로세서 실행 요청의 개별적 부분들을 실행하는데 걸린 시간 변화(즉, 실행 지연(execution latencies))로 인해 야기되거나 조성되는 차액취득거래 기회 및 기타 문제들을 해결하지 못한다.
다양한 태양으로, 본 발명은 멀티 네트워크 컴퓨팅 자원에 의한 데이터 프로세스의 관리를 위한 시스템, 방법 및 소프트웨어 코드 명령어 세트 및 데이터와 같은 컴퓨터 실행가능한 명령 메카니즘(예컨대, 비일시적 기계판독식 프로그래밍 구조)을 제공한다. 특히, 예컨대, 본 발명은 분산 네트워크 자원을 이용한 데이터 프로세스를 위한 관련된 요청들의 동기화를 제어하는데 유용한 시스템, 방법 및 코드 명령어 세트를 제공한다.
예컨대, 제 1 태양으로, 본 발명은 예컨대 시스템이 기계 해석가능한 명령어를 실행하도록 구성되고, 상기 시스템이
복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 적어도 하나의 데이터 프로세스의 실행을 위한 명령어를 나타내는 신호를 하나 이상의 데이터 소스로부터 수신하게 하고,
적어도 하나의 데이터 프로세스를 복수의 데이터 프로세싱 세그먼트들로 분할하게 하며,
복수의 네트워크 실행 프로세서들 각각으로 시스템에 의해 라우팅된 이전 데이터 프로세싱 요청의 실행시 적어도 부분적인 지연을 기초로, 복수의 타이밍 파라미터들을 결정하게 하고,
복수의 데이터 프로세싱 세그먼트들과 관련된 타이밍 파라미터들을 이용해, 복수의 데이터 프로세싱 세그먼트들을 복수의 네트워크 실행 프로세서들로 보내게 하는 적어도 하나의 프로세서를 구비하고,
각 데이터 프로세싱 세그먼트는 복수의 네트워크 실행 프로세서들 중 다른 하나로 보내지고,
상기 복수의 타이밍 파라미터들 각각은 복수의 데이터 프로세싱 세그먼트들 중 대응하는 프로세싱 세그먼트에 대한 것이며, 상기 복수의 타이밍 파라미터들은 복수의 네트워크 실행 프로세서들에 의해 복수의 데이터 프로세싱 세그먼트들의 동기화된 실행을 야기하도록 결정되는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세스를 야기하는 시스템, 방법 및 프로그래밍 또는 기타 기계 해석가능한 명령어를 제공한다.
몇몇 실시예에서, 본 명세서에 설명된 바와 같이, 네트워크 실행 프로세서는 예컨대 거래소 서버를 구비할 수 있고, 데이터 프로세싱 세그먼트는 상품과 같은 투자관계 및/또는 주식, 채권 및/또는 다양한 옵션 형태들과 같은 무형의 관계를 위한 거래 요청을 나타낸다.
복수의 결정된 타이밍 파라미터들은 본 발명에 따른 데이터프로세싱 요청의 소정의 연속 실행을 구현하기 위해 타이밍 시퀀스를 결정하고 실행하는데 이용될 수 있고, 예컨대, 많은 요인들로 인해 데이터 프로세싱 요청의 실행시 전체적으로 또는 부분적으로 지연을 나타내고/나타내거나 기초할 수 있다. 가령, 이런 파라미터들은 시스템에 의해 복수의 네트워크 실행 프로세서들 중 적어도 하나로 이전에 라우팅된 신호 프로세싱 요청들의 실행시 동적으로 모니터되는 지연(들)을 전체적으로 또는 부분적으로 기초로 할 수 있다. 이런 지연은 예컨대, 다양한 타입들의 통신 및 데이터 프로세스 지연을 포함한 많은 요인들에 의해 야기될 수 있다. 이런 타이밍 파라미터들은 통계, 예컨대 확률, 관찰된 지연 데이터의 모델, 및 패턴들을 더 기초로 할 수 있다.
이런 시스템, 방법 및 프로그래밍 또는 기타 기계 판독가능한 명령어들은 시스템이 각각의 복수의 데이터 중 적어도 하나와 적어도 하나의 수량 조건을 나타내는 프로세싱 세그먼트 데이터를 연관시키게 하고,
상기 적어도 하나의 수량 조건은 각각의 적어도 하나의 데이터 프로세싱 세그먼트들을 나타내는 요청에 따라 거래되는 금융 상품의 적어도 하나의 수량 및 각 이러한 수량 조건에 대한 적어도 하나의 해당 가격 조건을 나타내며, 상기 수량 조건은 적어도 하나의 데이터 프로세싱 세그먼트에 의해 표현된 거래가 실행되는 적어도 하나의 제안 가격을 나타내고,
상기 적어도 하나의 수량 조건은 적어도 하나의 데이터 프로세싱 세그먼트가 라우팅되는 네트워크 실행 프로세서(들)에 대한 시장에서 해당 관련된 가격 조건과 등가의 가격으로 공모된 금융 상품 중 적어도 하나의 수량보다 더 크도록 더 구성될 수 있다.
이런 수량 조건은 가령 데이터 프로세싱 세그먼트가 라우팅되는 네트워크 실행 프로세서와 관련된 시장에 대한 거래 이력(history)을 적어도 부분적으로 기초로 하여 결정될 수 있다. 이들은 예컨대 이력적으로 디스플레이되지 않은 오버사이즈 또는 예비 수량을 포함한 디스플레이되거나 디스플레이되지 않은 매물 및/또는 거래에 관한 데이터에 대해 결정될 수 있다.
다른 태양으로 본 발명은
예컨대, 기계 해석가능한 명령어를 실행하도록 구성되고, 시스템이
복수의 네트워크 컴퓨팅 자원들 각각에 의해 신호프로세스 실행요청의 실행을 모니터하게 하고,
시스템과 복수의 네트워크 컴퓨팅 자원들 각각 사이에 신호프로세스의 실행시 지연에 대한 적어도 하나의 타이밍 파라미터를 결정하게 하며,
적어도 하나의 프로세서에 의해 접속될 수 있는 기계판독가능한 메모리에 적어도 하나의 타이밍 파라미터를 저장하게 하는 적어도 하나의 프로세서를 구비하는 멀티 네트워크 컴퓨팅 자원들, 이런 시스템들에 의한 데이터의 동기화 프로세스를 하기 위한 시스템, 방법 및 프로그래밍 또는 다른 기계 판독가능한 명령어를 제공한다.
본 발명의 이런 및 다른 실시예에 따른 신호프로세스 실행요청의 실행 모니터링은 연속적, 주기적 및/또는 다른 적절하거나 바람직한 기반을 토대로 실행될 수 있다.
본 발명의 다양한 태양의 다양한 실시예에서, 네트워크 컴퓨팅 자원은 하나 이상의 거래소 서버들을 포함할 수 있다. 데이터 소스들은 하나 이상의 중개자 또는 트레이더 시스템 또는 서버를 포함할 수 있고, 컨트롤된 신호 프로세서들이 금융 상품에 있는 거래를 나타낼 수 있고, 신호프로세스 실행요청의 실행은 예컨대, 주식, 채권, 옵션 및 계약 이율, 통화 및/또는 기타 무형의 상품, 및/또는 재화를 포함한 금융 상품에서 거래의 실행을 나타낸다. 이런 실시예에서, 데이터 프로세스 절차의 실행을 위한 요청은 각 네트워크 컴퓨팅 자원에서 주문 수량의 실행시 예컨대 임의의 하나 이상의 현재 시장 데이터 시세, 주문 라우팅 규칙, 주문 특징, 각 네트워크 컴퓨팅 자원의 디스플레이되는 유동성, 및 가능한 지체 또는 지연을 포함한 파라미터에 전체적으로 또는 부분적으로 기초로 할 수 있다.
동일 및 다른 태양으로, 본 발명은 분산형 컴퓨터 자원에 의한 데이터 프로세스를 위한 요청을 컨트롤하거나 아니면 관리하는 시스템을 제공하며, 상기 시스템은
복수의 네트워크 컴퓨팅 자원들 각각에 의해 신호프로세스 실행요청의 실행을 모니터하게 하고,
시스템과 복수의 네트워크 컴퓨팅 자원들 각각 사이에 신호프로세스의 실행시 지연에 대한 적어도 하나의 타이밍 파라미터를 결정하게 하며,
복수의 네트워크 컴퓨팅 자원 각각에 대한 적어도 하나의 타이밍 파라미터들을 저장하게 하는 명령어를 실행하도록 구성된 하나 이상의 프로세서들을 포함한다.
본 발명에 의해 제안된 많은 이점들 중에 동적, 또는 '롤링' 기반으로 여러 부분 또는 다른 복잡한 데이터 프로세싱 요청의 네트워크 프로세스시 지연 및 기타 요인들을 모니터하고 본 명세서에 개시된 동기화 프로세싱 요청의 실행시 이용되는 타이밍 파라미터를 결정하는 데 있어 이런 동적으로 모니터되는 지연 및/또는 다른 인자들을 이용하는 가능성이 있다. 동기화 프로세싱 요청을 실행하는데 이용되는 타이밍 파라미터는 적용되는 애플리케이션의 필요, 목적, 및 기타 요인들에 따라 연속적이거나, 거듭되거나, 주기적이거나 기타 기반으로 모니터 및/또는 결정될 수 있다.
본 발명에 의해 제공된 다른 이점은 일방향 통신 지연을 고려할 필요성, 예컨대 라우팅 및 실행 프로세서들 간의 통신시 지연을 최소화할 필요성의 축소 또는 제거이다.
당업자에 인식되는 바와 같이, 이들이 본 명세서에 익숙해지면, 예컨대 이런 프로세스를 위한 요청의 동기화 전송에 의한 분산형 데이터 프로세싱 요청의 실행 동기화가 매우 많은 데이터 프로세스 분야에서 아주 많은 가능한 애플리케이션을 갖는다.
본 발명의 내용에 포함됨.
본 명세서의 예시적인 실시예로써 도시된 도면들을 참조로 한다.
도 1a, 도 1b 및 도 3은 본 발명의 다양한 태양에 따른 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 프로세스를 야기하는데 적합한 시스템의 예를 도시한 것이다.
도 2 및 도 4는 본 발명의 다양한 태양에 따른 멀티 네트워크 컴퓨팅 자원의 프로세스를 야기하기 위한 방법 예들을 나타낸 흐름도를 도시한 것이다.
도 5는 본 발명의 다양한 태양에 따른 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 프로세스를 관리하기 위한 일예시적인 방법에 사용될 수 있는 예시 히스토그램을 도시한 것이다.
도 6a 및 도 6b는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 프로세스를 위한 예시적인 방법 및 시스템을 이용하는 것 대 종래 방법 및 시스템을 이용한 것의 체결률의 비교를 도시한 것이다.
도 7은 종래 기술의 방법 및 시스템의 이용 결과 대 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 프로세스를 위한 예시적인 방법 및 시스템을 비교하기 위한 예시적인 측정의 이용을 도시한 것이다.
첨부도면 전체에 걸쳐 동일한 특징은 동일한 참조부호로 식별된다.
본 명세서에서, 당업자들이 아는 바와 같이, '동기화'라는 것은 규칙적, 불규칙적 및/또는 전체적으로 또는 부분적으로 동시이든지 간에 임의의 소정의 타이밍 시퀀스를 따르는 것을 말한다.
도 1은 본 발명에 따른 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 프로세스를 야기하는데 적합한 시스템(100)의 예를 도시한 것이다.
도시된 예에서, 시스템(100)은 (하나 이상의 각각의 소스(102a,102b)를 포함한) 하나 이상의 신호 또는 데이터 소스(102), 실행 라우터 프로세서(들)(104), 및 하나 이상의 네트워크 컴퓨팅 자원 또는 실행 프로세서(106)를 포함한다. 몇몇 실시예에서, 데이터 소스(102)는 하나 이상의 내부 데이터 소스들(102a)를 포함할 수 있고, 상기 소스들(102a)은 (예컨대, 사설 LAN이나 WAN 또는 다른 보안 무선 또는 유선 통신을 통해, 직접 통신채널(들)을 통해 또는 단일 서버내 통신(들)을 통해) 직접 라우터(104)와 통신할 수 있다. 동일 및/또는 다른 실시예에서, 데이터 소스들(102)은 또한 하나 이상의 외부 데이터 소스들(102b)을 포함할 수 있으며, 상기 소스들(102b)은 예를 들어 데이터 암호화 등을 포함할 수 있는 적절한 또는 그렇지 않으면 소정의 네트워크 보안 디바이스를 이용해 예컨대 하나 이상의 공중망(108)(가령, 인터넷과 같은 공중 또는 사설 통신망)을 통해 라우터 프로세서(들)(104)와 통신할 수 있다. 도시된 예에서, 라우터 프로세서(들)(104)는 네트워크(108)와 같거나 다를 수 있는, 네트워크(110)를 통하여 하나 이상의 네트워크 실행 또는 컴퓨팅 자원(106) 각각과 통신할 수 있다.
다양한 실시예에서, 데이터 소스(들)(102)은 거래 및/또는 다른 데이터 프로세싱 요청을 발생하는 하나 이상의 엔티티들을 대신해 라우터 프로세서(들)(104)로 데이터 프로세싱 프로세스의 실행과 관련된 데이터 및/또는 명령어를 라우팅하는 신호를 제공하는 디바이스들을 포함할 수 있고, 상기 라우터 프로세서(들)(104)가 (가령, 합, 평균 등으로 합계; 및/또는 세그먼트로 분할하기 등) 어떤 데이터 및/또는 명령어를 프로세스할 수 있고 네트워크 컴퓨팅 자원(106)에 의한 데이터 프로세싱 요청들에 대한 기반으로서 이용될 수 있다. 데이터 소스(102a,102b)는 예컨대 원자재(commodities)의 구매, 무형의 금융 상품 등을 위한 매도 및/또는 입찰과 같은 데이터 프로세싱 업무 및/또는 워드, 이미지 및/또는 다른 통신 또는 문서 프로세싱 업무와 같은 기타 데이터 프로세싱 업무의 실행을 위한 요청의 시스템, 서버, 프로세서 및/또는 임의의 적절한 소스(들)를 포함할 수 있다. 데이터 소스(들)(102), 프로세서(들)(104), 및 자원들(106) 각각 또는 어느 하나가 이런 멀티 시스템, 서버, 또는 프로세서를 포함할 수 있다.
다양한 실시예에서, 데이터 소스(들)(102) 및 라우터 프로세서(들)(104) 중 일부 또는 모두가 단일 장치상에 실행되는 멀티 프로그래밍 또는 다른 기계명령 애플리케이션을 실행하도록 결합 및/또는 그렇지 않으면 구성될 수 있다.
네트워크 컴퓨팅 자원(106)은 매우 광범위한 데이터 프로세싱 요청들 중 어느 하나를 수신하고 실행하기 위해 라우터 프로세서들(104)과 통신하는 임의의 디바이스들 또는 다른 자원들을 포함할 수 있다. 이런 네트워크 컴퓨팅 자원(106)은 가령 재화의 구매, 금융 상품 등을 위한 매도 및/또는 입찰의 프로세스 및/또는 워드 또는 문서프로세스, 이미지와 같은 다른 데이터 프로세스업무 및/또는 다른 통신 또는 문서 업무를 포함한 본 발명의 실행시 사용에 적합한 임의의 프로세서들의 실행에 적합한 시스템, 서버, 프로세서 또는 임의의 다른 적절한 디바이스들을 포함할 수 있다.
다양한 실시예에서, 하나 이상의 데이터 소스들(102)이 데이터 프로세스 기능을 실행하기 위한 명령어 또는 요청을 나타내는 신호들을 라우터 프로세서들(104)에 또는 라우터 프로세서들(104) 용으로 보내거나 아니면 제공한다. 임의의 주어진 데이터 소스들(102)로부터의 명령들은 임의의 하나 이상의 컴퓨팅 자원(106)에 의해 프로세스되는 신호 프로세서용 명령어를 포함할 수 있다. 요청된 신호 프로세서들은 다른 것들 중에서 예컨대 컴퓨팅 연산, 데이터 조작 및/또는 통신 프로세서 또는 기타 신호 교환을 포함할 수 있다. 몇몇 하지만 반드시 모두가 그렇지 않은 예에서, 이런 명령어들은 특히 이런 프로세서의 실행을 위해 목표로 된 네트워크 컴퓨팅 자원(들)(106)을 명확히 식별할 수 있다.
라우터 프로세서(들)(104)는 하나 이상의 자원(들)(102)으로부터 수신된 명령어 신호를 분석하고 수신된 명령어에 따라 데이터 프로세싱 및/또는 기타 신호 프로세스의 실행을 위해 이런 신호들을 이용해 명령어, 또는 요청들이 복수의 실행 프로세서들(106)로 전송되게 준비한다. 이런 명령어의 분석은, 예컨대, 행해질 문서 프로세싱 양 또는 거래의 주문 또는 입찰 분량 또는 수량, 및 주어진 데이터 프로세싱 및/또는 다른 신호 프로세싱 요청을 실행하고 이로써 이와 관련되도록 요청되는 네트워크 컴퓨팅 자원(들)(106)의 타입, 특성 및/또는 식별(들)을 포함한 요청된 프로세스(들)의 타입을 식별하는 단계를 포함할 수 있다.
예컨대, 신호 및/또는 다른 데이터 프로세싱 함수의 효율을 높이기 위해, 라우터 프로세서(들)(104)는 상대적으로 더 작은 실행요청을 위해 멀티 소스들(102)로부터 수신된 명령어 또는 요청들을 하나 이상의 더 큰 프로세싱 요청들로 분석, 분류 또는 규합할 수 있고, 예컨대 이런 프로세싱 요청들을 만족시키거나 완료하기 위한 실행 프로세서들(106)의 현재 능력에 따라 이러 규합된 요청(들)을 복수의 실행 프로세서들(106)에 분산되는 복수의 더 작은 요청들로 더 나눌 수 있다.
예컨대, 다른 데이터 소스(102a,102b)로부터 수신된 멀티 명령어 신호 세트가 개개의 네트워크 컴퓨팅 자원(들)(106)과 결합(가령, 전달 및 실행을 위해 어드레스)될 수 있고, 이런 명령어는 이런 네트워크 컴퓨팅 자원(들)(106)에 대한 단일 신호 프로세싱 실행 요청들에 규합될 수 있다. 몇몇 예들에서, 소정의 신호 프로세싱 요청을 맡은 네트워크 컴퓨팅 자원(들)(106)의 식별이 규합 후 수행될 수 있다. 예컨대, 다른 데이터 소스(102a,102b)로부터 멀티 명령어들이 저장되거나 아니면 단일 신호 또는 데이터 프로세스와 결합될 수 있고, 이런 명령어들은 규합될 수 있으며, 규합된 명령어들은 하나 이상의 식별된 네트워크 컴퓨팅 자원(들)(106)과 결합될 수 있어, 하나 이상의 신호 프로세싱 요청들은 이에 따라 식별된 네트워크 컴퓨팅 자원(들)(106)을 위해 준비될 수 있다. 이런 분석, 분류 및/또는 식별은 (가령, 하나 이상의 특정 네트워크 컴퓨팅 자원(들)(106)의 구성 또는 현재 프로세스 능력을 기초로) 기설정된 규칙 또는 알고리즘에 따라 그리고 적절한 곳에서 명령어에 인코딩되거나 아니면 원래 소스(들)(102)에 의해 제공된 요건들에 따라 수행될 수 있다.
다른 예로, 데이터 프로세스를 위한 단일 명령어 세트들이 프로세서(들)(104)에 의해 분해되고 분산 실행을 위한 복수의 자원들(106)에 분산될 수 있다. 예컨대, 단일 소스(102a,102b)로부터 발생한 하나 이상의 금융 상품들에서 거래를 위해 비교적 큰 주문은 완전히 체결되기 위해 다수의 거래소 서버들(106)에 분산될 필요가 있을 수 있다; 이런 경우 하나 이상의 소스(들)(102)로부터의 요청(들)이 복수의 이런 자원들(106)에 의한 실행을 위한 적절한 주문들로 프로세서(들)(104)에 의해 분해될 수 있다.
타겟된 또는 명확히 식별된 네트워크 컴퓨팅 자원/실행 프로세서들(106)이 세그먼트된 신호 프로세스 실행 요청들을 수신하기 위해 라우터 프로세서(들)(104)와 통신하고 그런 후 이에 따라 실행할 수 있다. 이런 신호 프로세스의 실행은 예컨대 다른 것들 중에서 텍스트 또는 이미지프로세스 연산, 수학적 계산 또는 통신 신호교환을 실행하는 것을 포함할 수 있다.
당업자들에 의해 쉽게 이해되는 바와 같이, 시스템(100)의 다양한 구성요소들이 결합될 수 있거나, 별개의 시스템들 또는 장치들의 형태로 실행될 수 있다. 폭넓게 다양한 구성들로, 이런 결합되거나 별개의 (서브)시스템들은 동일하거나 다른 엔티티들에 의해 동작될 수 있다. 특별한 예로서, 하나 이상의 요청 소스(들)(102)는 개개의 라우터(들)(104)와 통합될 수 있거나 아니면 결합될 수 있다.
본 발명에 따른 세그먼트 프로세싱 요청들의 분산 실행을 위한 시스템(100)의 적용 예는 거래 및/또는 거래를 위한 매물, 또는 주식, 채권, 통화(예컨대, 외환), 다양한 형태의 천연자원 또는 공산품, 옵션, 대출 등과 같은 유무형 금융 상품에 있어 다른 거래를 나타내는 데이터 프로세싱 요청의 프로세싱을 위해 형성된 금융 시스템(1000)에 의해 제공된다. 도 1a 및 도 1b에 도시된 바와 같이, 예컨대, 본 발명에 따른 금융 거래 데이터 프로세싱 시스템(1000)에서, 신호 또는 데이터 소스(들)(102)는 가령 트레이더/중개업자 시스템들 또는 서버들뿐만 아니라 임의의 다른 입찰, 매도 또는 공지된 금융거래 플랫폼에 의해 현재 제공된 것과 같은 금융 상품에 있어 다른 거래를 포함할 수 있는 거래 시스템(들)(1102)을 포함할 수 있다. 다양한 실시예에서, 이런 트레이더 시스템(1102)을 주문 발신 시스템이라 할 수 있다.
주문 발신 시스템(1102,102a)은 예컨대 은행 또는 증권회사와 같은 모회사 또는 다른 컨트롤 기관들에 의해 소유되거나 아니면 컨트롤되는 엔티티들에 의해 또는 엔티티들을 대신해 동작되는 시스템을 포함할 수 있다. 주문 발신 시스템(1102,102a)은 예컨대 별도로 컨트롤되는 은행들, 대규모 자금운용을 하는 기관투자가들, 및/또는 다른 증권회사들을 통해 또는 도움으로 거래하는 가령 개개의 투자자들을 대신해 행하는 중개업자 또는 다른 거래 엔티티들에 의해 또는 대신해 동작되는 시스템을 포함할 수 있다.
이런 실시예에서 라우터 프로세서(들)(104)는 가령 금융 상품에 있어 거래의 실행 및/또는 통지를 나타내는 데이터의 프로세싱을 위한 인코딩된 전자 신호들의 송수신을 통해 예컨대 트레이더 시스템(1102,102)과 통신하고; 중개업자, 거래소, 또는 다른 시장 시스템 또는 이런 거래들의 실행을 위한 실행 프로세서(들)(1106)과 통신하는 예컨대 서버(들) 또는 기타 시스템(들)(1104)을 포함할 수 있다. 이런 실시예에서, 프로세서(104)를 스마트 오더 라우터(Smart Order Router) 또는 택티컬 하이브리드 오더 라우터(Tactical Hybrid Order Router)(어느 한 경우, "SOR")(1104,104)라 할 수 있다. SOR(1104)은 예컨대 하나 이상의 트레이더 시스템(1102,102)과 (가령, 하나 이상의 전용 통신 채널(들)을 이용한 유선 통신을 통해, 또는 단일 서버내 통신을 통해) 직접적으로 및/또는 (가령, 무선 통신을 통해, 네트워크(108,1108)를 통해 또는 중간 서버를 통해) 간접적으로 라우터(들)(1104)에 의한 통신을 용이하게 하기 위한 하나 이상의 게이트웨이(들)(1112) 및/또는 라우터(들)(1124)를 포함할 수 있다. 거래소 또는 시장 시스템(1106) 또는 기타 실행 프로세서(들)(106)는 가령 네트워크(1108)와 동일할 수 있는 인터넷 또는 다른 공중망과 같은 네트워크(110,1110)를 통해 SOR(s)(1104)와 통신될 수 있다.
금융 거래 또는 주문 실행 시스템(1000)으로 구성된 시스템(100)의 실시예로, 소스(들)(102)에 의해 제공된 요청 및 실행된 신호 프로세스들은 금융 상품에서 거래 또는 기타 거래들을 나타낼 수 있다. 이런 거래들은 예컨대 주식, 채권, 통화(가령, 외환), 다양한 형태의 천연자원 또는 상품들, 옵션, 대출 등과 같은 금융 상품에 있어 거래 및/또는 거래를 위한 매도, 또는 기타 거래를 포함할 수 있다; 네트워크 컴퓨팅 자원들(106)은 예컨대 자동화 또는 전자 시장 시스템을 포함할 수 있는 예인 거래소 서버들(1106)일 수 있다.
당업자들이 잘 아는 바와 같이, 이런 거래 요청신호 세트를 수신하는 SOR (서브)시스템 또는 프로세서(1104)는 폭넓게 다양한 프로세스들을 요청(들)에 적용할 수 있다. 예컨대, 신호 세트가 금융 상품에 있어 거래를 위한 요청을 나타내는 경우, 요청된 거래는 시간에 걸쳐 및/또는 여러 거래 요청 소스들(1102)에 걸쳐 규합될 수 있다; 및/또는 하나 이상의 이해관계들에 있어 거래를 위한 프로세싱 요청들은 개별적으로 또는 배치로 멀티 실행 핸들러 또는 프로세서들(1106)로 라우팅을 위해 분할하어질 수 있다.
본 명세서에 기술된 다양한 실시예에서, 주문 소스(들)(102,1102)은 주문 라우터(들)(104,1104)와 함께 또는 일부로서 실행될 수 있다. 이는 예컨대, 프로세서(들)(102,104,106) 중 어느 하나 또는 모두를 포함한 시스템(들)(100,1000)의 다양한 구성요소들 중 어느 하나 또는 모두 및 본 명세서에 따라 동작하는 방법이 본 명세서에 개시된 목적을 위해 구성된 임의의 디바이스, 소프트웨어, 및/또는 펌웨어를 이용해 실행될 수 있는 것이 당업자에게 쉽게 이해된다. 이런 시스템, 디바이스 및 방법을 실행하기 위해 단독으로 및/또는 다양한 조합으로 이용될 경우 적절한 하드웨어 및 소프트웨어 모두의 폭넓게 다양한 구성요소들뿐만 아니라 펌웨어들이 현재 알려져 있다; 의심할 여지 없이 다른 것들도 하기에 설명할 것이다.
시스템(100,1000)의 실행예에 사용하기 적합한 구성요소들의 예들 및 가령 도 2의 프로세서(200)와 도 4의 프로세서(300)를 포함한 본 명세서에 개시된 다양한 프로세서들은 예컨대 IBM x3850 M2TM, HP ProLiant DL380 G5TM, HP ProLiant DL585TM, 및 HP ProLiant DL585 GlTM과 같은 서버급 시스템을 포함한다. 몇몇 실시예에서 데스크탑, 랩탑, 또는 팜 모델 시스템을 포함한 폭넓게 다양한 다른 프로세서들이 이용된다.
가령 시스템(1000)의 SOR(1104)과 같은 라우터 프로세서(들)(104)에 의한 실행에 적합한 거래 요청 신호소스(102,1102)에 의해 발생된 거래 요청 신호 세트의 프로세스를 위한 방법(200)의 일예가 도 2에 도시되어 있다.
도 2의 프로세서(200)는 가령 하나 이상의 금융 상품들의 거래와 같은 데이터 프로세스를 위한 요청을 나타내는 신호의 프로세서(들)(104,1104)에 의한 수신으로 단계(202)에서 시작하는 것이 고려될 수 있다. 거래 신호 소스(들)(1102)로부터 수신된 금융 상품의 거래 및/또는 다른 거래들의 실행을 위한 요청을 나타내는 신호들을 프로세스하도록 형성된 SOR 라우팅 프로세서(들)(1104)을 포함한 시스템(100,1000)의 실시예에서, 하나 이상의 금융 상품에 있어 거래의 실행을 위한 요청을 나타내는 신호 세트들은 예컨대
·트레이딩 시스템(102,1102)에 의해 사용되거나 아니면 연결된 URL 또는 기타 네트워크 어드레스 또는 식별자와 같은 요청의 소스(들);
·주식, 채권용 CUSIP 번호, 교환되는 통화 세트 등을 식별하기 위해 하나 이상의 거래소들이 사용하는 식별자와 같이 거래되거나 아니면 거래되는 이해관계(들);
·실행되거나 요청되는 거래 타입(가령, 구매, 판매, 입찰, 매도 등);
·(가령, 임의의 총액 및/또는 예비금을 포함한) 피거래 관계(들)의 하나 이상의 양(즉, 액수 또는 분량); 및
·해당 가격 조건을 나타내는 하나 이상의 식별자들을 나타내는 신호 또는 신호 세트를 포함할 수 있다.
다른 파라미터들은 예컨대 현재 및/또는 역사적
·여러 부분 또는 세그먼트 거래 요청들에 대한 체결 확률(fill probability)(즉, 거래 완료된 여러 부분 주문들의 역사적 비율);
·가령, 시세폭에서 현재 및/또는 역사적 경향과 관련된, 예컨대 입찰 및 매도 가격 간의 시세폭 량;
·거래되거나 관련된 특정 관계들 또는 해당 계(들) 또는 관련된 벤치마크 또는 지수들(indexes)에서 시장 변동성;
·시가 장부가(market book)(들)의 깊이, 예컨대 광범위하게 걸쳐 역사적 경향에 대한 현재 깊이;
·보유량;
·표시량; 및
·가령 구매 및/또는 판매측에 대한 표시 크기 및 밀림(backing)을 포함할 수 있다.
다른 실시예에서, 이런 신호 세트들은 이미지, 텍스트, 또는 기타 컨텐츠를 나타내거나 하나 이상의 실행 프로세서들(104,1104) 및 특정 실행요청에 의해 프로세스되는 컨텐츠 및/또는 식별자들을 포함할 수 있다.
본 발명의 다양한 실시예와 적절한 시장 시스템(1106)의 많은 타입들 가운데 '다크(dark)' 거래소 또는 '다크 풀(dark pools)'로 알려진 타입의 대체거래시스템(ATSs)이 있다. 일반적으로, 이런 거래소들은 공개적으로 거래하는 일반회원들에 시장 제안을 나타내지 않는다. 공지된 또는 예상된 보유량의 사용은 특히 이런 실시예에 유용할 수 있다.
따라서, 진술된 조건에 대한 소정의 관계에서 거래를 요청하기 위해 소스(102,1102)에 의해 제공되는 데이터 레코드의 일예는 다음을 포함할 수 있다:
<요청 소스(102, 1102)><거래 타입><관계 식별자><액수(들)><가격조건(들)>
202에서 프로세서(104,1104)에 의해 수신된 신호 세트들은 기록 및/또는 다른 프로세스를 위해 적절하게 임의의 휘발성 및/또는 영구 메모리(들)에 저장될 수 있다.
204에서는, 202에서 수신된 거래 또는 다른 데이터 프로세스 실행요청들은 실행 프로세서(들)(106,1106)에 제공되도록 하나 이상의 명령어 신호 세트들을 준비하는데 이용하기 위한 임의의 적절한 또는 소정의 형태로 두기 위해 라우터 프로세서(들)(104,1140)에 의해 분석될 수 있다. 명령어 신호의 분석은 예컨대 특정 관계(들)에서 거래를 위한 주문 또는 입찰 분량 및/또는 수량을 포함한 요청된 거래(들) 또는 프로세스(들)의 타입 및 이런 양들이 구매 또는 판매된 것인지 혹은 판매 또는 구매를 위해 제공된 것인지 식별하고; 행해질 문서 프로세스량 및/또는 타입; 및 네트워크 컴퓨팅 자원(들) 또는 실행에 요청되고 이로써 이런 실행 또는 프로세스 명령어와 관련된 실행 프로세서(들)(106)의 타입과 특성을 식별하는 것을 포함할 수 있다. 다양한 실시예에서, 분석된 명령어 세트들은 다른 프로세싱 요청들과 함께 규합, 멀티 실행 프로세서들/자원들(106,1106)에 라우팅하기 위한 구분, 및/또는 배치 또는 다른 지연된 실행요청들의 준비 및 포워딩하기 위해 해당 프로세서(들)(104,1104)에 의해 접근될 수 있는 임시 또는 휘발성 메모리(들)(118,1018)에 저장될 수 있다.
202에서 수신된 명령어들은 거래일 또는 임의의 세그먼트의 기간과 같이 정의된 시간 간격 또는 임의의 다른 소정의 시간 주기(들) 동안, 규칙적 또는 불규칙적으로 누적될 수 있으며, 상기 시간 주기들은 프로세서(들)(104,1104)에 의해 사전 결정 및/또는 동적으로 결정될 수 있다. 명령어들은 또한 수신에 따라 개별적으로 프로세스될 수 있다. 더 많은 명령어들이 프로세스 전에 수신되어야할 경우, 혹은 잠재적으로 수신될 수 있을 경우, 프로세스(200)는 202로 복귀할 수 있다.
거래 요청/명령어는 프로세서(들)(104,1104)에 의해 사전설정 및/또는 동적으로 결정될 수 있는 평일 또는 임의의 세그먼트의 기간 또는 소정 시간 주기와 같은 정의된 시간 기간 동안 누적될 수 있다. 수신될 명령어들이 더 많은 경우, 혹은 잠재적으로 수신될 수 있으면, 프로세스(200)는 202로 복귀될 수 있다.
주문 또는 기타 프로세스요청들을 분석하거나 아니면 준비하는 데 있어 분류/규합 기술을 이용하는 본 발명의 실시예에서, 206에서 프로세서들(104,1104)은 모든 요구된 또는 소정의 관련되거나 규합될 수 있는 프로세스요청 신호 세트들이 소스(들)(102,1102)로부터 수신될 때까지 프로세스(202-204)를 반복할 수 있다. 예컨대, 상술한 바와 같이, CUSIP(Committee on Uniform Security Identification Procedures) 번호에 의해 식별될 수 있는 채권 구매를 위한 주문 또는 요청을 나타내는 임의의 개수의 데이터 기록들이 데이터 소스(들)(102,1102)로부터 수신될 수 있고, 배치 프로세싱을 위해 프로세서(들)(104,1104)과 연결된 메모리(118,1018)에 저장될 수 있으며, 따라서:
<source l><sell><CUSIP No. AA><l0,000><price A><res. 9,000><price D>
<source 2><buy><CUSIP No. BB><l2,000><price C><res. l,000><price B>
<source 3><sell><CUSIP No. BB><1l,000><price A><res. 8,000><price D>
<source 6><sell><CUSIP No. AA><l4,000><price A><res. 2,000><price E>
<source 4><buy><CUSIP No. AA>< l8,000><price C><res. 7,000><price B>
<source l><sell><CUSIP No. BB><20,000><price A><res. 3,000><price D>
<source 3><sell><CUSIP No. AA><l3,000><price A>< res. 6,000><price D>
<source 4><buy><CUSIP No. BB><22,000><price C><res. 4,000><price B>
<source 5><sell><CUSIP No. AA><21,000><price A>< res. 5,000><price E>
<source 4><buy><CUSIP No. BB><l5,000><price C><res. 7,000><price F>
<source l><sell><CUSIP No. AA><l9,000><price A><res. 3,000><price D>
<source 5><buy><CUSIP No. BB><l6,000><price C><res. 8,000><price F>
<source 6><sell><CUSIP No. BB><l7,000><price A><res. 6,000><price H >
개별 수신시, 또는 주어진 주기 비율로, 소정의 주문 개수가 수신되었을 때, 모든 소정의 주문들이 수신되었을 때, 또는 임의의 다른 소정의 기준이 만족되었을 때의 주어진 시간에서 프로세서들(104,1104)은, 예컨대, 거래 요청 및 관계 식별자의 타입에 의해 204에서 명령어를 분석 또는 아니면 프로세스의 일부로서 임의의 하나 이상의 소정의 기준에 따라 저장된 기록들을 분류 및/또는 그룹화할 수 있고, 따라서:
buy><CUSIP No. AA><l8,000><price C><res. 7,000><price G><source 4>
<sell><CUSIP No. AA><l0,000><price A><res. 9,000><price D><source 1> <sell><CUSIP No. AA><l4,000><price A><res. 2,000><price E><source 6> <sell><CUSIP No. AA><l3,000><price A><res. 6,000><price D><source 3> <sell><CUSIP No. AA><21,000><price A><res. 5,000> <price E><source 5> <sell><CUSIP No. AA><l9,000><price A><res. 3,000><price D><source 1>
<buy><CUSIP No. BB>< l5,000><price C><res. 7,000><price F><source 4> <buy><CUSIP No. BB><22,000><price C><res. 4,000><price B><source 4> <buy><CUSIP No. BB><l2,000><price C><res. l,000><price B><source 2> <buy><CUSIP No. BB><l6,000><price C><res. 8,000> <price F><source 5>
<sell><CUSIP No. BB><20,000><price A><res. 3,000><price D><source 1> <sell><CUSIP No. BB><ll,000><price A><res. 8,000><price D><source 3> <sell><CUSIP No. BB><l7,000><price A><res. 6,000><price H><source 6>
도시된 바와 같이, 거래 요청 기록시 다양한 데이터 필드들이 라우팅 프로세서(들)(104,1104)의 프로세스 요구에 맞추기 위해 필요에 따라 또는 요구에 따라 기록되거나 아니면 다시 포맷될 수 있다. 예컨대, 도시된 바와 같이, "소스" 데이터 항의 결합은 프로세서(들)(104,1104)가 주문 프로세스의 완료시 거래/요청의 달성을 알리게 하면서 효율적 주문을 용이하게 하기 위해 다른 우선순위와 결합되거나 아니면 따르게 된다.
프로세서(204)는 예컨대, 해당 거래 요청들과 관련된 총계 또는 소계 수량을 합함으로써 수신 및 저장된 거래 요청의 프로세서(들)(104,1104)에 의해 특정 관계(들)에서 특정 타입의 거래를 위해 수집되거나 통합된 주문(들)로의 규합을 포함할 수 있고, 따라서:
<buy><CUSIP No. AA><l8,000><price C><res. 7,000> <price G>
<sell> <CUSIP No. AA><77,000><price A><res. 18,000><price D><res. 7,000><price E>
<buy><CUSIP No. BB><65,000><price C><res. 15,000><price E><res. 5,000><price B>
<sell><CUSIP No. BB><48,000><price A><res. 1l,000><price D><res. 6,000><price H>
모든 소정의 신호 세트들이 202에서 수신되고, 선택적으로, 204 및 208에서 분류, 누적 및/또는 아니면 프로세스되면, 204에서 프로세스된 명령어 세트를 이용한 프로세서(들)(104,1104)은 자원/실행 프로세서들(106,1106)로 전송을 위한 실행요청 신호 세트들을 준비할 수 있다. 이런 실행요청 신호 세트들은 컨텐츠 또는 데이터 및 명령 신호를 포함한 요청된 프로세스를 야기하기 위해 임의의 필요 또는 소정의 신호들을 포함할 수 있다. 예컨대, 금융 상품에서 거래를 위한 요청의 프로세스를 위해 적용된 본 발명의 실시예에서, 요청들은 거래되는 관계(들), 거래되는 관계(들)의 수량, 가격 등을 기초로 저장 및/또는 규합될 수 있고, 적절한 실행 명령 신호들과 관련될 수 있다. 주어진 요청과 관련된 임의의 실행 명령 신호의 형태는, 당업자가 인식하는 바와 같이, 피실행 특성 및 요청 타입 및 실행되는 프로세스들(106,1106), 또한 적용가능한 프로토콜 및 명령 포맷팅 요건을 포함한 프로세서(들)(104,1104 및 106,1106) 간에 교환된 신호들이 라우팅되는 임의의 네트워크들(110,1110)에 의존할 수 있다. 에르고(ergo), 시스템들(106, 1106, 104, 1104 및 110, 1110) 중 어느 하나 또는 모두에 속하는 데이터 및 이로써 이용된 프로토콜 및/또한 이로써 거래, 매도, 또는 기술된 이해관계자들에 관한 정보가 임의의 프로세서들 또는 자원들(106,1106) 중 어느 하나에 의한 프로세스의 실행을 위한 명령어를 분석하고 준비하는데 있어 프로세서(들)(104,1104)에 의해 접속 및 사용될 수 있다. 이런 데이터의 소스들(1126)은 예컨대, 금융 거래의 프로세스를 위해 적용된 본 발명의 실시예에서, 다양한 거래소 시스템들(1106)로부터 수신된 정보, 블룸버그 또는 로이터와 같은 뉴스정보 소스들 및/또는 다른 소스들을 포함할 수 있는 가령 거래소 시장 데이터 시스템(1126v)(도 1b)을 포함할 수 있다.
금융 거래를 실행하는데 사용하기 위해 구성된 많은 자원들을 포함한 네트워크 프로세스 자원들을 이용한 데이터 프로세스를 위한 요청들을 어셈블리하는데 있어 실행 및/또는 다른 프로세싱 요청들을 여러 부분들로 분해하는 것이 때로 필요하거나 바람직할 수 있다. 이런 부분들 또는 세그먼트들은 거래소 서버 또는 다른 실행 프로세서들 또는 핸들러들(1106)과 같은 복수의 네트워크 자원들(106)에 의해 실행될 예컨대 대량 주문들의 일부분 또는 다른 데이터 프로세싱 요청들에 해당할 수 있다. 가령, 복수의 거래소 서버들 또는 기타 시장들이 주식 또는 채권과 같은 상당한 양의 금융 상품을 위한 구매 주문을 나타내는 거래 요청의 실행을 위해 이용가능한 경우, 여러 시장들에서 및/또는 여러 거래소 서버들(1106)에 의한 실행을 위해 주문을 여러 부분들로 분할하는 것이 필요하거나 바람직할 수 있다. 가령, 단일 거래소에서는 모든 또는 소정의 가격들에 있어 충분한 양의 특정 관계들이 이용될 수 없다: 전체 주문을 체결하기 위해, 하나의 주문을 더 작은 세그먼트들로 분할하고 이를 여러 거래소들에 라우팅하는 것이 필요하거나 바람직할 수 있다.
따라서, 가령, 금융 증권에서 거래를 위한 요청의 프로세스를 위해 지향된 본 발명의 다양한 실시예에서, 하나 이상의 금융 상품들에서 거래를 마치기 위해 라우터(104,1104)가 하나 이상의 소스들(106,1106)에 의해 요청되면, 라우터(104,1104)는 거래를 위한 요청을 나타내는 신호 세트(들)을 준비하는데 있어 시장 데이터 소스(들)(1126)뿐만 아니라 임의의 하나 이상의 실행 프로세서(들)(106,1106)로부터 이용가능한 정보에 접속하여 각각의 프로세서(들)(106,1106)을 통해 이용가능한 이런 관계들 및 이런 양들이 이용가능한 조건의 양을 결정할 수 있고, 가장 바람직한 조건으로 이용가능한 양들의 개수를 바탕으로 각각의 소정의 프로세서(들)(106,1106)에 라우팅하도록 구성된 실행요청 신호세트를 구성할 수 있다.
상기 예를 구성하는 예로, 완료된 주문(들)의 이행을 달성하기 위해 하나 이상의 인커밍(incoming) 프로세싱 요청을 복수의 거래소들로 라우팅되는 더 작은 부분들로 분할하는 것이 필요하거나 바람직할 수 있다. 이는 예컨대 하나 이상의 거래소 서버들(1106)에 의해 제공된 현재 주문장을 나타내는 데이터에 접속하여 이에 따라 알고 있는 데이터 프로세스 기술을 이용해 상기 주문(들)을 나눔으로써 수행될 수 있다. 그러므로, 가령, 상기 규합된 'sell CUSIP No. AA' 주문은 부분 또는 세그먼트들로 분할하어질 수 있고, 다양한 세그먼트들을 필요에 따라 복수의 거래소 서버들(A1-C3)로 라우팅하는데 사용하기에 적합한 이런 세그먼트 URLs 또는 다른 네트워크 자원 어드레스 식별자들을 나타내는 데이터와 결합될 수 있고, 따라서:
<exchange Al><sell><CUSIP No. AA><l5,000><price A><res. 6,000><price D><res. 2,000><price E>
<exchange B2><sell><CUSIP No. AA><27,000><price A><res. 6,000><price D><res. 2,500><price E>
<exchange C3><sell><CUSIP No. AA><35,000><price A><res. 6,000><price D><res. 2,500><price E>
당업자가 인식하는 바와 같이, 시장 또는 거래소 서버들(1106) 또는 기타 실행 프로세서들(106)과 같은 복수의 네트워크 자원들에 의해 여러 거래소에서 주문된 금융 상품들의 거래와 같은 분산 거래 또는 기타 여러 부분의 데이터 프로세싱 요청의 개별 부분들의 실행은 일반적으로 다른 시간량을 필요로 한다. 즉, 소정의 거래 실행요청들의 여러 부분들이 동시에 복수의 거래소 실행 프로세서들(106,1106)에 보내지면, 거래 요청의 각 부분 또는 세그먼트는 시간상 다른 지점에서 실행할 것이 예상될 수 있다. 이는 왜냐하면 주문 라우터(들)(104,1104)에서 네트워크(110,1110) 또는 다른 통신 경로를 가로질러 다른 다양한 자원들 또는 실행 프로세서들(106,1106)로 실행요청 신호의 전송을 위해; 해당 프로세서들(106,1106)에 의한 실행요청의 해당 부분들의 실제 프로세스를 위해; 및/또는 확인 또는 기타 데이터를 주문 라우터(들)(104,1104)에 복원을 위해 요구되는 시간량 또는 '지연'은, 예컨대, 라우터(들)(104,1104) 및 실행 프로세서들(106,1106) 간의 네트워크 경로; 네트워크(들)(110,1110)에 의해 프로세스되는 네트워크 트래픽량; 개개의 실행 프로세서들(106,1106) 등에 의해 프로세스되는 요청 개수 등을 포함한 일반적으로 많은 요인들에 따라 변하기 때문이다.
많은 이유로, 이런 경우, 여러 부분의 실행요청 중 2 이상의 부분들의 실행을 동기화하는 것이 중요해질 수 있다. 일예로서, 실행요청이 여러 시장에서 또는 여러 거래소에서 금융 거래의 여러 부분들의 실행을 위한 요청을 나타낼 경우, 여러 해당 서버들에 의해 거래의 개개의 부분들의 비동기식의 엇갈린 실행은 조건들의 나중 부분들의 완료 가능성 및/또는 이런 나중 부분들이 완료될 수 있는 조건들 모두에 영향을 줄 수 있다.
실행요청을 동기화하는 바람직한 특별 예가 도 3을 참조로 예시될 수 있다. 도 3에 도시된 예에서, 시스템(100,1000)은 주문 라우터(104,1104)와 복수의 네트워크 실행 자원들(106), 거래소 서버들 또는 실행 프로세서들(1106) "Exchange 1", "Exchange 2", "Exchange 3"을 구비한다. 또한, 도 3의 시스템(100,1000)은 실행 자원(106) "Exchange 1"상에 거래 또는 다른 거래를 실행하도록 구성된 코로케이트 트레이딩 서버(co-located trading server)(304)를 더 구비한다. 도면에 나타낸 바와 같이, 상대적으로 저지연 트레이딩 알고리즘(low-latency trading algorithm)을 이용한 코로케이트 트레딩 서버(304)는 Exchange 1과 유사한 거래를 마치기 위해 라우터(들)(104,1104)과 같은 다른 프로세서들에 필요한 시간량에 비해 상대적으로 짧은 시간 주기로 Exchange 1과 거래를 실행할 수 있는 식으로 Exchange 1과 연결된다. 예컨대, 코로케이트 트레이딩 서버(304)는 직접 유선 연결에 의해 Exchange 1 또는 다른 고속프로세싱 시스템과 통신상 연결될 수 있다. 더욱이, Exchange 1은 Exchange 2 또는 Exchange 3에서 보다 상대적으로 짧은 시간 주기로(즉, "저지연"으로) 논코로케이트 프로세서(들)(104,1104)로 실행요청을 마칠 수 있다. 다시 말하면, 도 3에 도시된 바와 같이, 지연 Time X < Time Y 및 Time X < Time Z인 반면, 코로케이트 트레딩 서버(304)와 Exchange 1 간의 거래를 위한 실행 시간은 Time X, Time Y, 및 Time Z 중 어느 하나 보다 더 적다.
가령, 하나 이상의 금융 상품에서 거래에 요청을 나타내는 신호가 하나 이상의 요청 소스들(102,1102)로부터 라우터 프로세서(104,1140)에 의해 수신되고, 요청이 상기 요청을 반영한 주문이 너무 커 Exchange 1, 2, 또는 3 중 어느 하나에 의해 완전히 마치지 못한 이런 양 또는 크기이면, 주문 라우터(104,1104)는 Exchange 1, Exchange 2 및 Exchange 3 각각에 한 부분을 보내기 위해 다양한 이용가능한 프로세서들(106,1106)에 대한 이용가능성을 체크하고 이에 따라 주문을 분할하도록 시도할 수 있다. 도 3의 라우터(104,1104)가 요청된 거래의 실행을 위해 요청의 분할된 부분 또는 세그먼트를 실행 프로세서들(106,1106)(Exchange 1, Exchange 2 및 Exchange 3) 각각으로 동시에 전송하면, (가령 극초단타거래 엔티티(high-frequency trading entity) 또는 다른 투기적 투자가일 수 있는) 트레이딩 서버(304)는 이런 거래들(가령, 요청 프로세서(들)(104,1104)에 의해 제공된 주문들 이면의 것들)을 제안하는 것들이 추구될 수 있는 것보다 거래(들)를 유효하게 하는 상대방(예컨대, 서버(304)를 통해 동작하거나 작용하는 당사자)에 더 유리한 조건들에 대해, 예컨대 거래를 위한 요청시 언급된 조건들로 주문 라우터(104)에 의해 거래소로 라우팅된 거래 요청의 모두 또는 일부를 판매 또는 구매하여 제안된 거래에 대한 거래상대방으로서 작용함으로써 Exchange 1에 대한 거래의 일부를 이행할 수 있고 Exchange 2 및/또는 Exchange 3에서 주문의 나머지 부분들을 마치기 위해 조건을 변경하거나 아니면 포스트(post)하는데 시간이 걸릴 수 있다. 다시 말하면, 가령, 코로케이트 트레딩 서버(304)는 Exchange 1, Exchange 2 및 Exchange 3와의 거래와 관련된 실행 지연의 차로 인해 Exchange 1에 대한 요청된 거래의 일부를 이행할 수 있고, 투기업자 또는 수익자(들) 자신의 이익 또는 이들 거래소들에 대한 유사한 이해관계를 제안하는 다른 트레이더들의 이익을 높이기 위해 이런 나머지 부분들이 앞서 진술된 가격으로 실행할 수 있기 전에 Exchange 2 또는 Exchange 3에서 거래의 나머지 부분들을 이행하기 위해 그 조건을 개선하도록 예컨대 입찰/매도 가격을 올리거나 내림으로써 움직일 수 있다.
도 3에서 알 수 있는 바와 같이, ('지연 차익거래' 기회라고 할 수 있는) 이런 가능성은 다음과 같을 때 있을 수 있다:
Time X + Time A < Time Y 및/또는
Time X + Time B < Time Z.
거래 또는 기타 프로세스요청 신호들이 동시에 라운터(들)(104,1104)로부터 각각의 Exchange 1, Exchange 2 및 Exchange 3로 라우팅되는 곳에서도, 각각의 자원(106,1106)(예컨대, Time X, Y, Z)에 의한 수신, 통지 및/또는 프로세스되는 요청의 각 분할된 부분에 걸리는 시간은 일반적으로 가령 프로세서(들)(104,1104 및/또는 106,1106) 중 일부 또는 모두에서 네트워크 통신 경로 및 프로세스 속도에서의 차이로 인해 다를 수 있음이 당업자에게 인식된다. 마찬가지로, Exchange 2 및 3 각각에서 거래 제안 조건을 변경하기 위해 트레이딩 서버(304)에 걸리는 시간도 일반적으로 다를 수 있다.
이런 경우에 발생할 수 있는 단점들 중에는 요청 소스(들)(102,1102)에 의해 표현된 트레이더들이 이런 차익거래 기회가 없는 상태에서 갖게 되는 것보다 거래를 실행하는 데 있어 더 높은 가격을 지불할 수 있다는 것이다; 또는, 연이은 교환들에 대한 가격이 실행요청시 언급된 외부 조건들을 받도록 충분히 변경되면, 이들은 소정 량으로 거래를 마칠 수 없을 수 있다. 예컨대, 거래소 프로세서(1106)로 라우팅된 거래의 모두 또는 일부가 변동된 가격을 고려해 거래될 수 없다.
거래 명령이 가령 지연을 이용한 제 3 자에 의한 가격 또는 기타 조건 조작으로 인해 거래소 서버(1106)에서 충분히 실행될 수 없는 이런 예에서, 하나 이상의 거래소 서버들(1106)에서 데이터 프로세싱 요청을 수행하는 중에, 모든 거래소 서버들(1106)에 이런 거래 요청의 실행이 동기화 식으로 예컨대 실질적으로는 동시적으로 발생하도록 여러 거래소 서버들(1106)에 거래 요청의 전송을 시간 조절하거나 스케쥴하는데 유용할 수 있다. 특히, 예컨대, 신호프로세스가 실질적으로 동시에 자원(106,1106)에 의해 수신, 통지, 및/또는 실행되도록 멀티 네트워크 컴퓨팅 자원들(106,1106)에서, 신호프로세스 실행요청, 또는 실행요청의 일부분 또는 세그먼트들의 실행을 동기화는 것이 유용할 수 있다.
몇몇 실시예에서, 각 프로세서들(106,1106)에서 실행되는 신호프로세스가 동시에 실행될 필요가 없고
Time Y - Time X < Time A, 및/또는
Time Z - Time X < Time B
으로 충분해질 수 있어, 조건내 어떤 변화가 트레이딩 서버(304)에 의해 실행될 수 있기 전에 요청(들) 또는 세그먼트의 실행이 행해진다. 이런 동기화 타이밍의 이용은
Time X + Time A > Time Y, 및/또는
Time X + Time B > Time Z
를 초래할 수 있고, 따라서, 가령 지연차익거래 기회를 빼앗을 수 있다. 그러므로, 몇몇 실시예에서, 본 발명은 최소로 또는 거의 시간변화 없이 여러 자원들(106,1106)에 걸쳐 거래를 실행할 능력을 라우터(104,1104)에 제공하여, 저지연 알고리즘을 이용한 트레이더(들)(304)에 의해 실행되는 알고리즘들은 시장변화에 대응하기에 불충분한 시간이 주어진다.
따라서, 동기화가 필요한 이들 및 다른 경우에, 210에서 프로세서/라우터(104,1104)는 소정의 시퀀싱을 얻기 위해 실행요청의 다양한 부분들 또는 세그먼트들에 할당 또는 연결되는 절대 또는 상대 타이밍을 결정할 수 있다. 이런 타이밍은 임의의 소정의 동기화를 야기하도록 결정될 수 있다: 예컨대, 동시에 또는 실질적으로 동시에 실행을 야기하도록 구성된 타이밍이 결정될 수 있거나 임의의 소정의 시퀀싱을 야기하도록 구성된 타이밍이 결정될 수 있다.
따라서, 210에서, 타이밍 파라미터는 각각의 네트워크 컴퓨팅 자원(106,1106)에 할당되는 각 신호프로세스 실행요청 또는 그 일부에 대해 결정될 수 있다. 각각의 네트워크 컴퓨팅 자원들(106,1106) 각각에 신호프로세스 실행요청의 동기화 실행을 야기하기 위해 파라미터들이 이런 식으로 결정된다. 이 결정은 라우터 프로세서(들)(104,1104)과 각각의 네트워크 컴퓨팅 자원들(106,1106) 간에 신호 교환의 실행시 또는 이런 디바이스들 중 어느 하나에 의한 다른 이런 신호들의 프로세스시, 예컨대, 도 3의 지연(A,B,X,Y,Z) 중 어느 하나 또는 모두 및/또는 임의의 다른 기타 관련된 지연들과 같이 적어도 부분적으로 이런 요청(들) 및/또는 부분(들)의 실행시 해당하는 결정된 지연에 기초할 수 있다.
서버들 간의 실행시간의 변화로 인해 야기된 차익거래 및 다른 문제들은 또한 프로세싱 요청의 전송 및 실행시 절대적 지연을 줄임으로써 최소화되거나 제거될 수 있다. 따라서, 상술한 바와 같이 타이밍 파라미터들의 결정은 요청(들)(106,1106)에 의한 실행요청의 실행 및/또는 리포팅과 관련된 시간의 절대량을 또한 최소화하는 역할을 하는 절차들과 조합하여 실행될 수 있다.
라우터(들)(104,1104)에 의해 복수의 실행 프로세서들(106,1106)에 제공된 여러 부분의 실행요청의 다양한 부분들과 관련된 타이밍 파라미터들을 결정하는데 이용된 결정 지연에 대한 정보는 타이밍 정보(가령, 전송 지연, 신호전파지연, 연속지연, 큐잉지연, 및/또는 라우터 프로세서(들)(104,1104), 네트워크 컴퓨팅 자원(106,1106) 및/또는 네트워크(110,1110,108,1108)에서 기타 프로세스지연)을 포함할 수 있다. 이런 정보는 임의의 소스(들)에 제공되거나 소스(들)로부터 수신될 수 있고, 하나 이상의 데이터 저장소(214)에 저장 및 검색될 수 있다. 다양한 실시예에서, 타이밍 데이터 저장소(214)는 라우터 프로세서(들)(104,1104)과 연결되거나 아니면 접속될 수 있는 메모리(들)(118,1018)에 있는 데이터베이스 또는 다른 데이터 구조를 포함할 수 있다. 예컨대, 제 1 네트워크 컴퓨팅 자원(106,1106)과 연결된 실행요청 중 일부의 실행이 (가령, 도 3의 Exchange 1 대 Exchange 2 및 3의 경우에서와 같이) 제 2 네트워크 컴퓨팅 자원(106,1106)과 연결된 실행보다 더 길게 결정된 지연을 가지면, 이들 2개의 네트워크 컴퓨팅 자원들(106,1106)로 라우팅된 거래 요청의 관련된 부분들의 요청 타이밍은 요청들이 2개의 네트워크 컴퓨팅 자원(106)에서 실질적으로 동시에 또는 트레이딩 서버(304)에 의해 조작된 가능한 조건들에 대한 유효 최소시간(A 또는 B)내에 실행되는 목적으로 제 1 네트워크 컴퓨팅 자원(106,1106)과 연결된 실행요청 또는 그 일부가 제 2 네트워크 컴퓨팅 자원(106)과 연결된 요청보다 더 일찍 보내지도록 시간조절되게 결정될 수 있다.
몇몇 실시예에서, 가령 지연 확률 모델 또는 다른 예측 모델을 이용할 수 있는 하나 이상의 알고리즘들은 이런 통신 및/또는 프로세스지연 또는 지연들과 관련된 정보를 기초로 다양한 실행 프로세서들(106,1106)로 보내지도록 실행요청의 일부분들과 관련된 타이밍 파라미터들을 결정하는데 이용될 수 있다. 예컨대, 임의의 소정 디바이스들에 걸쳐 누적되거나 임의 소정 디바이스들과 관련된 역사적 지연 데이터의 롤링 평균, 시간 주기 또는 기타 타이밍 고려사항들이 데이터 프로세싱 요청의 실행을 위한 예상 지연을 예측하는데 이용될 수 있다.
네트워크 자원(106,1106)에서 이런 부분들 또는 요청들의 동시이거나 아니면 동기화된 도착을 야기하는 것이 바람직한 라우터(들)(104,1104)에 의해 소스(들)(102,1102)에 의해 제공된 실행을 위한 요청 부분(들)과 관련된 타이밍 파라미터들을 결정하는데 사용하기 적합한 알고리즘의 일예는 라우터(들)(104,1104)로부터 요청신호들의 전송 및 적절한 타이밍 기준 간의 평균 지연을 기초로 한다. 이런 타이밍 기준(들)은 예컨대 해당 타겟 자원(들)(106,1106)에 의한 프로세스의 개시 및/또는 요청의 수신 및/또는 요청의 실행 완료시 자원(들)(106,1106)에 의해 발생된 확인 신호의 라우팅 프로세서(들)(104,1104)에 의한 수신을 포함할 수 있다. 예컨대, 몇몇 실시예에서, 주어진 자원들(106,1106)로의 전송 및 확인 또는 통지 신호, 또는 이런 자원들(106,1106)로부터 기타 적절한 응답신호(1260)의 라우터(들)(104,1104)에 의한 수신 간에 지연을 측정하고 210에서 타이밍 파라미터(들)을 결정하는데 이런 측정된 지연(들)을 이용하는 것이 이점적일 수 있다.
진행 단계(210)는 예컨대 금융 시스템(1000)의 경우 자본관리 엔티티 또는 모듈(1126)과 같이 라우팅 프로세서(들)(104,1104)에 의해 실행되는 애플리케이션 또는 라우팅 프로세서들의 모듈에 의해 실행되거나 아니면 연결될 수 있다. 여러 부분의 실행요청의 각 부분 또는 세그먼트와 관련된 타이밍 파리미터의 결정은 예컨대 도 1b에 도시된 것과 같은 적응식 교환 RTL(Round-Trip Latency) 학습(learning) 및 보상 로직모듈(1126c)을 포함할 수 있다. 도 3을 참조하면, 이런 적응식 교환 RTL 학습 및 보상 로직모듈(1126c)은 다음과 같이 각 신호 프로세싱 요청(예컨대, 거래 요청)에 대한 타이밍을 결정할 수 있다:
1) m부의 여러 부분 프로세싱 요청(X)의 각 부분 또는 세그먼트(n)에 대해, 가령, 프로세서(들)(104,1104)에 대한 클록에 의해 제공된 시간(T1X,n)은 거래 주문(들) 또는 기타 프로세싱 요청(들)(X)을 분석 또는 발생하는 프로세스내 소정의 정의된 지점에서 프로세서(들)(104,1104)에 의해 타임스템프되고, m부의 요청(X)의 각 부분 또는 세그먼트(n)에 해당하는 프로세싱 요청신호 세트 레코드(들)과 관련된다.
2) 여러 부분의 요청(X)의 각 부분(n)에 대한 시간(T2X ,n)은 해당하는 n번째 부분의 요청신호 세트가 타겟 거래소(106,1106)에 수신되고 해당하는 거래발생 확인 메시지가 요청 라우팅 프로세서(104,1104)에 의해 수신되었을 경우 프로세서(들)(104,1104)에 의해 타임스템프된다.
3) 거래일(trading day)의 경과(또는 다른 데이터 프로세스 주기) 동안, 프로세스 단계(2 및 3)가 반복될 수 있고, 각 거래 세그먼트에 대해 결정된 해당 시간(T1X,n,T2X,n)이 주어진 실행 프로세서(106,1106)로 보내질 수 있다.
4) 연속 계류중인 여러 부분의 실행요청(Y)의 각 부분의 세그먼트(n)에 대해, 결정된 타이밍 파라미터 RTLy,n=Σ(T2X,n-T1X,n)/Z이며, 여기서 Z는 계산시 사용된 주어진 실행 프로세서(106,1106)에 라우팅된 이전에 실행된 주문 세그먼트의 개수이다.
타이밍 데이터 저장소(들)(214)은 하나 이상의 실행 자원들(106)/거래소 서버(1106)과 관련된 과거 타이밍 파라미터들(예컨대, 복수의 결정된 타이밍 파라미터들(RTLy,n))의 롤링 레코드를 저장하는 경우, 이런 데이터는 롤링 히스토그램을 만드는데 이용될 수 있으며, 상기 히스토그램은 각 자원(106)/거래소 서버(1106)에 대한 현재 또는 누적 지연을 예측하는데 이용될 수 있다. 이런 예측은 연속적으로 변하는("롤링") 레코드를 기초로 하기 때문에, 이 프로세스를 "온라인 학습(online learning)"이라 할 수 있다. 이를 담당하는 적응식 교환 RTL 학습 및 보상 로직모듈(1126c)내에 한 구성요소(예컨대, 미도시된 거래소 지연 히스토그램 메모리 또는 프로세스 구성요소)가 있을 수 있다.
적응식 교환 RTL 학습 및 보상 로직모듈(1126c)은 다른 거래소 서버들(1106)로 라우팅된 분할된 거래 요청들의 일부의 실행시 차이를 줄이거나 제어하거나 최소화하거나 제거하고 이에 따라 가령 기회적 거래자들에 의한 지연 차익거래에 대한 기회를 줄이거나 제거하는 식으로 이런 거래소 서버(1106)와 관련된 실행 지연에서의 차이를 보상하기 위해 다양한 거래소 서버들(1106)에 거래(또는 기타 데이터 프로세스) 요청을 전송하는데 이용된 적절한 타이밍 파라미터들을 결정하기 위해 예측된 지연을 이용할 수 있다.
적응식 RTL 모듈(들)(1126c)은 여러 부분의 프로세싱 요청들의 실행을 동기화하는데 사용하기 적절한 타이밍 파라미터들을 결정하는데 있어 다양한 알고리즘을 이용할 수 있다. 예컨대, 이런 모듈은 예컨대 프로세스를 위한 요청의 해당 부분들을 시간을 달리해 다양한 프로세서들(106,1106)로 보냄으로써 라우터(들)(104,1104)이 다른 거래 지연들을 보상해야 하는 정도를 결정하기 위해 다양한 거래소들에 대해 결정된 지연 값들을 이용할 수 있다. 이는 예컨대 해당 실행 자원(106,1106)에 의해 각각의 부분의 수신 간의 시간 차를 최소화함으로써 각 부분의 실행의 완료간 지연을 최소화할 수 있다(도 3에서, 예컨대, 이는 Time X, Time Y, 및 Time Z에서 지연된 시간들 간의 차이를 최소화함으로써 나타나진다). 또한 통신 지연이외에 다양한 자원들(106,1106)에 대한 거래 또는 기타 프로세스 주문의 실행에 걸리는 역사적 시간 차는 이런 알고리즘들 때문일 수 있다.
적응식 교환 RTL 학습 및 보상 로직모듈(1126c)은 (예컨대, 거래소 시장 데이터 소스(들)(1126v)과 같은 데이터 소스들을 이용해) 추가로 각 거래소 서버(1106)에 만연한 시장 조건들, 쇄도 주문/실행, 거래 요청이 라우팅된 경우 실제 지연 및 (가령, 상기 예상된 바와 같이) 타겟지연에 대한 정보를 추가로 수집할 수 있다. 이를 맡고 있는 적응식 교환 RTL 학습 및 보상 로직모듈(1126c)내에 한 구성요소가 있을 수 있다.
임의의 하나 이상의 실행 프로세서(들)(106,1106)에 라우팅되는 실행요청과 관련된 하나 이상의 타이밍 파라미터들도 또한 해당 라우팅 프로세서(들)(104,1104)(예컨대, 타이밍 데이터 저장소(214))에 (예컨대, 프로세서들 또는 (서브)시스템들(1126a-1126g 및/또는 1126v) 중 어느 하나 또는 이상을 포함한) 임의의 하나 이상의 마켓 데이터 피드(들) 또는 프로세서(들)(1126)에 의해 제공되거나 관련된 데이터를 이용한 이런 프로세서(들)(104,1104) 및/또는 프로세서(들)(106,1106) 자체에 의해 결정될 수 있다.
212에서, 선택적으로 규합되고 분할된 신호프로세스 실행요청(들)의 다양한 부분들이 결정되거나 아니면 210에서 획득된 타이밍 파라미터들 또는 시퀀스(들)에 따라 각각의 네트워크 컴퓨팅 자원들(106)로 라우팅된다. 그런 후, 요청(들) 또는 다양한 부분들이 필요 또는 요망에 따라 연이은 신호 통신 및 프로세스로 각각의 실행 자원들(106,1106)에 의해 실행될 수 있다. 당업자들이 아는 바와 같이, 일단 이들이 본 명세서에 익숙해지고, 소정의 실행요청 파라미터들이 라우터(들)(104,1104)에 의해 결정되면, 이들 파라미터들을 나타내는 신호들이 공지되거나 특수한 데이터 프로세스 기술을 이용해 어셈블리될 수 있고; 금융정보거래소(FIX) 프로토콜 및/또는 임의의 다른 소정의 프로토콜(들)에 따라 포맷될 수 있으며; 공지되거나 특수 신호 통신 기술을 이용해 해당 실행 프로세서(들)(106,1106)로 보내지거나, 기록되거나 이나면 통신될 수 있으며, 요청된 거래 또는 기타 데이터 프로세스들에 따라 실행될 수 있다.
예컨대, 상기 예에 이어서, 이들 중 하나 또는 모두가 0 또는 임의의 다른 적절한 시간 주기와 같을 수 있는 타이밍 지연 또는 파라미터들(X',Y',Z')은 상기 개시에 따라 결정될 수 있고 각각 예비로 가격(D 및 E)으로 25,000 채권 더미(18,000+7,000)와 함께 가격(A)으로 CUSIP No. AA 채권의 77,0000 채권 더미의 구매를 위해 프로세서(들)(1104)에 의해 발생된 주문 세그먼트들과 연관될 수 있으며, 따라서:
<delay X'><exchange Al><sell><CUSIP No. AA><l5,000><price A> <res. 6,000><price D><res. 2,000><price E>
<delay Y'><exchange B2><sell><CUSIP No. AA><27,000><price A> <res. 6,000><price D><res. 2,500><price E>
<delay Z'><exchange C3><sell><CUSIP No. AA><35,000><price A> <res. 6,000><price D><res. 2,500><price E>.
그 후, 라우팅 프로세서(들)(104,1104)은 타이밍 파라미터들, 예컨대 해당 거래 세그먼트들이 동시에 아니면 소정의 순차적 실행을 위해 소정 타이밍 시퀀스들에 따른 실행을 위해 전송되거나 아니면 거래소(106,1106, A1, B2, C3)에 제공되게 하는 지연(X',Y',Z')을 이용해 거래 세그먼트들을 프로세스할 수 있다.
라우팅된 거래 또는 프로세싱 세그먼트들 모두 또는 많은 부분들의 실행에 이어, 라우팅 프로세서(들)(104,1104)은 해당 실행 프로세서(들)(106,1106)로부터 이런 실행을 확인하거나 아니면 나타내는 데이터를 수신할 수 있고, 관련된 메모리(들)에 저장된 데이터 레코드에 접속함으로써, 요청 소스(들)(102,1102)에 실행 결과를 할당할 수 있다.
멀티 네트워크 컴퓨팅 자원(106)에 의한 데이터의 프로세스를 관리하는데 이용되는 타이밍 파라미터들을 결정하는 방법(300)의 예를 나타내는 도 4를 참조한다. 도시된 실시예에서, 방법(300)은 반복 방법이며, 상기 방법(300)의 각 루프는 N으로 표시된다. 방법(300)은, 예컨대, 특히 라우터 프로세서(들)(104,1104) 및 데이터 소스(들)(1126)을 포함한 시스템(100,1000) 및 그 구성요소의 다양한 실시예들 중 어느 하나를 이용한 실행에 적합하다.
302에서, 복수의 네트워크 컴퓨팅 자원(106,1106) 각각은 신호프로세스 실행요청의 수신 및/또는 실행과 관련된 지연에 대해, 예컨대, 라우터 프로세서(들)(104,1104), 실행 프로세서(들)(106,1106), 외부 프로세서(들)(1126) 및/또는 이에 의해 동작되거나 아니면 이와 연결된 다양한 구성요소들에 의해 모니터된다. 이는 예컨대 라우터 프로세서(들)(104,1104)에서 모니터링 모듈(가령, 금융 시스템(1000)에 대한 것과 같이 거래소 RTL 측정 모듈(1126b))에 의해 수행될 수 있다. 이런 모니터링은, 예컨대, 데이터의 프로세스를 위한 아웃고잉 요청을 타임스템핑하는 것과, 프로세스로 인한 확인(들) 또는 결과의 수신 시간과 해당 타임스템핑된 아웃고잉 요청을 비교하는 것을 포함할 수 있다.
아웃고잉 요청과 인커밍 수신 확인 및/또는 데이터 프로세스결과들 간의 시간 차는 데이터 또는 신호프로세스 지연으로서 정의될 수 있고, 라우터 프로세서(들)(104,1104)에 의해 접속가능한 메모리에 저장될 수 있다. 아웃고잉 요청들 및 인커밍 수신간의 시간 차, 확인 및/또는 결과들로 인해, 이런 지연들이 연속적, 주기적 및/또는 기타 동적 기반으로 모니터될 수 있다.
306에서, 라우팅 프로세서(들)(104,1104)에 의해 모니터되는 자원들(106,1106)에 제공된 신호 프로세싱 요청들의 실행시 관찰된 지연(들)과 관련된 적어도 하나의 타이밍 파라미터들이 결정된다. 본 명세서에 기술된 바와 같이, 이런 타이밍 파라미터(들)은, 다른 것들 가운데, 예컨대 전송 지연 또는 기타 신호전파지연과 같은 통신 지연 및/또는 프로세스지연을 포함할 수 있다. 일반적으로, 거래 주문 또는 다른 데이터 프로세싱 요청, 또는 그 일부가 라우팅 프로세서(들)(104,1104)에 의해 라우팅되는 것이 예상되는 복수의 네트워크 컴퓨팅 자원(106,1106) 각각에 대해 해당 타이밍 파라미터(들)이 결정된다.
다양한 실시예에서, 금융 시스템(1000)의 다양한 형태에서와 같이 그리고 이용되는 소정의 프로세스 결과에 대한 시스템(들)의 타입에 따라, 이런 타이밍 파라미터들은 자본 관리 엔티티 및 거래소 서버(1106)에 의해 또는 대신해 동작되는 라우팅 프로세서(들)(1104) 간에 일방 및/또는 왕복 통신, 즉, 자본 관리 엔티티의 라우팅 프로세서(1104)에 의한 여러 부분의 거래 요청의 발생으로부터 대량 거래 주문 및/또는 프로세싱 요청이 라우팅된 실행 자원으로부터 요청된 거래 중 일부 또는 모두의 실행 확인과 같은 응답의 수신을 위해 결정될 수 있다. 예로써 상술된 도 1b를 참조하면, RTL 측정은 라우팅 프로세서(들)(104,1104)로부터 라우팅된 통신과 거래소 서버(106,1106)로부터 라우팅된 응답(예컨대, 통신의 통지, 거래 요청의 거절, 거래 요청의 확인 등) 모두에 대해 자본 관리 엔티티 서버(1104)내 신호, 자본 관리 엔티티(1104)내 신호의 프로세스, 자본 관리 엔티티(1104)와 네트워크(1110) 간에 신호의 전송, 네트워크(1110)내 신호의 전송, 네트워크(1110)와 타겟 거래소 서버(1106) 간의 신호의 전송, 및 거래소 서버(1106)내 신호의 프로세스 중 어느 하나 또는 모든 전송으로 인한 지연을 포함할 수 있다. 이런 실시예에서, 타이밍 파라미터(들)은 단순히 왕복 통신을 위한 총 시간이거나 통계적 또는 그 다른 수학적 기능일 수 있다.
예컨대, 도 1b에 도시된 SOR(1104)과 관련된 모듈과 같이 거래소 RTL 측정모듈(1126b)은 다음과 같은 타이밍 파라미터들을 결정할 수 있다:
1) 타임스템프 값(T1)은 거래소 서버(1106)로 프로세서(들)(1104)에 의해 라우팅된 새 통신(M1)(예컨대, 거래 요청)과 관련된다.
2) 타임스템프 값(T2)은 프로세서(들)(1104)에 의해 요청(M1)이 라우팅된 거래소 프로세서(1106)로부터 수신된 요청(M1)에 대한 어떤 응답과 관련된다. 이 응답은 통지, 거절, 전체 또는 부분적 체결 등과 같은 임의의 응답일 수 있거나 M1에 의해 표현된 요청의 특성에 따를 수 있다.
3) 요청(M1)과 관련된 RTL은 T2 및 T1 간의 차로 계산된다. 상기 언급한 바와 같이, 몇몇 실시예에서, RTL은 복수의 타겟 거래소 프로세서(들)(1106) 각각에 라우팅된 프로세싱 요청의 지난 횟수(Z)(예컨대, 30)에 대한 시간 평균(T2-T1)으로서 계산될 수 있다.
308에서, 각 네트워크 컴퓨팅 자원(106)과 관련된 타이밍 파라미터(들)은 타이밍 데이터 저장소(들)(214)에 저장될 수 있다. 본 명세서에 기술된 바와 같이, 몇몇 실시예에서, 타이밍 데이터 저장소(214)는 라우터 프로세서(들)(104)과 결합되거나 접속될 수 있는 메모리에 있는 데이터베이스 또는 기타 데이터 구조일 수 있다. 타이밍 데이터 저장소(들)(214)에 저장된 타이밍 프로세서(들)은 도 2의 프로세스 블록(210)과 관련해 기술된 프로세서들들과 같은 프로세스에 이용될 수 있다.
프로세서(들)(104,1104)에 의해 결정된 타이밍 파라미터(들)은 예컨대 개개의 실행 프로세서들(106,1106) 및/또는 다른 시스템(100,1000) 구성요소들과 관련된 지연을 나타내는 롤링 히스토그램(들)을 나타낼 수 있다.
도 5는 시스템(100,1000)에서 통신과 관련된 프로세스지연 시간값 및/또는 실행 프로세서(106,1106)와 관련된 기타 프로세스를 나타내는 저장된 데이터를 나타내는 히스토그램의 예를 도시한 것이다. 도시된 예에서, 왕복 지연시간(ms 단위)은 가장 최근 30개 거래 요청들 또는 소정의 실행 서버(106)와의 다른 통신에 대해 저장된다. 상기 예는 저장된 30개의 지연시간을 나타내고 있으나, RTL 또는 기타 타이밍 파라미터들에 사용된 저장된 타이밍 파라미터(들)의 개수는 더 크거나 작을 수 있고 일시, 계절 등과 같은 조건에 따라 변할 수 있다. 저장된 지연을 기초로 한 계산 결과 및 다른 관련된 데이터도 도한 타이밍 데이터 저장(들)(214)에 저장될 수 있다. 예컨대, 도 5의 예에서, 원래 지연시간 이외에, 각 실행 서버(106)와 또는 각 실행 서버(106)에 의한 통신 및/또는 기타 프로세스와 관련된 롤링 평균 또는 지난 30개(또는 기타 적절한 개수) 지연시간의 롤링 모드가 또한 타이밍 데이터 저장소(들)(214)에서 계산되고 저장될 수 있다.
당업자에게 쉽게 인식되는 바와 같이, 예컨대, 소정의 고정 오프세트 또는 지연, 또는 일시, 주간, 연중 계절 등과 관련된 스케일링 요인들, 알려진 거래 또는 기타 데이터 프로세스 패턴, 경제 상태 등을 포함하는 기타 요인들이 210에서 타이밍 파라미터 결정에 이용될 수 있다.
210에서 결정된 타이밍 파라미터들은 라우팅 프로세서(들)(104,1104)에 의해 소스(102,1102)에 의해 발생되고, 예컨대, 이런 요청들 또는 여러 프로세서(들)(106,1106) 각각에 의한 실행을 위해 전송되는 요청의 일부와 관련해 프로세서(들)(106,1106)로 라우팅된 프로세싱 요청들의 실행을 동기화하여 소정의 절대시간 또는 상대시간에서 해당 프로세서(들)(106,1106)에 대한 요청의 통신을 야기하여 해당 실행 프로세서(들)(106,1106)에서 요청의 도착의 소정 동기화를 달성하는데 이용될 수 있다. 예컨대, 프로세서(들)(104,1104)과 관련된 클록에 따라 소정 시간(들)에서 요청의 하나 이상의 부분들의 통신을 야기하도록 구성된 데이터 항들을 이용함으로써, 프로세서(들)(104,1104)은 바라는 일시 또는 실제 일시와는 관계없지만 오히려 서로 또는 몇몇 제 3 지수(index)에 대해 임의의 원하는 관련된 주문 또는 시퀀스에서 요청(들) 또는 요청 부분(들)이 통신되게 할 수 있다.
310에서, N은 1씩 또는 다른 적절한 값으로 증가되거나, 아니면 프로세스(302-308)가 계속되도록 컨트롤이 302로 복귀된다. 선택적으로, 최대의 소정 반복 횟수를 마칠 때까지 또는 거래에 대한 모든 요청들 또는 주문에 의한 기타 프로세스가 진행될 때까지(예컨대, 실행 프로세서(106,1106)로 보내질 때까지), 또는 다른 적절한 기준이 충족될 때까지 프로세스(302-310)가 계속된다.
시스템(들)(100,1000) 또는 시스템 구성요소들의 운영자 또는 사용자를 돕거나, 몇몇 태양에서, 멀티 네트워크 컴퓨팅 자원에 의한 데이터 프로세스를 하기 위해 개시된 방법과 시스템의 효과를 이해 또는 평가하기 위해, 본 개시는 또한 시스템(10,1000)의 다양한 구성요소들 중 어느 하나 또는 모두에 의해 그리고 발생된 데이터의 사용을 통해 결정될 수 있는 다양한 계측기(예컨대, 금융 시스템(1000)의 경우 거래 벤치마크)를 제공한다.
개시된 방법 및 시스템의 예에 따라 복수의 네트워크 컴퓨팅 자원들 또는 실행 프로세서들(106,1106)로 여러 부분의 거래 실행요청들의 전송 결과와 종래 전송된 여러 부분의 거래 요청들의 결과의 비교를 도시한 도 6을 참조한다.
도 6a는 복수의 거래소 서버(106,1106)에 의해 여러 부분의 거래 요청(판매 주문)의 다양한 부분들 또는 세그먼트들(624)의 동기화(예시된 경우에서, 실질적으로 동시) 실행을 얻기 위한 개시된 방법 및 시스템을 이용한 여러 부분 거래 요청의 실행의 결과를 도시한 것이다. 도시된 예에서, 본래 규합된 주문의 94% 체결률은 ("LEVEL 1"로 도시된) $4.21의 원래 제안가격(630)으로 달성되었다. (626으로 도시된 단일 거래로 이행된) 두번째 거래에서, 나머지 분량은 다소 바람직하지 못하나 여전히 수용할 수 있는 ("LEVEL 2"로 도시된) $4.20의 가격(632)으로 팔렸다. 요청된 주문 가격(즉, 레벨 2의 이들 주문들) 아래로 이행된 주문과 관련된 값은 거래 시스템(1102)(예컨대, 클라이언트 시스템)에 대해서는 $53,000였고 자본 관리 엔티티(1106)에 대해서는 $10,049였다.
도 6b에서, 종래 기술의 거래 방법 및 시스템을 이용해, 동일한 전체 거래 요청에 대해 여러, 비동기화된 주분 세그먼트들(624')를 구성하는 비동기화된 여러 부분의 거래 요청(여러 거래소 판매 주문)은 ("LEVEL 1"로 도시된) $4.21의 바람직한 주문가격(630)에서 초기 체결률은 47%였다. 요청의 다른 43%가 연이어 ("LEVEL 2"로 도시된) $4.20의 덜 바람직한 가격(632)으로 이행되었고, 나머지는 ("LEVEL 3"로 도시된) $4.19의 더 줄어든 가격(634)으로 이행되었다.
개시에 다른 방법 및 시스템을 이용해서는, 628에 도시된 바와 같이 주당 $4.2094의 거래량가중평균 판매가격(VWAP)(636)이 실현되었다. 종래 기술의 방법 및 시스템을 이용해서는, 주당 $4.2038의 VWAP(638)가 실현되었다.
당업자들이 쉽게 아는 바와 같이, 시스템(100,1000)은 폭넓게 다양한 다른 측정 및 기능들을 제공하는데 적합한 디바이스들 또는 구성요소들을 구비할 수 있다. 예컨대, 시장 뉴스 서비스 또는 다른 시장 데이터 소스(1126v)에 의해 제공된 시장 평균 가격에 대한 벤치마크 비교의 라우팅 프로세스(104,1104) 또는 기타 프로세서에 의한 제공의 2가지 예를 도시한 도 7을 참조한다. 646에서, 본 발명에 따른 여러 부분의 거래 요청의 동기화 프로세스시 시스템(100,1000)의 성능은 시장 성능 표시자 "평균가격 벤치마크"와 비교된다. 이런 평균 가격 벤치마크 또는 다른 벤치마크의 측정 요인은, 예컨대 구성요소들(1126,1106) 등 중 어느 하나 또는 모두로부터 얻을 수 있다. 644에서, 종래 기술의 방법에 따른 여러 부분의 거래 요청의 비동기화 프로세스시 시스템(100,1000)의 성능은 동일한 시장 성능 표시자 "평균 가격 벤치마크"와 비교된다. 비교들(646,644)의 비교는 본 발명에 따른 거래의 프로세스가 금융 상품의 판매자를 위하여 더 나은 결과를 제공하는 것을 나타낸다. 당업자가 아는 바와 같이, 본 발명에 따른 시스템 및 방법의 성능을 평가하는데 폭넓은 다양한 벤치마크들이 이용될 수 있다. 이런 벤치마크들은 적어도 부분적으로 사용된 시스템(100,1000) 및 이런 시스템에 의해 프로세스된 거래 또는 기타 실행요청의 타입에 의해 결정될 수 있다.
도 1b에 도시된 실시예에서, 금융 거래 또는 다른 데이터 프로세스 실행요청을 준비하는데 있어 프로세서(들)(104)에 의해 이용될 수 있는 소스(들)(1126)은 여러 부분의 실행요청을 준비하는데 유용한 복수의 모듈들(1126a-g)을 포함한다. 도시된 예에서, 모듈(1126a-g)은 시장 데이터 프로세스 모듈(1126a), 거래소 왕복 지연 측정모듈(1126b), 적응식 거래소 왕복 지연(RTL) 학습 및 보상논리모듈(1126c), 스마트 스위핑 주식 할당논리모듈(1126d), 스마트 포스팅 논리모듈(1126e), 지역 및 국제 거래소 접속논리모듈(1127f) 및 공격적 관리모듈(1127g)을 포함한다.
시장 데이터 프로세스모듈(1126a)은 거래소 서버(1106)의 거래소 시장 데이터 모듈(1126v)을 통해 제공된 데이터와 같거나 다를 수 있는 시장 데이터를 수신하고 프로세스한다. 이런 데이터의 소스들은 필요에 따라 원하는 바에 따라 시스템(1104)에 대해 내부적이거나 외부적일 수 있고, 실행요청들 및 특히 거래 주문을 분할하거나 아니면 준비하는데 유용한 이런 요청들에 유용한 데이터의 임의의 적절한 사적 또는 공적 이용가능한 소스들을 포함할 수 있다: 제공된 정보는 예컨대 임의의 특별한 거래소에 이용가능한 개수 또는 수량 및/또는 가격; 역사적 거래수량 또는 가격; 시장(들) 또는 유동성의 현재 및 역사적 깊이; 보유 크기; 절대, 상대 및/또는 평균 가격폭; 및 주식 또는 특정 이해관계의 휴리스틱스(heuristics); 및/또는 그 중 어느 하나 또는 모두에서의 경향을 포함할 수 있다.
거래소 RTL 측정 모듈(1126b)은 예컨대 본 명세서에 설명된 바와 같이 개개의 실행 프로세서(들)(106,1106)에 요청 또는 기타 데이터를 전송하는 것과 개별 실행 서버(들)로부터 확인 또는 실행 결과를 수신하는 것 간에 경과된 시간(들)을 나타내는 통계적으로 정의된 지연 데이터를 이용해 복수의 거래소 서버들(1106)에 의한 여러 부분 거래 또는 기타 데이터 프로세싱 요청의 실행을 동기화하는데 사용하기 위한 타이밍 파라미터를 결정한다.
적응식 거래소 RTL 측정 모듈(1126c)은, 예컨대, 본 명세서에 설명된 바와 같이, 개별 실행 서버(들)(106,1106)에 여러 프로세싱 요청들 또는 기타 데이터를 전송하는 것과 개별 실행 서버(들)로부터 확인 또는 실행 결과를 수신하는 것 간에 경과된 시간(들)을 나타내는 동적으로 정의된("롤링") 지연 데이터를 이용해 복수의 거래소 서버들(1106)에 의한 여러 부분의 거래 또는 기타 데이터 프로세싱 요청의 실행을 동기화하는데 사용하기 위한 타이밍 파라미터들을 결정한다. 이런 롤링 데이터를 나타내는 히스토그램 및 기타 데이터 모델 및/또는 구조는 모듈(들)(1126c)에 의해 이런 프로세스들에 따라 타이밍 파라미터를 결정하는데 사용될 수 있다.
스마트 스위핑 주식 할당 논리모듈(1126d)은 전략적으로 오버사이즈 거래 요청 및/또는 역사적으로 관찰된 시장 데이터를 기초로 공개적으로 알려진 주문들과 보유량(들)을 관련시키기 위한 통계적 모델을 포함한다. 이 모듈(1126d)은 예컨대 주어진 주기에 걸쳐 또는 다른 특정 조건(예컨대, 지난 30개 거래 요청)하에서 상기 거래소 서버(1106)에 이용가능한 숨겨진 보유량에 대한 통계적 데이터를 기초로 거래소 서버(1106)에서 예상된 숨겨진 보유량을 고려해 공개 주문시 포함된 적절한 오버사이즈(즉, 거래 요청시 과도주문)를 결정한다. 이런 예상된 숨은 시장 보유량을 기초로, 공개적으로 볼 수 있는 주문의 전략적 오버사이즈로 발생하고 실제 소정 거래량이 구현되는 것을 보장하는데 도움을 줄 수 있게 적절한 크기의 숨겨진 보유량이 결정되고 거래 주문과 관련될 수 있다.
스마트 포스팅 논리모듈(1126e)은 개개의 거래소 서버(1106)에 라우팅된 거래 요청시 구현될 것으로 예상되는 체결 가능성(즉, 거래 요청의 퍼센트 만족)을 결정하기 위한 통계적 모델을 포함한다. 이런 통계적 모델은 예컨대 주어진 주기(예컨대, 지난 30개의 거래요청, 지난 달, 이전 12개월 등)에 걸쳐 이런 개별 거래소에서 구현된 역사적 체결 데이터를 포함할 수 있다. 스마트 포스팅 논리모듈(1126e)은, 예컨대 다른 요인들 중에서 각 거래소 서버(1106)에서 최우선호가(the top of book)의 깊이, 거래소 서버들(1106)에 걸쳐 변동성 수준, 및 거래 요청의 실행을 위한 평균 지연시간을 포함한 요인들을 고려할 수 있다.
지역 및 국제 거래소 접속 로직모듈(1126f)은 거래소 서버(1106)가 지역적이거나 국제적인지 여부에 따라 거래 요청이 거래소 서버(1106)로 보내져야 하는지에 대한 정보를 제공한다. 피관찰 규제들 등 이용되는 적절한 프로토콜(들)에 대한 내부 및/또는 외부 저장된 데이터가 이런 데이터를 제공하는데 이용될 수 있다. 이런 데이터는 예컨대 요청(들)이 제공된 자원(들)(106,1106)을 고려해 라우팅 프로세서(들)(104,1104)에 의해 외부 자원(106,1106)으로 라우팅된 거래 또는 기타 프로세싱 요청들이 적절히 포맷되도록 보장하고 이런 요청(들)이 모든 적용가능한 법적 기준에 맞는 것을 보장하는데 이용될 수 있다.
공격적 관리 논리모듈(1126g)은 개개의 거래소 서버들(1106)에 대한 체결 퍼센트의 확률을 결정하고 따라서 이런 서버들에 라우팅된 실행요청을 변경하기 위한 확률 모델을 포함한다. 이런 모듈(1126g)은 다른 요인들 중에서, 예컨대, 각 거래소 서버(1106)에서 필 레이트, 각 거래소 서버(1106)에서 최우선호가(depth-of-book) 및 거래소 서버들(1106)을 가로지르는 변동성 수준들과 같은 요인들을 고려할 수 있다.
본 명세서는 특정 현재 바람직한 실시예와 연계하여 제공되고 예시되어 있으나, 본 명세서에 개시된 본 발명(들)의 기술사상 및 범위로부터 벗어남이 없이 많은 변형 및 변경들이 이루어질 수 있다. 따라서, 본 명세서 및 본 발명(들)은 상기 나타낸 정확한 구성요소 또는 방법 및 구성의 세부내용에 국한되지 않는다. 본 프로세스 자체 필요하거나 고유한 정도를 제외하고, 도면을 포함한 본 명세서에 기술된 방법 또는 프로세스들의 단계들 또는 국면들에 특별한 주문이 전혀 의도되거나 포함되지 않는다. 많은 경우, 프로세스 단계의 순서는 기술된 방법의 목적, 효과 또는 의미를 바꾸지 않고 변할 수 있다. 청구의 범위는 균등물 학설 및 관련된 학설에 대한 고려로 인해 주어진 특허청구범위에 의해서만 단지 정의된다.

Claims (77)

  1. 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템에 있어서,
    기계 해석가능한 명령어를 실행하도록 구성된 적어도 하나의 프로세서를 포함하며,
    상기 적어도 하나의 프로세서는 상기 시스템이,
    하나 이상의 데이터 소스들로부터 복수의 실행 프로세서들에 의해 실행될 수 있는 적어도 하나의 데이터 프로세스의 실행을 위한 명령어를 나타내는 신호를 수신하고,
    상기 적어도 하나의 데이터 프로세스를, 각각 복수의 네트워크 실행 프로세서들 중 서로 다른 것으로 라우팅되는 복수의 데이터 프로세싱 세그먼트들로 분할하며,
    복수의 네트워크 실행 프로세서들 각각으로 시스템에 의해 라우팅된 이전 데이터 프로세싱 요청의 실행시 지연에 적어도 부분적으로 기초하여, 복수의 타이밍 파라미터들을 결정하고,
    복수의 데이터 프로세싱 세그먼트들과 관련된 타이밍 파라미터들을 이용해, 복수의 데이터 프로세싱 세그먼트들을 복수의 해당 네트워크 거래소 서버들로 라우팅하게 하며,
    상기 네트워크 실행 프로세서들은 하나 이상의 거래소 서버들을 포함하고 상기 데이터 프로세싱 세그먼트들은 금융 상품들의 거래 요청을 나타내며,
    상기 복수의 타이밍 파라미터들 각각은 복수의 데이터 프로세싱 세그먼트들 중 대응하는 하나와 관련되며, 상기 복수의 타이밍 파라미터들은 복수의 네트워크 실행 프로세서들에 의해 복수의 데이터 프로세싱 세그먼트들의 동기화된 실행을 야기하도록 결정되는, 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  2. 제 1 항에 있어서,
    복수의 결정된 타이밍 파라미터들 중 적어도 하나는 적어도 부분적으로 상기 복수의 네트워크 실행 프로세서들 중 적어도 하나로 시스템에 의해 라우팅된 신호 프로세싱 요청의 실행시 동적으로 모니터되는 지연을 기초로 결정되는, 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  3. 제 1 항에 있어서,
    복수의 결정된 타이밍 파라미터들 중 적어도 하나는 적어도 부분적으로 통신 지연 및 프로세싱 지연 중 적어도 하나를 기초로 결정되는, 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  4. 제 1 항에 있어서,
    복수의 결정된 타이밍 파라미터들 중 적어도 하나는 적어도 부분적으로 지연 확률 모델을 기초로 결정되는, 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  5. 제 1 항에 있어서,
    상기 금융 상품들은 원자재 및 무형의 거래 상품들 중 적어도 하나를 포함하는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  6. 제 1 항에 있어서,
    상기 금융 상품들은 주식, 채권 및 옵션들 중 적어도 하나를 포함하는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  7. 제 1 항에 있어서,
    상기 적어도 하나의 프로세서는 상기 시스템이, 적어도 하나의 수량 조건을 나타내는 데이터를 복수의 데이터 프로세싱 세그먼트들 중 적어도 하나의 각각에 연관시키게 하기 위한 명령어들을 실행하도록 더 구성되고,
    상기 적어도 하나의 수량 조건은 적어도 하나의 데이터 프로세싱 세그먼트들 각각으로 표현되는 거래 요청에 따라 거래될 금융 상품들의 적어도 하나의 수량 및 적어도 하나의 수량 조건에 각각 대응하는 적어도 하나의 가격 조건을 나타내며,
    상기 가격 조건은 적어도 하나의 데이터 프로세싱 세그먼트에 의해 표현된 거래가 실행될 적어도 하나의 제안 가격을 나타내고,
    상기 적어도 하나의 수량 조건은, 적어도 하나의 데이터 프로세싱 세그먼트가 라우팅되는 네트워크 실행 프로세서(들)와 관련된 시장에서, 상기 적어도 하나의 가격 조건과 등가의 가격으로 공모된 금융 상품들 중 적어도 하나의 수량보다 더 큰, 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  8. 제 7 항에 있어서,
    적어도 하나의 수량 조건은 데이터 프로세싱 세그먼트가 라우팅되는 네트워크 실행 프로세서와 관련된 시장에서 실행된 거래 이력(trading history)을 적어도 부분적으로 기초로 하여 결정되는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  9. 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템에 있어서,
    기계 해석가능한 명령어를 실행하도록 구성된 적어도 하나의 프로세서를 포함하고,
    상기 적어도 하나의 프로세서는 상기 시스템이,
    복수의 네트워크 실행 프로세서들 각각에 의한 신호 프로세싱 실행 요청의 실행을 모니터하고,
    상기 시스템과 복수의 네트워크 실행 프로세서 각각 사이에 신호 프로세스들의 실행시 지연과 관련된 적어도 하나의 타이밍 파라미터를 결정하며,
    기계 판독가능한 메모리에 적어도 하나의 타이밍 파라미터를 저장하게 하고,
    상기 적어도 하나의 타이밍 파라미터는 상기 복수의 네트워크 실행 프로세서들에 의한 복수의 데이터 프로세싱 요청의 동기화된 실행을 야기하도록 결정되며,
    상기 네트워크 실행 프로세서들은 거래소 서버를 포함하고 데이터 프로세싱 세그먼트는 금융 상품의 거래를 위한 요청을 나타내는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  10. 제 9 항에 있어서,
    적어도 하나의 지연은 통신 지연 및 프로세스 지연 중 적어도 하나에 대한 것인 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  11. 제 9 항에 있어서,
    신호 프로세싱 요청의 실행이 주기적으로 모니터되는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  12. 제 9 항에 있어서,
    신호 프로세싱 실행 요청의 실행이 연속으로 모니터되는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 시스템.
  13. 멀티 네트워크 컴퓨팅 자원에 의한 데이터 동기화 프로세싱 방법에 있어서,
    적어도 하나의 프로세서가
    하나 이상의 데이터 소스들로부터 복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 적어도 하나의 데이터 프로세스의 실행을 위한 명령어를 나타내는 신호를 수신하고,
    적어도 하나의 데이터 프로세스를 각각 복수의 네트워크 실행 프로세서들 중 다른 것으로 라우팅되는 복수의 데이터 프로세싱 세그먼트들로 분할하며,
    복수의 네트워크 실행 프로세서들 각각으로 시스템에 의해 라우팅된 이전 데이터 프로세싱 요청의 실행시 지연에 적어도 부분적으로 기초하여, 복수의 타이밍 파라미터들을 결정하고,
    복수의 데이터 프로세싱 세그먼트들과 관련된 타이밍 파라미터들을 이용해, 복수의 데이터 프로세싱 세그먼트들을 복수의 해당 네트워크 실행 프로세서들로 라우팅하도록 구성된 기계 해석가능한 명령어를 실행하는 적어도 하나의 프로세서에 의해 수행되고,
    데이터 프로세싱 세그먼트는 하나 이상의 금융 상품들에 대한 거래 요청을 나타내고,
    상기 복수의 타이밍 파라미터들 각각은 복수의 데이터 프로세싱 세그먼트들 중 대응하는 하나와 관련되며, 상기 복수의 타이밍 파라미터들은 복수의 네트워크 실행 프로세서들에 의해 복수의 데이터 프로세싱 세그먼트들의 동기화된 실행을 야기하도록 결정되는 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 방법.
  14. 제 13 항에 있어서,
    상기 기계 해석가능한 명령어는 적어도 하나의 프로세서가
    각각의 복수의 데이터 프로세싱 세그먼트들 중 적어도 하나와 적어도 하나의 수량 조건을 나타내는 데이터를 연관시키게 하도록 더 구성되고,
    상기 적어도 하나의 수량 조건은 적어도 하나의 데이터 프로세싱 세그먼트들로 표현되는 거래 요청에 따라 거래되는 금융 상품의 적어도 하나의 수량 및 적어도 하나의 수량 조건에 각각 대응하는 적어도 하나의 가격 조건을 나타내며,
    상기 가격 조건은 적어도 하나의 데이터 프로세싱 세그먼트에 의해 표현된 거래가 실행되는 적어도 하나의 제안 가격을 나타내고,
    상기 적어도 하나의 수량 조건은, 적어도 하나의 데이터 프로세싱 세그먼트가 라우팅되는 네트워크 실행 프로세서(들)와 관련된 시장에서, 상기 적어도 하나의 가격 조건과 등가의 가격으로 공모된 금융 상품 중 적어도 하나의 수량보다 더 큰, 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 방법.
  15. 멀티 네트워크 컴퓨팅 자원에 의하여 데이터의 동기화된 프로세싱을 야기하는 방법에 있어서,
    적어도 하나의 프로세서가
    복수의 네트워크 컴퓨팅 자원들 각각에 의해 신호 프로세싱 실행 요청의 실행을 모니터하고,
    시스템과 복수의 네트워크 컴퓨팅 자원들 각각 사이에 신호 프로세스의 실행시 지연과 관련된 적어도 하나의 타이밍 파라미터를 결정하며,
    적어도 하나의 프로세서에 의해 접속될 수 있는 기계 판독가능한 메모리에 적어도 하나의 타이밍 파라미터를 저장하게 하도록 구성된 기계 해석가능한 명령어를 실행하는 적어도 하나의 프로세서에 의해 수행되며,
    상기 복수의 신호 프로세싱 실행 요청은 하나 이상의 금융 상품들의 거래를 위한 요청을 나타내며, 상기 복수의 타이밍 파라미터는 상기 복수의 네트워크 컴퓨팅 자원들에 의한 실행 요청의 동기화된 실행을 야기하도록 결정되는, 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세싱 방법.
  16. 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화된 프로세싱을 야기하고,
    적어도 하나의 프로세서가
    하나 이상의 데이터 소스들로부터 복수의 네트워크 컴퓨팅 자원에 의해 실행가능한 적어도 하나의 데이터 프로세스의 실행을 위한 명령어를 나타내는 신호를 수신하고,
    적어도 하나의 데이터 프로세스를 복수의 데이터 프로세싱 세그먼트로 분할하며,
    시스템에 의해 복수의 네트워크 실행 프로세서들 각각에 라우팅된 이전 데이터 프로세싱 요청의 실행시 지연을 적어도 부분적으로 기초하여, 복수의 타이밍 파라미터를 결정하고,
    복수의 데이터 프로세싱 세그먼트들과 관련된 타이밍 파라미터를 이용해, 복수의 데이터 프로세싱 세그먼트를 복수의 해당 네트워크 실행 프로세스들로 라우팅하게 하도록 구성된 비일시적 기계 판독가능한 프로그래밍 구조를 포함하고,
    각 데이터 프로세싱 세그먼트는 복수의 네트워크 실행 프로세서들 중 다른 것으로 라우팅되며, 각 데이터 프로세싱 세그먼트는 하나 이상의 금융 상품의 거래를 위한 요청을 나타내며,
    복수의 타이밍 파라미터들 각각은 복수의 데이터 프로세싱 세그먼트들 중 대응하는 것과 관련되고, 복수의 타이밍 파라미터들은 복수의 네트워크 실행 프로세서들에 의해 복수의 데이터 프로세싱 세그먼트들의 동기화된 실행을 야기하도록 결정되는, 컴퓨터 판독가능한 기록매체.
  17. 제 16 항에 있어서,
    상기 기계 판독가능한 프로그래밍 구조는 적어도 하나의 프로세서가
    복수의 데이터 프로세싱 세그먼트 중 적어도 하나 각각과 적어도 하나의 수량 조건을 나타내는 데이터를 연관시키도록 더 구성되고,
    적어도 하나의 수량 조건은 적어도 하나의 데이터 프로세싱 세그먼트로 표현되는 거래 요청에 따라 거래되는 금융 상품 중 적어도 하나의 수량 및 적어도 하나의 수량 조건에 각각 대응하는 적어도 하나의 가격 조건을 나타내며, 상기 가격 조건은 적어도 하나의 데이터 프로세싱 세그먼트에 의해 표현된 거래가 실행될 적어도 하나의 제안 가격을 나타내며,
    상기 적어도 하나의 수량 조건은, 적어도 하나의 데이터 프로세싱 세그먼트가 라우팅되는 네트워크 실행 프로세서(들)와 관련된 시장에서, 상기 적어도 하나의 가격 조건과 등가의 가격으로 공모된 금융 상품 중 적어도 하나의 수량보다 더 큰, 컴퓨터 판독가능한 기록매체.
  18. 멀티 네트워크 컴퓨팅 자원에 의한 데이터의 동기화 프로세스를 야기하도록 구성되고, 적어도 하나의 프로세서가
    복수의 네트워크 컴퓨팅 자원들 각각에 의해 신호 프로세싱 실행 요청의 실행을 모니터하고,
    시스템과 복수의 네트워크 컴퓨팅 자원들 각각 사이에 신호 프로세스의 실행시 지연과 관련된 적어도 하나의 타이밍 파라미터를 결정하며,
    적어도 하나의 프로세서에 의해 접속될 수 있는 기계 판독가능한 메모리에 적어도 하나의 타이밍 파라미터를 저장하게 하도록 구성된 비일시적 기계판독가능 프로그래밍 구조들을 구비하고,
    상기 복수의 신호 프로세싱 실행 요청은 하나 이상의 금융 상품들의 거래를 위한 요청을 나타내며, 상기 복수의 타이밍 파라미터들은 복수의 네트워크 컴퓨팅 자원들에 의한 실행 요청의 동기화된 실행을 야기하도록 결정되는, 컴퓨터 판독가능 기록매체.
  19. 복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 복수의 데이터 프로세스 부분들의 실행을 위한 명령어들을 나타내는 신호들과 하나 이상의 금융 상품들의 복수의 제안된 거래를 나타내는 데이터 프로세스를 연관시키고,
    적어도 하나의 관련된 타이밍 파라미터를 이용해, 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어를 나타내는 신호들을 복수의 네트워크 컴퓨팅 자원들로 라우팅하도록 구성된 적어도 하나의 프로세스를 구비하며,
    적어도 하나의 타이밍 파라미터는 적어도 부분적으로 적어도 하나의 네트워크 컴퓨팅 자원에 의한 신호 프로세싱 요청의 실행과 관련된 하나 이상의 지연을 이용하여 결정되며,
    적어도 하나의 관련된 타이밍 파라미터는 복수의 네트워크 컴퓨팅 자원에 의한 복수의 제안된 거래의 동기화된 실행을 야기하도록 결정되는 디바이스.
  20. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅되는 신호 프로세싱 요청의 실행 시 동적으로 모니터되는 지연을 기초로 결정되는 디바이스.
  21. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 통계적 지연을 기초로 결정되는 디바이스.
  22. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 이력적 지연을 기초로 결정되는 디바이스.
  23. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 예상 지연을 기초로 결정되는 디바이스.
  24. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 동시에 일어나도록 결정되는 디바이스.
  25. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 비동시적 시퀀스에 따르도록 결정되는 디바이스.
  26. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 결정된 상대적 타이밍에 따르도록 결정되는 디바이스.
  27. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 통신 지연 또는 프로세스 지연 중 적어도 하나를 기초로 결정되는 디바이스.
  28. 제 19 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 지연 확률 모델을 기초로 결정되는 디바이스.
  29. 제 19 항에 있어서,
    상기 금융 상품은 원자재 또는 통화(currency) 상품 중 적어도 하나를 포함하는 디바이스.
  30. 제 19 항에 있어서,
    상기 금융 상품은 주식 상품, 비주식 상품 및 그들의 파생물 중 적어도 하나를 포함하는 디바이스.
  31. 복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 복수의 데이터 프로세스 부분들의 실행을 위한 명령어들을 나타내는 신호들과 하나 이상의 금융 상품들의 복수의 제안된 거래를 나타내는 데이터 프로세스를 연관시키는 단계; 및
    적어도 하나의 관련된 타이밍 파라미터를 이용해, 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어를 나타내는 신호들을 복수의 네트워크 컴퓨팅 자원들로 라우팅하는 단계를 포함하고,
    적어도 하나의 타이밍 파라미터는 적어도 하나의 네트워크 컴퓨팅 자원에 의한 신호 프로세싱 요청의 실행과 관련된 하나 이상의 지연을 이용해 적어도 부분적으로 결정되며,
    적어도 하나의 관련된 타이밍 파라미터는 복수의 네트워크 컴퓨팅 자원에 의한 복수의 제안된 거래의 동기화된 실행을 야기하도록 결정되는, 적어도 하나의 프로세스에 의한 수행 방법.
  32. 제 31 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 동적으로 모니터되는 지연을 기초로 결정되는 적어도 하나의 프로세스에 의한 수행 방법.
  33. 제 31 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나에 라우팅된 신호 프로세싱 요청의 실행시 통계적 지연을 기초로 결정되는 적어도 하나의 프로세스에 의한 수행 방법.
  34. 제 31 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나에 라우팅된 신호 프로세싱 요청의 실행시 이력적 지연을 기초로 결정되는 적어도 하나의 프로세스에 의한 수행 방법.
  35. 제 31 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나에 라우팅된 신호 프로세싱 요청의 실행시 예상 지연을 기초로 결정되는 적어도 하나의 프로세스에 의한 수행 방법.
  36. 제 31 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 동시에 일어나도록 결정되는 적어도 하나의 프로세스에 의한 수행 방법.
  37. 제 31 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 비동시적인 시퀀스에 따르도록 결정되는 적어도 하나의 프로세스에 의한 수행 방법.
  38. 제 31 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 결정된 상대적 타이밍에 따르도록 결정되는 적어도 하나의 프로세스에 의한 수행 방법.
  39. 적어도 하나의 프로세서가
    복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 복수의 데이터 프로세스 부분들의 실행을 위한 명령어들을 나타내는 신호들과 하나 이상의 금융 상품들의 복수의 제안된 거래를 나타내는 데이터 프로세스를 연관시키고,
    적어도 하나의 관련된 타이밍 파라미터를 이용해, 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어를 나타내는 신호들을 복수의 네트워크 컴퓨팅 자원들로 라우팅하도록 구성된 비일시적 기계 판독가능한 프로그래밍 구조를 구비하며,
    적어도 하나의 타이밍 파라미터는 적어도 하나의 네트워크 컴퓨팅 자원에 의한 신호 프로세싱 요청의 실행과 관련된 하나 이상의 지연을 적어도 부분적으로 이용하여 결정되며,
    적어도 하나의 관련된 타이밍 파라미터는 복수의 네트워크 컴퓨팅 자원들에 의한 복수의 제안된 거래의 동기화된 실행을 야기하도록 결정되는 컴퓨터 판독가능 기록매체.
  40. 제 39 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 동적으로 모니터되는 지연을 기초로 결정되는 컴퓨터 판독가능 기록매체.
  41. 제 39 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 통계적 지연을 기초로 적어도 결정되는 컴퓨터 판독가능 기록매체.
  42. 제 39 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 이력적 지연을 기초로 결정되는 컴퓨터 판독가능 기록매체.
  43. 제 39 항에 있어서,
    상기 적어도 하나의 타아밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 예상 지연을 기초로 결정되는 컴퓨터 판독가능 기록매체.
  44. 제 39 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 동시에 일어나도록 결정되는 컴퓨터 판독가능 기록매체.
  45. 제 39 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 비동시적인 시퀀스에 따르도록 결정되는 컴퓨터 판독가능 기록매체.
  46. 제 39 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 실행이 결정된 상대적 타이밍에 따르도록 결정되는 컴퓨터 판독가능 기록매체.
  47. 적어도 하나의 프로세서가,
    복수의 데이터 프로세싱 세그먼트들을 나타내는 신호를 발생시키고,
    복수의 네트워크 컴퓨팅 자원들 각각에 라우팅된 이전 데이터 프로세싱 요청의 실행시 지연을 적어도 부분적으로 기초하여, 복수의 타이밍 파라미터를 결정하며,
    복수의 데이터 프로세싱 세그먼트와 관련된 타이밍 파라미터를 이용해, 복수의 데이터 프로세싱 세그먼트를 복수의 네트워크 컴퓨팅 자원으로 라우팅하도록 구성되는 기계 해석가능한 명령어들을 실행하며,
    각 데이터 프로세싱 세그먼트는 복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 데이터 프로세스의 부분의 실행을 위한 명령어를 나타내며,
    복수의 타이밍 파라미터들 각각은 복수의 데이터 프로세싱 세그먼트들 중 대응하는 하나와 연결되고, 복수의 타이밍 파라미터들은 복수의 네트워크 컴퓨팅 자원들에 의해 복수의 데이터 프로세싱 세그먼트들의 동기화된 실행을 야기하도록 결정되는 적어도 하나의 프로세서에 의한 수행 방법.
  48. 제 47 항에 있어서,
    상기 기계 해석가능한 명령어는 또한,
    적어도 하나의 프로세스가 복수의 데이터 프로세싱 세그먼트 각각과 적어도 하나의 수량 조건을 나타내는 데이터를 연관시키도록 구성되고,
    상기 적어도 하나의 수량 조건은 대응하는 데이터 프로세싱 세그먼트에 의해 표현된 요청에 따라 거래되는 금융 상품의 적어도 하나의 수량 및 적어도 하나의 해당 가격 조건을 나타내며, 상기 가격 조건은 적어도 하나의 데이터 프로세싱 세그먼트에 의해 표현된 거래가 실행되는 적어도 하나의 제안 가격을 나타내는, 적어도 하나의 프로세서에 의한 수행 방법.
  49. 복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 복수의 데이터 프로세스 부분들의 실행을 위한 명령어들을 나타내는 신호들과 하나 이상의 금융 상품들의 복수의 제안된 거래를 나타내는 데이터 프로세스를 연관시키는 단계; 및
    적어도 하나의 관련된 타이밍 파라미터를 이용해, 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어를 나타내는 신호들을 복수의 네트워크 컴퓨팅 자원들로 라우팅하는 단계를 포함하며,
    적어도 하나의 타이밍 파라미터는 적어도 하나의 네트워크 컴퓨팅 자원에 의한 신호 프로세싱 요청의 실행과 관련된 하나 이상의 지연을 적어도 부분적으로 이용하여 결정되며,
    적어도 하나의 관련된 타이밍 파라미터는 복수의 네트워크 컴퓨팅 자원에 의한 하나 이상의 제안된 거래의 복수의 부분들을 위해 명령어들을 나타내는 신호들의 동기화된 실행을 야기하도록 결정되는, 적어도 하나의 데이터 프로세서에 의한 수행 방법.
  50. 복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 복수의 데이터 프로세스 부분들의 실행을 위한 명령어들을 나타내는 신호들과 하나 이상의 금융 상품들의 복수의 제안된 거래를 나타내는 데이터 프로세스를 연관시키고;
    적어도 하나의 관련된 타이밍 파라미터를 이용해, 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어를 나타내는 신호들을 복수의 네트워크 컴퓨팅 자원들로 라우팅하도록 구성된 적어도 하나의 프로세서를 포함하며,
    적어도 하나의 타이밍 파라미터는 적어도 하나의 네트워크 컴퓨팅 자원에 의한 신호 프로세싱 요청의 실행과 관련된 하나 이상의 지연을 적어도 부분적으로 이용하여 결정되며,
    적어도 하나의 관련된 타이밍 파라미터는 복수의 네트워크 컴퓨팅 자원에 의한 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어들을 나타내는 신호들의 동기화된 도달을 야기하도록 결정되는, 디바이스.
  51. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 동적으로 모니터되는 지연을 기초로 결정되는 디바이스.
  52. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 통계적 지연을 기초로 결정되는 디바이스.
  53. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 이력적 지연을 기초로 결정되는 디바이스.
  54. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 예상 지연을 기초로 결정되는 디바이스.
  55. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 동시에 일어나도록 결정되는 디바이스.
  56. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 비동시적인 시퀀스에 따르도록 결정되는 디바이스.
  57. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 결정된 상대적 타이밍에 따르도록 결정되는 디바이스.
  58. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 통신 지연 또는 프로세스 지연 중 적어도 하나를 기초로 결정되는 디바이스.
  59. 제 50 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 지연 확률 모델을 기초로 결정되는 디바이스.
  60. 제 50 항에 있어서,
    상기 금융 상품은 원자재 또는 통화(currency) 상품 중 적어도 하나를 포함하는 디바이스.
  61. 제 50 항에 있어서,
    상기 금융 상품은 주식 상품, 비주식 상품 및 그들의 파생물 중 적어도 하나를 포함하는 디바이스.
  62. 복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 복수의 데이터 프로세스 부분들의 실행을 위한 명령어들을 나타내는 신호들과 하나 이상의 금융 상품들의 복수의 제안된 거래를 나타내는 데이터 프로세스를 연관시키는 단계; 및
    적어도 하나의 관련된 타이밍 파라미터를 이용해, 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어를 나타내는 신호들을 복수의 네트워크 컴퓨팅 자원들로 라우팅하는 단계를 포함하며,
    적어도 하나의 타이밍 파라미터는 적어도 하나의 네트워크 컴퓨팅 자원에 의한 신호 프로세싱 요청의 실행과 관련된 하나 이상의 지연을 적어도 부분적으로 이용하여 결정되며,
    적어도 하나의 관련된 타이밍 파라미터는 복수의 네트워크 컴퓨팅 자원에 의한 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어들을 나타내는 신호들의 동기화된 도달을 야기하도록 결정되는, 적어도 하나의 프로세스에 의한 수행 방법.
  63. 제 62 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 동적으로 모니터되는 지연을 기초로 결정되는 적어도 하나의 프로세서에 의한 수행 방법.
  64. 제 62 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 통계적 지연을 기초로 결정되는 적어도 하나의 프로세서에 의한 수행 방법.
  65. 제 62 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 이력적 지연을 기초로 결정되는 적어도 하나의 프로세서에 의한 수행 방법.
  66. 제 62 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 예상 지연을 기초로 결정되는 적어도 하나의 프로세서에 의한 수행 방법.
  67. 제 62 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 동시에 일어나도록 결정되는 적어도 하나의 프로세서에 의한 수행 방법.
  68. 제 62 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 비동시적인 시퀀스에 따르도록 결정되는 적어도 하나의 프로세서에 의한 수행 방법.
  69. 제 62 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 결정된 상대적 타이밍에 따르도록 결정되는 적어도 하나의 프로세서에 의한 수행 방법.
  70. 적어도 하나의 프로세서가,
    복수의 네트워크 컴퓨팅 자원에 의해 실행될 수 있는 복수의 데이터 프로세스 부분들의 실행을 위한 명령어들을 나타내는 신호들과 하나 이상의 금융 상품들의 복수의 제안된 거래를 나타내는 데이터 프로세스를 연관시키고;
    적어도 하나의 관련된 타이밍 파라미터를 이용해, 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어를 나타내는 신호들을 복수의 네트워크 컴퓨팅 자원들로 라우팅하도록 구성된 비일시적 기계 판독가능한 프로그래밍 구조를 포함하며,
    적어도 하나의 타이밍 파라미터는 적어도 하나의 네트워크 컴퓨팅 자원에 의한 신호 프로세싱 요청의 실행과 관련된 하나 이상의 지연을 적어도 부분적으로 이용하여 결정되며,
    적어도 하나의 관련된 타이밍 파라미터는 복수의 네트워크 컴퓨팅 자원에 의한 복수의 제안된 거래의 복수의 부분들의 실행을 위한 명령어들을 나타내는 신호들의 동기화된 도달을 야기하도록 결정되는, 컴퓨터 판독가능한 기록매체.
  71. 제 70 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 동적으로 모니터되는 지연을 기초로 결정되는 컴퓨터 판독가능한 기록매체.
  72. 제 70 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 통계적 지연을 기초로 결정되는 적컴퓨터 판독가능한 기록매체.
  73. 제 70 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 이력적 지연을 기초로 결정되는 컴퓨터 판독가능한 기록매체.
  74. 제 70 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 적어도 부분적으로 복수의 네트워크 컴퓨팅 자원들 중 적어도 하나로 라우팅된 신호 프로세싱 요청의 실행시 예상 지연을 기초로 결정되는 컴퓨터 판독가능한 기록매체.
  75. 제 70 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 동시에 일어나도록 결정되는 컴퓨터 판독가능한 기록매체.
  76. 제 70 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 비동시적인 시퀀스에 따르도록 결정되는 컴퓨터 판독가능한 기록매체.
  77. 제 70 항에 있어서,
    상기 적어도 하나의 타이밍 파라미터는 동기화된 도달이 결정된 상대적 타이밍에 따르도록 결정되는 컴퓨터 판독가능한 기록매체.
KR1020127017789A 2009-12-10 2010-06-08 네트워크 컴퓨팅 자원에 의한 데이터 동기화 프로세싱 KR101667697B1 (ko)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US28537509P 2009-12-10 2009-12-10
US61/285,375 2009-12-10
PCT/CA2010/000872 WO2011069234A1 (en) 2009-12-10 2010-06-08 Synchronized processing of data by networked computing resources

Publications (2)

Publication Number Publication Date
KR20120101535A KR20120101535A (ko) 2012-09-13
KR101667697B1 true KR101667697B1 (ko) 2016-10-19

Family

ID=43381950

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020127017789A KR101667697B1 (ko) 2009-12-10 2010-06-08 네트워크 컴퓨팅 자원에 의한 데이터 동기화 프로세싱

Country Status (13)

Country Link
US (8) US10650450B2 (ko)
EP (1) EP2510451B1 (ko)
JP (2) JP5785556B2 (ko)
KR (1) KR101667697B1 (ko)
CN (2) CN102859938B (ko)
AU (6) AU2010330629B2 (ko)
BR (1) BR112012013891B1 (ko)
CA (4) CA2707196C (ko)
ES (1) ES2754099T3 (ko)
MX (1) MX337624B (ko)
SG (2) SG181616A1 (ko)
WO (1) WO2011069234A1 (ko)
ZA (2) ZA201205093B (ko)

Families Citing this family (63)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8122124B1 (en) 2008-09-29 2012-02-21 Amazon Technologies, Inc. Monitoring performance and operation of data exchanges
US7865594B1 (en) 2008-09-29 2011-01-04 Amazon Technologies, Inc. Managing resources consolidation configurations
US7930393B1 (en) 2008-09-29 2011-04-19 Amazon Technologies, Inc. Monitoring domain allocation performance
US8316124B1 (en) 2008-09-29 2012-11-20 Amazon Technologies, Inc. Managing network data display
US8286176B1 (en) 2008-09-29 2012-10-09 Amazon Technologies, Inc. Optimizing resource configurations
US8117306B1 (en) 2008-09-29 2012-02-14 Amazon Technologies, Inc. Optimizing content management
US9230259B1 (en) 2009-03-20 2016-01-05 Jpmorgan Chase Bank, N.A. Systems and methods for mobile ordering and payment
US7917618B1 (en) 2009-03-24 2011-03-29 Amazon Technologies, Inc. Monitoring web site content
US9959572B2 (en) 2009-12-10 2018-05-01 Royal Bank Of Canada Coordinated processing of data by networked computing resources
SG181616A1 (en) 2009-12-10 2012-07-30 Royal Bank Of Canada Synchronized processing of data by networked computing resources
US9979589B2 (en) 2009-12-10 2018-05-22 Royal Bank Of Canada Coordinated processing of data by networked computing resources
US9940670B2 (en) 2009-12-10 2018-04-10 Royal Bank Of Canada Synchronized processing of data by networked computing resources
US10057333B2 (en) 2009-12-10 2018-08-21 Royal Bank Of Canada Coordinated processing of data by networked computing resources
US8930525B2 (en) * 2010-04-27 2015-01-06 Hewlett-Packard Development Company, L.P. Method and apparatus for measuring business transaction performance
US8832061B2 (en) 2010-07-02 2014-09-09 Salesforce.Com, Inc. Optimizing data synchronization between mobile clients and database systems
US10263888B2 (en) * 2010-09-30 2019-04-16 Trading Technologies International, Inc. Sticky order routers
JP5701708B2 (ja) * 2011-07-26 2015-04-15 株式会社日立製作所 通信システム
KR101963321B1 (ko) * 2012-09-12 2019-03-28 아이이엑스 그룹, 인크. 전송 레이턴시 평준화 장치, 방법 및 시스템
WO2014089673A1 (en) * 2012-12-11 2014-06-19 Joseph Schmitt System and method for automated trading of financial interests
GB2512061A (en) * 2013-03-18 2014-09-24 Rapid Addition Ltd Transactional message format data conversion
EP2936420A4 (en) 2013-06-24 2016-08-03 Aequitas Innovations Inc SYSTEM AND METHOD FOR AUTOMATED TRADING OF FINANCIAL INVESTMENTS
US9922101B1 (en) * 2013-06-28 2018-03-20 Emc Corporation Coordinated configuration, management, and access across multiple data stores
US10002348B1 (en) * 2013-07-24 2018-06-19 Amazon Technologies, Inc. Routing and processing of payment transactions
US20160239913A1 (en) * 2013-08-13 2016-08-18 Cfph, Llc Foreign exchange trading
EP3066631A4 (en) * 2013-11-07 2017-03-15 Cfph, Llc Foreign exchange trading
EP3117393A4 (en) 2014-03-11 2017-08-16 Chicago Mercantile Exchange, Inc. Improved market operation through regulation of incoming order match allocation and/or dynamic resting order match allocation priorities
BR112016024211A2 (pt) * 2014-04-16 2017-08-15 Iex Group Inc sistemas e métodos para provisão de informação atualizada para transações
US11157998B2 (en) 2014-08-04 2021-10-26 Renaissance Technologies Llc System and method for executing synchronized trades in multiple exchanges
CA2958845C (en) 2014-08-22 2022-11-08 Iex Group, Inc. Dynamic peg orders in an electronic trading system
US10706470B2 (en) 2016-12-02 2020-07-07 Iex Group, Inc. Systems and methods for processing full or partially displayed dynamic peg orders in an electronic trading system
US10311515B2 (en) 2014-09-17 2019-06-04 Iex Group, Inc. System and method for a semi-lit market
CA2944925C (en) 2014-10-08 2017-04-25 Tsx Inc. Selective delayed and undelayed database updating
CA2940605C (en) 2014-10-20 2018-08-21 Tsx Inc. Database updating with latency tolerance
WO2016095012A1 (en) * 2014-12-15 2016-06-23 Royal Bank Of Canada Verification of data processes in a network of computing resources
US11165714B2 (en) 2014-12-15 2021-11-02 Royal Bank Of Canada Verification of data processes in a network of computing resources
US9769248B1 (en) 2014-12-16 2017-09-19 Amazon Technologies, Inc. Performance-based content delivery
US9705769B1 (en) * 2014-12-17 2017-07-11 Juniper Networks, Inc. Service latency monitoring using two way active measurement protocol
US10311371B1 (en) 2014-12-19 2019-06-04 Amazon Technologies, Inc. Machine learning based content delivery
US10311372B1 (en) 2014-12-19 2019-06-04 Amazon Technologies, Inc. Machine learning based content delivery
US10225365B1 (en) 2014-12-19 2019-03-05 Amazon Technologies, Inc. Machine learning based content delivery
KR102494427B1 (ko) * 2015-02-27 2023-02-01 로얄 뱅크 오브 캐나다 네트워크 컴퓨팅 자원에 의한 데이터 프로세싱의 조정
US10225326B1 (en) 2015-03-23 2019-03-05 Amazon Technologies, Inc. Point of presence based data uploading
US9774619B1 (en) 2015-09-24 2017-09-26 Amazon Technologies, Inc. Mitigating network attacks
US10506074B2 (en) * 2015-09-25 2019-12-10 Verizon Patent And Licensing Inc. Providing simultaneous access to content in a network
US10817606B1 (en) * 2015-09-30 2020-10-27 Fireeye, Inc. Detecting delayed activation malware using a run-time monitoring agent and time-dilation logic
US10419975B1 (en) * 2015-12-11 2019-09-17 Spectranet, Inc. Parallel multi-bit low latency wireless messaging
WO2017117191A1 (en) 2015-12-30 2017-07-06 Chicago Mercantile Exchange Inc. Execution of co-dependent transactions in a transaction processing system
CN105847329B (zh) * 2016-03-15 2023-04-07 优品财富管理有限公司 一种基于股票数据服务器的管理设备及方法
US20200302526A1 (en) * 2016-03-24 2020-09-24 Tradition America, Llc Make live at order processing system and method
US10943297B2 (en) * 2016-08-09 2021-03-09 Chicago Mercantile Exchange Inc. Systems and methods for coordinating processing of instructions across multiple components
US10748210B2 (en) 2016-08-09 2020-08-18 Chicago Mercantile Exchange Inc. Systems and methods for coordinating processing of scheduled instructions across multiple components
WO2018044334A1 (en) 2016-09-02 2018-03-08 Iex Group. Inc. System and method for creating time-accurate event streams
US11037243B2 (en) 2018-04-25 2021-06-15 Ubs Business Solutions Ag Dynamic dissemination of information to network devices
US11037241B2 (en) * 2018-04-25 2021-06-15 Ubs Business Solutions Ag Dynamic dissemination of information to network devices
US10511520B1 (en) * 2018-05-29 2019-12-17 Ripple Labs Inc. Multi-hop path finding
US10795974B2 (en) * 2018-05-31 2020-10-06 Microsoft Technology Licensing, Llc Memory assignment for guest operating systems
US11184288B2 (en) 2019-01-11 2021-11-23 Arista Networks, Inc. System and a method for controlling timing of processing network data
US20200402170A1 (en) * 2019-06-19 2020-12-24 Chicago Mercantile Exchange Inc. Deterministic Message Processing in a Distributed Network
US11734757B2 (en) 2020-04-14 2023-08-22 Banque Nationale Du Canada Computer implemented method and system for automating analysis of profit and loss (PnL) variations based on market events
US11537455B2 (en) 2021-01-11 2022-12-27 Iex Group, Inc. Schema management using an event stream
US11658918B2 (en) * 2021-05-17 2023-05-23 Juniper Networks, Inc. Latency-aware load balancer for topology-shifting software defined networks
US11893267B2 (en) 2022-01-14 2024-02-06 Bank Of America Corporation Data flow control and routing using machine learning
US11915315B1 (en) 2022-08-10 2024-02-27 Bgc Partners, L.P. Method, apparatus and system for time stamping and sequencing data items

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5820463A (en) 1996-02-06 1998-10-13 Bell Atlantic Network Services, Inc. Method and apparatus for multi-player gaming over a network
WO2008154306A1 (en) 2007-06-08 2008-12-18 Exegy Incorporated Method and system for high speed options pricing
WO2009073023A1 (en) 2007-12-03 2009-06-11 Zircon Computing Llc Parallel processing system

Family Cites Families (267)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE68927946T2 (de) 1988-08-02 1997-10-16 Philips Electronics Nv Verfahren und Vorrichtung für die Synchronisierung von parallelen Prozessoren unter Verwendung einer unscharf definierten Sperre
US5179702A (en) 1989-12-29 1993-01-12 Supercomputer Systems Limited Partnership System and method for controlling a highly parallel multiprocessor using an anarchy based scheduler for parallel execution thread scheduling
US5339415A (en) 1990-06-11 1994-08-16 Cray Research, Inc. Dual level scheduling of processes to multiple parallel regions of a multi-threaded program on a tightly coupled multiprocessor computer system
JPH0448350A (ja) * 1990-06-18 1992-02-18 Toshiba Corp データベース管理システム
JP3285629B2 (ja) 1992-12-18 2002-05-27 富士通株式会社 同期処理方法及び同期処理装置
CA2123447C (en) 1993-09-20 1999-02-16 Richard L. Arndt Scalable system interrupt structure for a multiprocessing system
KR960003444A (ko) * 1994-06-01 1996-01-26 제임스 디. 튜턴 차량 감시 시스템
US5768594A (en) * 1995-07-14 1998-06-16 Lucent Technologies Inc. Methods and means for scheduling parallel processors
JP3417741B2 (ja) 1995-10-06 2003-06-16 富士通株式会社 取引制御システム
US5887143A (en) 1995-10-26 1999-03-23 Hitachi, Ltd. Apparatus and method for synchronizing execution of programs in a distributed real-time computing system
US5896523A (en) 1997-06-04 1999-04-20 Marathon Technologies Corporation Loosely-coupled, synchronized execution
US6570911B1 (en) * 1997-06-27 2003-05-27 Intel Corporation Method and apparatus for controlling modem data pump parameters based on processor loading
US6490620B1 (en) * 1997-09-26 2002-12-03 Worldcom, Inc. Integrated proxy interface for web based broadband telecommunications management
US6081906A (en) * 1997-11-21 2000-06-27 Fuji Xerox Co., Ltd. Multi-thread processing with queuing and recovery
US6026497A (en) * 1997-12-23 2000-02-15 Sun Microsystems, Inc. System and method for determining the resolution of a granular clock provided by a digital computer and for using it to accurately time execution of computer program fragment by the digital computer
US6002737A (en) * 1998-06-02 1999-12-14 Adaptec, Inc. Timer using a single counter to track multiple time-outs
US20010051910A1 (en) 1998-09-25 2001-12-13 Snelgrove William Martin System and method for conducting an auction over a communications network
US6618707B1 (en) 1998-11-03 2003-09-09 International Securities Exchange, Inc. Automated exchange for trading derivative securities
US20020026321A1 (en) 1999-02-26 2002-02-28 Sadeg M. Faris Internet-based system and method for fairly and securely enabling timed-constrained competition using globally time-sychronized client subsystems and information servers having microsecond client-event resolution
US6677858B1 (en) * 1999-02-26 2004-01-13 Reveo, Inc. Internet-based method of and system for monitoring space-time coordinate information and biophysiological state information collected from an animate object along a course through the space-time continuum
JP2000293424A (ja) * 1999-04-09 2000-10-20 Hitachi Ltd ネットワークキャッシュ装置およびキャッシュ制御方法
JP3557947B2 (ja) 1999-05-24 2004-08-25 日本電気株式会社 複数のプロセッサで同時にスレッドの実行を開始させる方法及びその装置並びにコンピュータ可読記録媒体
US7277861B1 (en) 1999-08-27 2007-10-02 Westport Insurance Corporation Insurance policy renewal method and system
US6578068B1 (en) 1999-08-31 2003-06-10 Accenture Llp Load balancer in environment services patterns
US6810411B1 (en) * 1999-09-13 2004-10-26 Intel Corporation Method and system for selecting a host in a communications network
US7630986B1 (en) * 1999-10-27 2009-12-08 Pinpoint, Incorporated Secure data interchange
US6493341B1 (en) 1999-12-31 2002-12-10 Ragula Systems Combining routers to increase concurrency and redundancy in external network access
US6295276B1 (en) 1999-12-31 2001-09-25 Ragula Systems Combining routers to increase concurrency and redundancy in external network access
US7454457B1 (en) * 2000-02-07 2008-11-18 Parallel Networks, Llc Method and apparatus for dynamic data flow control using prioritization of data requests
US7707245B2 (en) 2000-02-22 2010-04-27 Harvey Lunenfeld Metasearching a client's request for displaying different order books on the client
US6871341B1 (en) 2000-03-24 2005-03-22 Intel Corporation Adaptive scheduling of function cells in dynamic reconfigurable logic
US7650376B1 (en) * 2000-03-27 2010-01-19 Blumenau Trevor I Content distribution system for distributing content over a network, with particular applicability to distributing high-bandwidth content
US20020038228A1 (en) * 2000-03-28 2002-03-28 Waldorf Jerry A. Systems and methods for analyzing business processes
US6789125B1 (en) 2000-05-10 2004-09-07 Cisco Technology, Inc. Distributed network traffic load balancing technique implemented without gateway router
US6742044B1 (en) 2000-05-10 2004-05-25 Cisco Technology, Inc. Distributed network traffic load balancing technique implemented without gateway router
US9183351B2 (en) * 2000-05-30 2015-11-10 Vladimir Shusterman Mobile system with network-distributed data processing for biomedical applications
US7680715B2 (en) * 2000-06-01 2010-03-16 Pipeline Financial Group, Inc. Systems and methods for providing anonymous requests for quotes for financial instruments
US8380630B2 (en) * 2000-07-06 2013-02-19 David Paul Felsher Information record infrastructure, system and method
US6829589B1 (en) 2000-07-21 2004-12-07 Stc, Llc Method and apparatus for stock and index option price improvement, participation, and internalization
US7219158B2 (en) * 2000-07-21 2007-05-15 Hughes Network Systems Llc Method and system for improving network performance using a performance enhancing proxy
US7031945B1 (en) * 2000-07-24 2006-04-18 Donner Irah H System and method for reallocating and/or upgrading and/or rewarding tickets, other event admittance means, goods and/or services
US6856970B1 (en) * 2000-09-26 2005-02-15 Bottomline Technologies Electronic financial transaction system
US7478058B2 (en) 2000-11-15 2009-01-13 Spc Holdings Pty Limited Collaborative commerce hub
US7184984B2 (en) * 2000-11-17 2007-02-27 Valaquenta Intellectual Properties Limited Global electronic trading system
US7051330B1 (en) 2000-11-21 2006-05-23 Microsoft Corporation Generic application server and method of operation therefor
US6809733B2 (en) 2000-11-27 2004-10-26 Silicon Graphics, Inc. Swap buffer synchronization in a distributed rendering system
US20030177187A1 (en) 2000-11-27 2003-09-18 Butterfly.Net. Inc. Computing grid for massively multi-player online games and other multi-user immersive persistent-state and session-based applications
US7937470B2 (en) * 2000-12-21 2011-05-03 Oracle International Corp. Methods of determining communications protocol latency
GB2377784B (en) * 2001-02-12 2003-11-05 Altio Ltd A presentation server which enables a client device to run a network based application
WO2002069174A1 (fr) 2001-02-28 2002-09-06 Fujitsu Limited Procede d'execution en parallele de processus et ordinateur a processeurs multiples
US7181017B1 (en) * 2001-03-23 2007-02-20 David Felsher System and method for secure three-party communications
US7117504B2 (en) * 2001-07-10 2006-10-03 Microsoft Corporation Application program interface that enables communication for a network software platform
JP3702813B2 (ja) 2001-07-12 2005-10-05 日本電気株式会社 マルチスレッド実行方法及び並列プロセッサシステム
US7318083B2 (en) * 2001-08-27 2008-01-08 Ricoh Company, Ltd. Information processing system
JP3815278B2 (ja) * 2001-08-30 2006-08-30 ソニー株式会社 ネットワークゲームシステム、ネットワークゲームサーバ装置、ネットワークゲーム端末装置、情報処理方法、及び情報処理プログラム
US8473922B2 (en) * 2001-09-19 2013-06-25 Hewlett-Packard Development Company, L.P. Runtime monitoring in component-based systems
EP1504385A4 (en) * 2001-12-05 2008-12-03 Xchange Advantage Inc E METHOD AND SYSTEM FOR MANAGING DISTRIBUTED TRADING DATA
WO2003069848A1 (en) * 2002-01-22 2003-08-21 Siemens Medical Solutions Health Services Corporation System for estimating network traffic characteristics of executable software applications
JP4170227B2 (ja) * 2002-01-24 2008-10-22 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ 多重処理環境における処理の実行
US7171479B2 (en) * 2002-04-26 2007-01-30 International Business Machines Corporation Efficient delivery of boot code images from a network server
US7114171B2 (en) 2002-05-14 2006-09-26 Thales Avionics, Inc. Method for controlling an in-flight entertainment system
AU2003237831A1 (en) 2002-05-14 2003-12-02 Bank Of New York Commission management system
US7747729B2 (en) * 2002-06-14 2010-06-29 Hanoch Levy Determining client latencies over a network
US6721765B2 (en) * 2002-07-02 2004-04-13 Sybase, Inc. Database system with improved methods for asynchronous logging of transactions
EP1391820A3 (en) 2002-07-31 2007-12-19 Texas Instruments Incorporated Concurrent task execution in a multi-processor, single operating system environment
EP1414187A1 (en) 2002-10-22 2004-04-28 Alcatel Method for evaluating the quality of service of a telecommunication link via a network
US7778896B2 (en) 2002-12-03 2010-08-17 Bny Convergex Group Llc Systems and methods for direct electronic trading of depositary receipts
US9032465B2 (en) * 2002-12-10 2015-05-12 Ol2, Inc. Method for multicasting views of real-time streaming interactive video
US7552445B2 (en) * 2002-12-13 2009-06-23 Savvis Communications Corporation Systems and methods for monitoring events from multiple brokers
JP3747908B2 (ja) 2002-12-13 2006-02-22 ソニー株式会社 カメラ制御システム、カメラサーバ及びその制御方法
US9818136B1 (en) * 2003-02-05 2017-11-14 Steven M. Hoffberg System and method for determining contingent relevance
US7290168B1 (en) * 2003-02-28 2007-10-30 Sun Microsystems, Inc. Systems and methods for providing a multi-path network switch system
US7178112B1 (en) * 2003-04-16 2007-02-13 The Mathworks, Inc. Management of functions for block diagrams
JP4131514B2 (ja) 2003-04-21 2008-08-13 インターナショナル・ビジネス・マシーンズ・コーポレーション ネットワークシステム、サーバ、データ処理方法及びプログラム
US20040267897A1 (en) * 2003-06-24 2004-12-30 Sychron Inc. Distributed System Providing Scalable Methodology for Real-Time Control of Server Pools and Data Centers
JP4028444B2 (ja) 2003-06-27 2007-12-26 株式会社東芝 スケジューリング方法およびリアルタイム処理システム
CN1515472A (zh) 2003-08-26 2004-07-28 王金水 一种保温食品容器
US7373548B2 (en) * 2003-08-29 2008-05-13 Intel Corporation Hardware recovery in a multi-threaded architecture
US10127765B1 (en) * 2003-10-20 2018-11-13 Tipping Point Group, Llc Gaming machine having secondary gaming controller with proxy configuration
US8655755B2 (en) * 2003-10-22 2014-02-18 Scottrade, Inc. System and method for the automated brokerage of financial instruments
US7447775B1 (en) * 2003-11-07 2008-11-04 Cisco Technology, Inc. Methods and apparatus for supporting transmission of streaming data
US7752559B1 (en) * 2003-12-05 2010-07-06 The Mathworks, Inc. Graphical model preparation for embedded deployment
US20050125329A1 (en) * 2003-12-09 2005-06-09 Nucenz Technologies, Inc. Systems and methods for processing multiple contingent transactions
US7774172B1 (en) * 2003-12-10 2010-08-10 The Mathworks, Inc. Method for using a graphical debugging tool
US7502912B2 (en) * 2003-12-30 2009-03-10 Intel Corporation Method and apparatus for rescheduling operations in a processor
US7269758B2 (en) * 2004-01-20 2007-09-11 International Business Machines Corporation Method and system for identifying runaway software agents
US7899179B2 (en) * 2004-01-20 2011-03-01 International Business Machines Corporation Method for monitoring off-schedule software agents
US7802015B2 (en) * 2004-01-26 2010-09-21 Tantalus Systems Corp. Communications system of heterogeneous elements
EP1770614A4 (en) 2004-04-27 2009-01-21 Bitwallet Inc PAYMENT TERMINAL MANAGEMENT SERVER, PAYMENT TERMINAL MANAGEMENT METHOD, PAYMENT TERMINAL, CALCULATION INSTRUCTION ENTRY DEVICE, AND PRICE CHANGE INFORMATION ENTRY DEVICE
US20060047591A1 (en) 2004-08-26 2006-03-02 Snouffer Bradley D Method of capitalizing a distributed business entity and allocating profits thereof
US7890735B2 (en) * 2004-08-30 2011-02-15 Texas Instruments Incorporated Multi-threading processors, integrated circuit devices, systems, and processes of operation and manufacture
US7590589B2 (en) * 2004-09-10 2009-09-15 Hoffberg Steven M Game theoretic prioritization scheme for mobile ad hoc networks permitting hierarchal deference
US7818236B2 (en) 2004-09-13 2010-10-19 Nyfix, Inc. System for aggregating executions in a communication network for securities transactions and the like
US7590942B2 (en) * 2004-09-16 2009-09-15 Novatech Llc System, method and computer program product for documenting and managing execution of procedures in a graphical interface environment
US8230426B2 (en) 2004-10-06 2012-07-24 Digipede Technologies, Llc Multicore distributed processing system using selection of available workunits based on the comparison of concurrency attributes with the parallel processing characteristics
US20060075408A1 (en) 2004-10-06 2006-04-06 Digipede Technologies, Llc Distributed object execution system
US8145908B1 (en) * 2004-10-29 2012-03-27 Akamai Technologies, Inc. Web content defacement protection system
US7634430B2 (en) * 2004-12-06 2009-12-15 Hewlett-Packard Development Company, L.P. System and method for allocating resources in a distributed computational system using proportional share auctions
US8140423B2 (en) 2004-12-10 2012-03-20 Nyfix, Inc. Controlling an order slicer for trading a financial instrument
US7487125B2 (en) 2005-01-14 2009-02-03 Littlewood Margaret G Method for providing aggregation of trading on multiple alternative trading systems
US7788163B2 (en) 2005-03-11 2010-08-31 Chicago Mercantile Exchange Inc. System and method of utilizing a distributed order book in an electronic trade match engine
US20060218071A1 (en) 2005-03-28 2006-09-28 Espeed, Inc. System and method for managing trading between related entities
JP4514648B2 (ja) * 2005-05-18 2010-07-28 富士通株式会社 管理サーバによる情報処理方法及びルータ
US8566213B2 (en) * 2005-05-20 2013-10-22 Bgc Partners, Inc. System and method for automatically distributing a trading order over a range of prices
US7805706B1 (en) * 2005-06-21 2010-09-28 Unisys Corporation Process for optimizing software components for an enterprise resource planning (ERP) application SAP on multiprocessor servers
JP4979206B2 (ja) * 2005-07-06 2012-07-18 株式会社ソニー・コンピュータエンタテインメント 情報処理方法および情報処理装置
US20080037532A1 (en) * 2005-08-20 2008-02-14 Sykes Edward A Managing service levels on a shared network
US9058406B2 (en) 2005-09-14 2015-06-16 Millennial Media, Inc. Management of multiple advertising inventories using a monetization platform
US7693873B2 (en) 2005-10-13 2010-04-06 International Business Machines Corporation System, method and program to synchronize files in distributed computer system
US7720662B1 (en) * 2005-12-02 2010-05-18 The Mathworks, Inc. Visual representation of model execution results contributing to a failure condition in a model
US9081609B2 (en) * 2005-12-21 2015-07-14 Xerox Corporation Image processing system and method employing a threaded scheduler
US20070156786A1 (en) 2005-12-22 2007-07-05 International Business Machines Corporation Method and apparatus for managing event logs for processes in a digital data processing system
AR059552A1 (es) 2006-02-17 2008-04-09 Directv Group Inc Agrupamiento de datos de usuario en relacion con datos geograficos
US8037119B1 (en) 2006-02-21 2011-10-11 Nvidia Corporation Multipurpose functional unit with single-precision and double-precision operations
JP2007241394A (ja) 2006-03-06 2007-09-20 Mitsubishi Electric Corp 分割処理管理装置及び分割処理管理システム及び演算処理実行システム及び分割処理管理方法
US8190682B2 (en) * 2006-03-31 2012-05-29 Amazon Technologies, Inc. Managing execution of programs by multiple computing systems
US8307119B2 (en) * 2006-03-31 2012-11-06 Google Inc. Collaborative online spreadsheet application
US8862680B2 (en) 2006-05-01 2014-10-14 The Boeing Company Methods and systems for data prioritization
US7755621B2 (en) * 2006-06-16 2010-07-13 Autodesk, Inc. Fast interactive object manipulation
US7921046B2 (en) 2006-06-19 2011-04-05 Exegy Incorporated High speed processing of financial information using FPGA devices
GB0613275D0 (en) * 2006-07-04 2006-08-16 Codeplay Software Ltd Distributed computer system
US7822728B1 (en) * 2006-11-08 2010-10-26 Emc Corporation Metadata pipelining and optimization in a file server
EP1936907A1 (en) 2006-12-12 2008-06-25 The Sporting Exchange Ltd. Transaction processing system
US7716118B2 (en) 2007-01-16 2010-05-11 Peter Bartko System and method for providing latency protection for trading orders
US20080294332A1 (en) 2007-01-17 2008-11-27 3-D-V-U Israel (2000) Ltd. Method for Image Based Navigation Route Corridor For 3D View on Mobile Platforms for Mobile Users
US7970891B1 (en) 2007-01-17 2011-06-28 Google Inc. Tracking links in web browsers
US8706849B1 (en) * 2007-02-09 2014-04-22 Crimson Corporation Systems and methods for increasing the scalability in a client/server environment
US8301790B2 (en) * 2007-05-30 2012-10-30 Randy Morrison Synchronization of audio and video signals from remote sources over the internet
US7840481B2 (en) 2007-06-07 2010-11-23 Bny Convergex Execution Solutions Llc Aged transactions in a trading system
EP2192483B1 (en) * 2007-06-20 2016-04-20 Fujitsu Limited Processing device
US8347292B2 (en) 2007-08-30 2013-01-01 International Business Machines Corporation Transaction aggregation to increase transaction processing throughout
JP5122890B2 (ja) 2007-09-06 2013-01-16 株式会社日立製作所 通信システム及びその装置
US8326970B2 (en) * 2007-11-05 2012-12-04 Hewlett-Packard Development Company, L.P. System and method for modeling a session-based system with a transaction-based analytic model
US8621475B2 (en) * 2007-12-06 2013-12-31 International Business Machines Corporation Responsive task scheduling in cooperative multi-tasking environments
US8583515B2 (en) * 2007-12-21 2013-11-12 Metabank Transfer account systems, computer program products, and associated computer-implemented methods
US9060208B2 (en) * 2008-01-30 2015-06-16 Time Warner Cable Enterprises Llc Methods and apparatus for predictive delivery of content over a network
US8918541B2 (en) * 2008-02-22 2014-12-23 Randy Morrison Synchronization of audio and video signals from remote sources over the internet
CN101256660A (zh) * 2008-04-02 2008-09-03 刘波涌 一种基于gps技术的交互系统和交互方法
US7979344B2 (en) 2008-05-23 2011-07-12 Bny Convergex Group, Llc Systems, methods, and media for automatically controlling trade executions based on percentage of volume trading rates
US8473469B1 (en) * 2008-08-25 2013-06-25 Salesforce.Com, Inc. Techniques for implementing batch processing in a multi-tenant on-demand database system
US8291252B2 (en) 2008-08-27 2012-10-16 Igt Power management in a multi-station gaming machine
US8127001B1 (en) * 2008-10-06 2012-02-28 Rockstar Bidco, LP Method and system for selecting providers for role based services
US8869256B2 (en) 2008-10-21 2014-10-21 Yahoo! Inc. Network aggregator
US8380551B2 (en) * 2008-11-05 2013-02-19 The Boeing Company Method and system for processing work requests
CA3184014A1 (en) 2008-12-15 2010-07-08 Exegy Incorporated Method and apparatus for high-speed processing of financial market depth data
US8270594B2 (en) 2009-01-08 2012-09-18 Soundbite Communications, Inc. Method and system for managing interactive communications campaign with reduced customer-to-agent connection latency
US8352956B1 (en) * 2009-02-02 2013-01-08 Juniper Networks, Inc. Calculating an estimated time remaining for completion of a multi-phased and multi-threaded process
US8392314B1 (en) * 2009-02-02 2013-03-05 Marketaxess Holdings, Inc. Methods and systems for computer-based incremental trading
US20100332373A1 (en) 2009-02-26 2010-12-30 Jason Crabtree System and method for participation in energy-related markets
US8868497B2 (en) 2009-06-12 2014-10-21 Sap Ag Correlation aware synchronization for near real-time decision support
US8103769B1 (en) * 2009-09-03 2012-01-24 Amazon Technologies, Inc. Dynamic isolation of shared resources
US9804943B2 (en) * 2009-10-16 2017-10-31 Sap Se Estimating service resource consumption based on response time
SG181616A1 (en) 2009-12-10 2012-07-30 Royal Bank Of Canada Synchronized processing of data by networked computing resources
US10771536B2 (en) * 2009-12-10 2020-09-08 Royal Bank Of Canada Coordinated processing of data by networked computing resources
US9081501B2 (en) * 2010-01-08 2015-07-14 International Business Machines Corporation Multi-petascale highly efficient parallel supercomputer
US8484661B2 (en) * 2010-03-19 2013-07-09 At&T Mobility Ii Llc Agnostic execution cluster for an agnostic execution environment
US8358765B1 (en) 2010-03-31 2013-01-22 Cox Communications, Inc. System for simultaneous delivery of communication session invitation messages to communication devices
US8315940B2 (en) 2010-04-27 2012-11-20 Omx Technology Ab System and method for rapidly calculating risk in an electronic trading exchange
US20110289141A1 (en) * 2010-05-20 2011-11-24 Salesforce.Com, Inc. Methods and systems for providing a user interface in a multi-tenant database environment
WO2011146898A2 (en) * 2010-05-21 2011-11-24 Bologh Mark J Internet system for ultra high video quality
US8635133B2 (en) 2010-05-28 2014-01-21 Massachusetts Institute Of Technology System and method for relativistic statistical securities trading
JP5458308B2 (ja) * 2010-06-11 2014-04-02 株式会社日立製作所 仮想計算機システム、仮想計算機システムの監視方法及びネットワーク装置
WO2012008915A1 (en) 2010-07-13 2012-01-19 M-Daq Pte Ltd Method and system of trading a security in a foreign currency
US8738798B2 (en) 2010-08-06 2014-05-27 Acquire Media Ventures, Inc. Method and system for pacing, ack'ing, timing, and handicapping (PATH) for simultaneous receipt of documents
US8527440B2 (en) * 2010-10-12 2013-09-03 Sap Ag System and apparatus for performing consistency maintenance of distributed graph structures that compares changes to identify a conflicting operation
US8336051B2 (en) * 2010-11-04 2012-12-18 Electron Database Corporation Systems and methods for grouped request execution
US8843545B2 (en) 2010-11-30 2014-09-23 Telefonaktiebolaget L M Ericsson (Publ) Supervision timer control mechanisms
US10037568B2 (en) * 2010-12-09 2018-07-31 Ip Reservoir, Llc Method and apparatus for managing orders in financial markets
US8543868B2 (en) * 2010-12-21 2013-09-24 Guest Tek Interactive Entertainment Ltd. Distributed computing system that monitors client device request time and server servicing time in order to detect performance problems and automatically issue alerts
KR101803303B1 (ko) * 2010-12-21 2017-12-29 삼성전자주식회사 멀티미디어 아키텍처 패턴 결정 방법, 싱글코어에서 멀티코어 기반으로의 아키텍처 전환 장치 및 방법
CN103392314B (zh) 2010-12-29 2016-06-15 思杰系统有限公司 用于可扩展的n核统计信息聚合的系统和方法
US20120221546A1 (en) 2011-02-24 2012-08-30 Rafsky Lawrence C Method and system for facilitating web content aggregation initiated by a client or server
US8832219B2 (en) * 2011-03-01 2014-09-09 Red Hat, Inc. Generating optimized resource consumption periods for multiple users on combined basis
US8838584B2 (en) 2011-03-29 2014-09-16 Acquire Media Ventures, Inc. Method for selecting a subset of content sources from a collection of content sources
US8667019B2 (en) * 2011-04-01 2014-03-04 Microsoft Corporation Placement goal-based database instance consolidation
US8824687B2 (en) 2011-05-04 2014-09-02 Acquire Media Ventures, Inc. Method and system for pacing, acking, timing, and handicapping (path) for simultaneous receipt of documents employing encryption
US8407284B2 (en) * 2011-05-27 2013-03-26 Red Hat, Inc. Systems and methods for cloud data deployment based on preferential and/or existing subscription relationships
US20130027561A1 (en) 2011-07-29 2013-01-31 Panasonic Corporation System and method for improving site operations by detecting abnormalities
US8909996B2 (en) * 2011-08-12 2014-12-09 Oracle International Corporation Utilizing multiple storage devices to reduce write latency for database logging
US8930489B2 (en) * 2011-10-11 2015-01-06 Rakspace US, Inc. Distributed rate limiting of handling requests
US9300548B2 (en) * 2011-10-14 2016-03-29 Alcatel Lucent Providing dynamic reliability and security in communications environments
US9154984B1 (en) * 2011-11-15 2015-10-06 Google Inc. System and method for estimating network performance
US9503510B2 (en) 2012-03-10 2016-11-22 Headwater Partners Ii Llc Content distribution based on a value metric
US9210217B2 (en) 2012-03-10 2015-12-08 Headwater Partners Ii Llc Content broker that offers preloading opportunities
US8891364B2 (en) * 2012-06-15 2014-11-18 Citrix Systems, Inc. Systems and methods for distributing traffic across cluster nodes
US9467383B2 (en) * 2012-06-19 2016-10-11 Hewlett Packard Enterprise Development Lp Iterative optimization method for site selection in global load balance
US8745267B2 (en) 2012-08-19 2014-06-03 Box, Inc. Enhancement of upload and/or download performance based on client and/or server feedback information
KR101963321B1 (ko) 2012-09-12 2019-03-28 아이이엑스 그룹, 인크. 전송 레이턴시 평준화 장치, 방법 및 시스템
WO2014089673A1 (en) 2012-12-11 2014-06-19 Joseph Schmitt System and method for automated trading of financial interests
US9628345B2 (en) * 2012-12-13 2017-04-18 Level 3 Communications, Llc Framework supporting content delivery with collector services network
US9128781B2 (en) * 2012-12-28 2015-09-08 Intel Corporation Processor with memory race recorder to record thread interleavings in multi-threaded software
US9679104B2 (en) 2013-01-17 2017-06-13 Edico Genome, Corp. Bioinformatics systems, apparatuses, and methods executed on an integrated circuit processing platform
US9734535B2 (en) 2013-03-15 2017-08-15 Trading Technologies International, Inc. Charting multiple markets
US20140310392A1 (en) * 2013-04-10 2014-10-16 Lap-Wah Lawrence Ho Method and apparatus for processing composite web transactions
US9208032B1 (en) * 2013-05-15 2015-12-08 Amazon Technologies, Inc. Managing contingency capacity of pooled resources in multiple availability zones
EP2936420A4 (en) 2013-06-24 2016-08-03 Aequitas Innovations Inc SYSTEM AND METHOD FOR AUTOMATED TRADING OF FINANCIAL INVESTMENTS
US20150066727A1 (en) * 2013-08-29 2015-03-05 D. E. Shaw & Co., L.P. Electronic Trading Exchange with User-Definable Order Execution Delay
US9633051B1 (en) 2013-09-20 2017-04-25 Amazon Technologies, Inc. Backup of partitioned database tables
US9552242B1 (en) * 2013-09-25 2017-01-24 Amazon Technologies, Inc. Log-structured distributed storage using a single log sequence number space
US10838926B2 (en) * 2013-10-01 2020-11-17 Sap Se Transparent access to multi-temperature data
US9691102B2 (en) * 2013-11-07 2017-06-27 Chicago Mercantile Exchange Inc. Transactionally deterministic high speed financial exchange having improved, efficiency, communication, customization, performance, access, trading opportunities, credit controls, and fault tolerance
US9560312B2 (en) * 2013-12-11 2017-01-31 Cellco Partnership Time synchronization of video and data inside a mobile device
US9032373B1 (en) * 2013-12-23 2015-05-12 International Business Machines Corporation End to end testing automation and parallel test execution
US9552582B2 (en) * 2014-03-21 2017-01-24 Ca, Inc. Controlling ecommerce authentication with non-linear analytical models
JP6248747B2 (ja) * 2014-03-28 2017-12-20 富士通株式会社 情報処理装置、制御方法および制御プログラム
JP6330456B2 (ja) * 2014-04-30 2018-05-30 富士通株式会社 相関係数算出方法、相関係数算出プログラムおよび相関係数算出装置
US20170235600A1 (en) * 2014-05-08 2017-08-17 Tsx Inc. System and method for running application processes
US10511694B2 (en) 2014-07-23 2019-12-17 Citrix Systems, Inc. Systems and methods for application specific load balancing
US10621666B2 (en) 2014-09-17 2020-04-14 Iex Group, Inc. System and method for facilitation cross orders
JP6378057B2 (ja) * 2014-11-13 2018-08-22 株式会社東芝 接続制御装置、接続制御方法、接続制御システムおよびコンピュータプログラム
US9813518B2 (en) 2014-11-20 2017-11-07 Trading Technologies International, Inc. Merging data downloads with real-time data feeds
US20160217526A1 (en) 2015-01-26 2016-07-28 Trading Technologies International Inc. Methods and Systems for the Calculation and Presentation of Time Series Study Information
US20160225085A1 (en) 2015-01-30 2016-08-04 Trading Technologies International, Inc. System and Method for Implementing a Dynamic Simulation System
KR102494427B1 (ko) 2015-02-27 2023-02-01 로얄 뱅크 오브 캐나다 네트워크 컴퓨팅 자원에 의한 데이터 프로세싱의 조정
US10579748B2 (en) * 2015-03-31 2020-03-03 Ca, Inc. Capacity planning for systems with multiprocessor boards
WO2017007705A1 (en) * 2015-07-06 2017-01-12 Shape Security, Inc. Asymmetrical challenges for web security
EP3326074B1 (en) * 2015-07-22 2023-03-15 Dynamic Network Services, Inc. Methods, systems, and apparatus for geographic location using trace routes
US10120938B2 (en) * 2015-08-01 2018-11-06 MapScallion LLC Systems and methods for automating the transmission of partitionable search results from a search engine
US20170063927A1 (en) * 2015-08-28 2017-03-02 Microsoft Technology Licensing, Llc User-Aware Datacenter Security Policies
US10185670B2 (en) * 2015-09-15 2019-01-22 Gatekeeper Ltd. System and method for securely connecting to a peripheral device
KR20170033121A (ko) * 2015-09-16 2017-03-24 삼성전자주식회사 서비스 처리 방법 및 이를 구현하는 전자 장치
US9952932B2 (en) 2015-11-02 2018-04-24 Chicago Mercantile Exchange Inc. Clustered fault tolerance systems and methods using load-based failover
US10269075B2 (en) 2016-02-02 2019-04-23 Allstate Insurance Company Subjective route risk mapping and mitigation
US10708126B2 (en) * 2016-03-18 2020-07-07 Plume Design, Inc. Cloud-based control of a Wi-Fi network
US10362109B2 (en) * 2016-03-30 2019-07-23 Task Performance Group, Inc. Cloud operating system and method
US10346428B2 (en) * 2016-04-08 2019-07-09 Chicago Mercantile Exchange Inc. Bilateral assertion model and ledger implementation thereof
US10437798B2 (en) 2016-07-19 2019-10-08 Sap Se Full system simulator and memory-aware splay tree for in-memory databases in hybrid memory systems
US10083183B2 (en) 2016-07-19 2018-09-25 Sap Se Full system simulator and memory-aware splay tree for in-memory databases in hybrid memory systems
US10943297B2 (en) * 2016-08-09 2021-03-09 Chicago Mercantile Exchange Inc. Systems and methods for coordinating processing of instructions across multiple components
WO2018048355A1 (en) 2016-09-08 2018-03-15 Aiq Pte. Ltd. Object detection from visual search queries
US10509601B2 (en) * 2016-12-28 2019-12-17 Amazon Technologies, Inc. Data storage system with multi-tier control plane
US10771550B2 (en) * 2016-12-28 2020-09-08 Amazon Technologies, Inc. Data storage system with redundant internal networks
US10484015B2 (en) * 2016-12-28 2019-11-19 Amazon Technologies, Inc. Data storage system with enforced fencing
US11010064B2 (en) * 2017-02-15 2021-05-18 Amazon Technologies, Inc. Data system with flush views
US11032350B2 (en) * 2017-03-15 2021-06-08 Commvault Systems, Inc. Remote commands framework to control clients
US20180337841A1 (en) * 2017-05-19 2018-11-22 Microsoft Technology Licensing, Llc Enhanced component latency tracking
US20180357661A1 (en) * 2017-06-13 2018-12-13 Facebook, Inc. Generating analytics for a content item presented to individuals by one or more content publishers based on attributes extrapolated from online system users
US11233905B1 (en) * 2017-07-06 2022-01-25 United Services Automobile Association (Usaa) Call center load balancing and routing management
US10306068B1 (en) * 2017-07-06 2019-05-28 United Services Automobile Association (Usaa) Call center load balancing and routing management
US10212043B1 (en) * 2017-07-26 2019-02-19 Citrix Systems, Inc. Proactive link load balancing to maintain quality of link
US11258682B2 (en) 2017-08-03 2022-02-22 Chicago Mercantile Exchange Inc. Compressed message tracing and parsing
US10972358B2 (en) * 2017-08-30 2021-04-06 Citrix Systems, Inc. Inferring congestion and signal quality
US10803042B2 (en) 2017-10-06 2020-10-13 Chicago Mercantile Exchange Inc. Database indexing in performance measurement systems
US10416974B2 (en) 2017-10-06 2019-09-17 Chicago Mercantile Exchange Inc. Dynamic tracer message logging based on bottleneck detection
US10740832B2 (en) * 2017-11-16 2020-08-11 Coupa Software Incorporated Computer-implemented method and systems for using transaction data to generate optimized event templates based on a requested event type
US10452436B2 (en) * 2018-01-03 2019-10-22 Cisco Technology, Inc. System and method for scheduling workload based on a credit-based mechanism
US10705849B2 (en) 2018-02-05 2020-07-07 The Regents Of The University Of Michigan Mode-selectable processor for execution of a single thread in a first mode and plural borrowed threads in a second mode
US10783060B2 (en) * 2018-05-02 2020-09-22 Servicenow, Inc. Post-upgrade debugging in a remote network management platform
US11243777B2 (en) * 2018-05-18 2022-02-08 Nuxeo Corporation Process stream replication for content management system synchronization
EP3802878A1 (en) 2018-06-04 2021-04-14 Guardant Health, Inc. Methods and systems for determining the cellular origin of cell-free nucleic acids
US10972387B2 (en) * 2018-06-16 2021-04-06 Versa Networks, Inc. Application performance based path-selection using dynamic metrics
US10855749B2 (en) * 2018-07-03 2020-12-01 Wandisco Inc. Methods, devices and systems for a distributed coordination engine-based exchange that implements a blockchain distributed ledger
US20180345129A1 (en) * 2018-07-27 2018-12-06 Yogesh Rathod Display virtual objects within predefined geofence or receiving of unique code from closest beacon
US10673708B2 (en) * 2018-10-12 2020-06-02 International Business Machines Corporation Auto tuner for cloud micro services embeddings
US11303543B2 (en) * 2018-11-15 2022-04-12 Citrix Systems, Inc. Real-time scalable virtual session and network analytics
US11017778B1 (en) * 2018-12-04 2021-05-25 Sorenson Ip Holdings, Llc Switching between speech recognition systems
US11170761B2 (en) * 2018-12-04 2021-11-09 Sorenson Ip Holdings, Llc Training of speech recognition systems
US10846194B1 (en) 2019-05-02 2020-11-24 More Cowbell Unlimited, Inc Methods and systems for estimating process capacity
US10992585B1 (en) 2019-05-09 2021-04-27 Amazon Technologies, Inc. Unified network traffic controllers for multi-service environments
US20200366573A1 (en) * 2019-05-17 2020-11-19 Citrix Systems, Inc. Systems and methods for visualizing dependency experiments
US11416362B2 (en) * 2019-05-17 2022-08-16 Citrix Systems, Inc. Dependency API controlled experiment dashboard
US11169723B2 (en) * 2019-06-28 2021-11-09 Amazon Technologies, Inc. Data storage system with metadata check-pointing
WO2021025430A1 (ko) * 2019-08-07 2021-02-11 엘지전자 주식회사 Ims 시그널링
US11963247B2 (en) * 2019-11-07 2024-04-16 Qualcomm Incorporated Handling slice limitations
US11983528B2 (en) * 2021-02-17 2024-05-14 Infosys Limited System and method for automated simulation of releases in agile environments
US20230123573A1 (en) * 2021-10-18 2023-04-20 Oracle International Corporation Automatic detection of seasonal pattern instances and corresponding parameters in multi-seasonal time series
US11637753B1 (en) * 2021-10-29 2023-04-25 Juniper Networks, Inc. Adaptive location-based SD-WAN policies

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5820463A (en) 1996-02-06 1998-10-13 Bell Atlantic Network Services, Inc. Method and apparatus for multi-player gaming over a network
WO2008154306A1 (en) 2007-06-08 2008-12-18 Exegy Incorporated Method and system for high speed options pricing
WO2009073023A1 (en) 2007-12-03 2009-06-11 Zircon Computing Llc Parallel processing system

Also Published As

Publication number Publication date
JP2015092353A (ja) 2015-05-14
AU2016200212B2 (en) 2018-03-01
SG10201704581VA (en) 2017-07-28
US20230410200A1 (en) 2023-12-21
MX337624B (es) 2016-03-11
SG181616A1 (en) 2012-07-30
CN105978756A (zh) 2016-09-28
AU2023200177A1 (en) 2023-02-16
CA2707196C (en) 2016-11-01
US11776054B2 (en) 2023-10-03
KR20120101535A (ko) 2012-09-13
JP5785556B2 (ja) 2015-09-30
US20170039648A1 (en) 2017-02-09
US20130304626A1 (en) 2013-11-14
CA2927532A1 (en) 2011-01-11
EP2510451B1 (en) 2019-08-28
AU2018274909A1 (en) 2019-01-03
US11308555B2 (en) 2022-04-19
US10650450B2 (en) 2020-05-12
CN102859938B (zh) 2016-07-06
CN102859938A (zh) 2013-01-02
CA2927607C (en) 2021-04-06
AU2021200879A1 (en) 2021-03-04
US20120042080A1 (en) 2012-02-16
CA2927607A1 (en) 2011-01-11
US8984137B2 (en) 2015-03-17
WO2011069234A1 (en) 2011-06-16
BR112012013891A2 (pt) 2016-05-03
CN105978756B (zh) 2019-08-16
CA2707196A1 (en) 2011-01-11
EP2510451A4 (en) 2015-11-18
BR112012013891B1 (pt) 2020-12-08
US20220237697A1 (en) 2022-07-28
AU2016231624A1 (en) 2016-10-20
JP2013513171A (ja) 2013-04-18
US20160260173A1 (en) 2016-09-08
US20100332650A1 (en) 2010-12-30
US20200302536A1 (en) 2020-09-24
EP2510451A1 (en) 2012-10-17
US10706469B2 (en) 2020-07-07
CA3109739A1 (en) 2011-01-11
AU2021200879B2 (en) 2023-02-02
US8489747B2 (en) 2013-07-16
ES2754099T3 (es) 2020-04-15
AU2018274909B2 (en) 2020-11-12
ZA201309197B (en) 2016-02-24
AU2010330629B2 (en) 2015-11-05
AU2010330629A1 (en) 2012-02-23
ZA201205093B (en) 2014-02-26
MX2012006659A (es) 2013-01-22
AU2016200212A1 (en) 2016-02-04
CA2927532C (en) 2016-08-09

Similar Documents

Publication Publication Date Title
KR101667697B1 (ko) 네트워크 컴퓨팅 자원에 의한 데이터 동기화 프로세싱
US11635999B2 (en) Conservation of electronic communications resources and computing resources via selective processing of substantially continuously updated data

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant