KR20240070238A - Synchronous communication system and method between multiple images and data - Google Patents

Synchronous communication system and method between multiple images and data Download PDF

Info

Publication number
KR20240070238A
KR20240070238A KR1020220151823A KR20220151823A KR20240070238A KR 20240070238 A KR20240070238 A KR 20240070238A KR 1020220151823 A KR1020220151823 A KR 1020220151823A KR 20220151823 A KR20220151823 A KR 20220151823A KR 20240070238 A KR20240070238 A KR 20240070238A
Authority
KR
South Korea
Prior art keywords
data
communication
packet
client device
video
Prior art date
Application number
KR1020220151823A
Other languages
Korean (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 주식회사 인포웍스
Priority to KR1020220151823A priority Critical patent/KR20240070238A/en
Publication of KR20240070238A publication Critical patent/KR20240070238A/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/4302Content synchronisation processes, e.g. decoder synchronisation
    • H04N21/4307Synchronising the rendering of multiple content streams or additional data on devices, e.g. synchronisation of audio on a mobile phone with the video output on the TV screen
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/236Assembling of a multiplex stream, e.g. transport stream, by combining a video stream with other content or additional data, e.g. inserting a URL [Uniform Resource Locator] into a video stream, multiplexing software data into a video stream; Remultiplexing of multiplex streams; Insertion of stuffing bits into the multiplex stream, e.g. to obtain a constant bit-rate; Assembling of a packetised elementary stream
    • H04N21/23605Creation or processing of packetized elementary streams [PES]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/236Assembling of a multiplex stream, e.g. transport stream, by combining a video stream with other content or additional data, e.g. inserting a URL [Uniform Resource Locator] into a video stream, multiplexing software data into a video stream; Remultiplexing of multiplex streams; Insertion of stuffing bits into the multiplex stream, e.g. to obtain a constant bit-rate; Assembling of a packetised elementary stream
    • H04N21/23614Multiplexing of additional data and video streams
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/643Communication protocols
    • H04N21/64322IP

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

본 발명은 다중 영상 및 데이터 간 동기화 송수신 시스템 및 방법에 관한 것으로, 보다 구체적으로는 TCP/IP 기반 Socket 통신이 가능한 Device(디바이스)에서 Capture한 다중 영상 데이터와 물체/객체 데이터, 센싱(Sensing) 데이터 등의 해당 영상과 관련된 다양한 정보 데이터를 동기화하여 송수신하고, 실시간으로 클라이언트별 통신 가중치를 계산해 통신 흐름을 동적으로 최적화하는 시스템 및 방법에 관한 것이다.The present invention relates to a system and method for synchronizing transmission and reception between multiple images and data, and more specifically, to multiple image data, object/object data, and sensing data captured from a device capable of TCP/IP-based socket communication. It relates to a system and method that synchronizes and transmits and receives various information data related to the video, and dynamically optimizes the communication flow by calculating communication weights for each client in real time.

Description

다중 영상 및 데이터 간 동기화 송수신 시스템 및 방법{SYNCHRONOUS COMMUNICATION SYSTEM AND METHOD BETWEEN MULTIPLE IMAGES AND DATA}System and method for synchronizing transmission and reception between multiple images and data {SYNCHRONOUS COMMUNICATION SYSTEM AND METHOD BETWEEN MULTIPLE IMAGES AND DATA}

본 발명은 다중 영상 및 데이터 간 동기화 송수신 시스템 및 방법에 관한 것으로, 보다 구체적으로는 TCP/IP 기반 Socket 통신이 가능한 Device(디바이스)에서 Capture한 다중 영상 데이터와 물체/객체 데이터, 센싱(Sensing) 데이터 등의 해당 영상과 관련된 다양한 정보 데이터를 동기화하여 송수신하고, 실시간으로 클라이언트별 통신 가중치를 계산해 통신 흐름을 동적으로 최적화하는 시스템 및 방법에 관한 것이다.The present invention relates to a system and method for synchronizing transmission and reception between multiple images and data, and more specifically, to multiple image data, object/object data, and sensing data captured from a device capable of TCP/IP-based socket communication. It relates to a system and method that synchronizes and transmits and receives various information data related to the video, and dynamically optimizes the communication flow by calculating communication weights for each client in real time.

일반적인 영상 스트리밍(Streaming)에 있어 RTSP(Real Time Streaming Protocol)는 영상을 전송하는데 최적화된 Protocol을 제공하여 우위를 점하고 있다. 그러나 상기 내용과 같이 영상 전송에만 최적화되어 있어 전송하는 영상 데이터에 다른 데이터를 함께 보낼 수 없고, 전송해야 하는 비디오 소스가 여러 개 일 때 여러 비디오 데이터를 서버에서 한 번에 동기화하여 받기 위해서는 해상도(Resolution), 초당 프레임 수 (Frames Per Second), 영상 포맷(Format) 등의 Capture Device의 성능이 모두 일치해야 하는 제약이 따른다.In general video streaming, RTSP (Real Time Streaming Protocol) has the upper hand by providing a protocol optimized for video transmission. However, as described above, it is optimized only for video transmission, so other data cannot be sent together with the video data being transmitted. When there are multiple video sources that need to be transmitted, resolution is required to synchronize and receive multiple video data from the server at once. ), the number of frames per second (Frames Per Second), and video format (Format) must all match the performance of the capture device.

일반적인 인터넷 방송과 같은 단일 비디오 데이터 서비스 외 해상도(Resolution), 초당 프레임 수 (Frames Per Second), 영상 포맷(Format) 등이 다른 여러 비디오 데이터 및 센싱(Sensing) 데이터를 동시간에 수집해야 하는 다중 비디오 데이터 서비스 개발에 있어서 기존 RTSP Protocol은 한계점이 존재할 수밖에 없다. 즉 RTSP Protocol은 공공기관 및 산업체에 동시성이 중요한 다중 비디오 데이터 전송 서비스 개발에 있어 제약이 크다는 뜻이다.In addition to single video data services such as general Internet broadcasting, multiple video data and sensing data with different resolutions, frames per second, and video formats must be collected simultaneously. In data service development, the existing RTSP Protocol inevitably has limitations. In other words, the RTSP Protocol has significant limitations in developing multiple video data transmission services where concurrency is important for public institutions and industries.

이에 상기와 같은 문제를 해결하기 위해 동시성이 보장된 다중 비디오 데이터 전송 기술을 구비한, 다중 영상 및 데이터 간 동기화 송수신 시스템 개발이 필요하다.Accordingly, in order to solve the above problems, it is necessary to develop a synchronized transmission and reception system between multiple videos and data, equipped with multi-video data transmission technology with guaranteed concurrency.

본 발명은 TCP/IP 기반 Socket 통신이 가능한 Device에서 Capture한 다중 영상 데이터와 물체/객체 데이터, 센싱(Sensing) 데이터 등의 해당 영상과 관련된 다양한 정보 데이터를 동기화하여 두 데이터 간 지연 및 오차를 최소화하여 데이터를 서버로 전송하는 다중 영상 및 데이터 간 동기화 송수신 시스템 및 방법을 제공하는데 그 목적이 있다.The present invention synchronizes multiple image data captured from a device capable of TCP/IP-based Socket communication and various information data related to the image, such as object/object data and sensing data, thereby minimizing delay and error between the two data. The purpose is to provide a synchronized transmission and reception system and method between multiple images and data that transmits data to a server.

본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템 및 동기화 방법은, 클라이언트 장치로부터 비디오 데이터, 센싱(Sensing) 데이터 및 통신 상태 데이터 중 적어도 하나 이상을 포함하는 데이터를 수신하는 통신부; 및 복수개의 상기 클라이언트 장치가 전송하는 상기 비디오 데이터와 상기 센싱(Sensing) 데이터를 동기화하여 수신하는 동기화 제어부;를 구비한다.A synchronization transmission and reception system and method between multiple images and data according to an embodiment of the present invention includes a communication unit that receives data including at least one of video data, sensing data, and communication status data from a client device; and a synchronization control unit that synchronizes and receives the video data and the sensing data transmitted by the plurality of client devices.

또한, 상기 클라이언트 장치와 상기 통신부는 TCP/IP 프로토콜 기반 정의된 통신 규격으로 통신하고, 상기 정의된 통신 규격은 비디오 패킷(Packet), 정보 패킷(Packet) 및 통신 우선순위 패킷(Packet) 중 적어도 하나 이상을 포함한다.In addition, the client device and the communication unit communicate using a defined communication standard based on the TCP/IP protocol, and the defined communication standard is at least one of a video packet (Packet), an information packet (Packet), and a communication priority packet (Packet). Includes more.

또한, 상기 비디오 데이터는, 상기 클라이언트 장치가 카메라를 통해 수집한 영상 데이터이고, 비디오 패킷(Packet)에 포함되어 전송된다.Additionally, the video data is image data collected by the client device through a camera, and is transmitted in a video packet.

또한, 상기 센싱(Sensing) 데이터는, 상기 클라이언트 장치가 센서(Sensor)를 통해 수집한 데이터이고, 정보 패킷(Packet)에 포함되어 전송된다.Additionally, the sensing data is data collected by the client device through a sensor, and is transmitted in an information packet.

또한, 상기 통신 상태 데이터는, 상기 클라이언트 장치에 설정된 클라이언트 통신 우선순위 및 상기 클라이언트 장치가 송수신한 총 패킷 수 중 적어도 하나 이상을 포함하고, 통신 우선순위 패킷(Packet)에 포함되어 전송된다.Additionally, the communication status data includes at least one of the client communication priority set in the client device and the total number of packets transmitted and received by the client device, and is transmitted in a communication priority packet.

또한, 상기 비디오 패킷, 상기 정보 패킷 및 상기 통신 우선순위 패킷은,Additionally, the video packet, the information packet, and the communication priority packet are:

송신할 패킷의 시작을 의미하고, 상기 패킷을 식별하는 패킷ID를 포함하는 START PACKET; 상기 비디오 데이터, 상기 정보 데이터 및 상기 통신 상태 데이터 중 적어도 하나를 포함하는 DATA PACKET; 상기 DATA PACKET의 크기를 포함하는 LENGTH PACKET; 및 상기 DATA PACKET을 수신할 상태인지 확인하는 CHECK PACKET;을 포함한다.START PACKET, which indicates the start of a packet to be transmitted and includes a packet ID that identifies the packet; A DATA PACKET containing at least one of the video data, the information data, and the communication status data; LENGTH PACKET including the size of the DATA PACKET; and CHECK PACKET to check whether the DATA PACKET is in a state to be received.

또한, 상기 클라이언트 장치와 상기 통신부 간의 통신은 적어도 하나 이상의 통신 사이클(Cycle)을 포함하고, 상기 통신 사이클은 적어도 하나 이상의 상기 비디오 패킷, 적어도 하나 이상의 상기 정보 패킷 및 적어도 하나 이상의 상기 통신 우선순위 패킷을 송수신하는 과정을 포함한다.Additionally, communication between the client device and the communication unit includes at least one communication cycle, and the communication cycle includes at least one of the video packets, at least one of the information packets, and at least one of the communication priority packets. It includes the process of sending and receiving.

또한, 상기 동기화 송수신 시스템은, 상기 통신 사이클을 수행하는데 걸린 시간인 1사이클완료시간, 상기 클라이언트 장치의 통신 우선순위 및 상기 통신 사이클 동안 송수신한 총 패킷 수를 사용하여 통신 가중치를 산정하는 통신 가중치 산출부를 더 포함한다.In addition, the synchronization transmission and reception system calculates the communication weight using one cycle completion time, which is the time taken to perform the communication cycle, the communication priority of the client device, and the total number of packets transmitted and received during the communication cycle. Includes more wealth.

또한, 상기 동기화 제어부는, 상기 통신 사이클이 끝날 때 마다 상기 통신 가중치를 적용하여 상기 클라이언트 장치의 통신 우선순위를 갱신하고, 상기 통신 우선순위에 따라 통신 흐름을 제어한다.Additionally, the synchronization control unit updates the communication priority of the client device by applying the communication weight each time the communication cycle ends and controls the communication flow according to the communication priority.

또한, 다중 영상 및 데이터 송수신 동기화 시스템에 의해 구현되는 다중 영상 및 데이터 간 동기화 방법에 있어서, 클라이언트 장치와 통신부 간의 통신 채널을 연결하는 통신 연결 단계; 상기 통신 채널에서 비디오 패킷을 송수신 하는 단계; 상기 통신 채널에서 정보 패킷을 송수신 하는 단계; 상기 통신 채널에서 통신 우선순위 패킷을 송수신 하는 단계; 및 통신 가중치 산출부가 상기 클라이언트 장치의 통신 가중치를 산출하여 상기 클라이언트 장치의 통신 우선순위를 갱신하는 단계;를 포함한다.In addition, a synchronization method between multiple images and data implemented by a multiple image and data transmission/reception synchronization system includes a communication connection step of connecting a communication channel between a client device and a communication unit; Transmitting and receiving video packets on the communication channel; Transmitting and receiving information packets in the communication channel; Transmitting and receiving a communication priority packet in the communication channel; and a step of a communication weight calculation unit calculating a communication weight of the client device and updating the communication priority of the client device.

데이터를 송수신한 후 데이터 동기화를 위한 별도의 처리가 불필요하여 저 성능 서버 또는 시스템에서도 동시성이 보장된 다중 영상 및 데이터 관리가 가능해진다. 즉 TCP/IP 기반 Socket 통신을 지원하는 여러 Device에서 폭넓은 사용이 가능하다.Since there is no need for separate processing for data synchronization after sending and receiving data, management of multiple images and data with guaranteed concurrency is possible even in low-performance servers or systems. In other words, it can be widely used in various devices that support TCP/IP-based socket communication.

동시성이 보장된 여러 범위에 다중 비디오 데이터와 이와 연관된 센싱(Sensing)데이터 추출 및 전송이 하나의 통신 사이클(Cycle) 내에서 가능하므로 실시간 다중 데이터 수집 시스템의 구축이 단순해진다.Extraction and transmission of multiple video data and related sensing data in multiple ranges with guaranteed concurrency is possible within one communication cycle, simplifying the construction of a real-time multiple data collection system.

서버에서 실시간으로 클라이언트별 통신 가중치를 계산해 통신 흐름을 동적으로 최적화한다. 이를 통해 다중 클라이언트 환경에서 특정 클라이언트로 데이터 송수신이 쏠리는 병목 현상과 이에 따른 데이터 지연 문제를 최소화한다.The server calculates the communication weight for each client in real time and dynamically optimizes the communication flow. This minimizes the bottleneck phenomenon in which data transmission and reception is focused on a specific client in a multi-client environment and the resulting data delay problem.

도 1은 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)의 구성도이다.
도 2는 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)에서 서버(200)의 구성도이다.
도 3은 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)에서 통신 규약을 정의한 패킷 구성도이다.
도 4는 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)에서 클라이언트 장치(100)의 통신 가중치와 통신 우선순위 산정을 도식화한 도면이다.
도 5는 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 방법을 나타낸 순서도이다.
도 6은 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 방법에서 하나의 통신 사이클(Cycle) 내에서 패킷의 송수신 흐름을 나타낸 흐름도이다.
Figure 1 is a configuration diagram of a synchronization transmission and reception system 10 between multiple images and data according to an embodiment of the present invention.
Figure 2 is a configuration diagram of the server 200 in the synchronization transmission and reception system 10 between multiple images and data according to an embodiment of the present invention.
Figure 3 is a packet configuration diagram defining a communication protocol in the synchronization transmission and reception system 10 between multiple images and data according to an embodiment of the present invention.
FIG. 4 is a diagram illustrating calculation of communication weight and communication priority of the client device 100 in the synchronized transmission and reception system 10 between multiple images and data according to an embodiment of the present invention.
Figure 5 is a flowchart showing a method for synchronizing transmission and reception between multiple images and data according to an embodiment of the present invention.
Figure 6 is a flowchart showing the flow of packet transmission and reception within one communication cycle in the synchronized transmission and reception method between multiple images and data according to an embodiment of the present invention.

이하에서는 도면을 참조하여 본 발명의 구체적인 실시예를 상세하게 설명한다. 다만, 본 발명의 사상은 제시되는 실시예에 제한되지 아니하고, 본 발명의 사상을 이해하는 당업자는 동일한 사상의 범위 내에서 다른 구성요소를 추가, 변경, 삭제 등을 통하여, 퇴보적인 다른 발명이나 본 발명 사상의 범위 내에 포함되는 다른 실시예를 용이하게 제안할 수 있을 것이나, 이 또한 본원 발명 사상 범위 내에 포함된다고 할 것이다.Hereinafter, specific embodiments of the present invention will be described in detail with reference to the drawings. However, the spirit of the present invention is not limited to the presented embodiments, and a person skilled in the art who understands the spirit of the present invention may add, change, or delete other components within the scope of the same spirit, thereby creating other degenerative inventions or the present invention. Other embodiments that are included within the scope of the invention can be easily proposed, but this will also be said to be included within the scope of the invention of the present application.

그리고, 후술되는 용어들은 본 발명에서의 기능을 고려하여 설정된 용어들로써 이는 발명자의 의도 또는 관례에 따라 달라질 수 있으므로 그 정의는 본 명세서 전반에 걸친 내용을 토대로 내려져야 할 것이고, 본 명세서에서 본 발명에 관련된 공지의 구성 또는 기능에 대한 구체적인 설명이 본 발명의 요지를 흐릴 수 있다고 판단되는 경우에 이에 관한 자세한 설명은 생략하기로 한다.In addition, the terms described below are terms set in consideration of the function in the present invention, and may vary depending on the inventor's intention or custom, so the definition should be made based on the content throughout the present specification, and in this specification related to the present invention. In cases where it is determined that detailed descriptions of well-known configurations or functions may obscure the gist of the present invention, detailed descriptions thereof will be omitted.

이하, 도면을 참조로 하여 본 발명에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템 및 방법을 설명한다.Hereinafter, a system and method for synchronizing transmission and reception between multiple images and data according to the present invention will be described with reference to the drawings.

도 1은 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)의 구성도이다.Figure 1 is a configuration diagram of a synchronization transmission and reception system 10 between multiple images and data according to an embodiment of the present invention.

본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)은 적어도 하나 이상의 클라이언트 장치(100)와 서버(200)로 구성될 수 있고, 각 장치들은 네트워크로 연결되어 서로 통신할 수 있다.The synchronization transmission and reception system 10 between multiple images and data according to an embodiment of the present invention may be composed of at least one client device 100 and a server 200, and each device may be connected to a network and communicate with each other. there is.

본 발명에서 클라이언트 장치(100)는 영상을 촬영/캡쳐(Capture)하여 전송하는 카메라/촬영 장치, 각종 데이터를 수집하는 센서, 스마트 장치 등을 포함할 수 있다.In the present invention, the client device 100 may include a camera/photography device that shoots/captures and transmits images, sensors that collect various data, smart devices, etc.

본 발명에서 언급하는 서버(200)는 클라이언트 장치(100)의 접속 요청을 수신하여 양방향 통신 채널을 생성하고, 클라이언트 장치(100)가 전송하는 비디오 데이터 및 전송하는 비디오 데이터와 연관된 센싱(Sensing) 데이터 또는 영상 Frame의 물체/객체 데이터를 의미한다. 센싱(Sensing) 데이터는 센서로부터 수집된 물체 정보, 주변 환경 정보, 기상 정보, 거리 정보 등을 포함할 수 있다.The server 200 referred to in the present invention receives a connection request from the client device 100, creates a two-way communication channel, and receives video data transmitted by the client device 100 and sensing data associated with the transmitted video data. Or it refers to the object/object data of the video frame. Sensing data may include object information, surrounding environment information, weather information, distance information, etc. collected from sensors.

또한 본 발명에서 언급하는 서버(200)는 일종의 웹 서비스 서버, 데이터베이스 서버, 빅데이터 서버, IoT서버, 미디어 서버 및 어플리케이션 서버 중 적어도 하나 이상의 역할을 하는 서버로 구축될 수 있다.Additionally, the server 200 referred to in the present invention may be constructed as a server that functions as at least one of a type of web service server, database server, big data server, IoT server, media server, and application server.

또한, 상기 열거한 각각의 역할을 하나의 물리적 서버에서 수행할 수도 있고, 물리적으로 분리된 복수개의 서버로 구성되어 운영될 수도 있다. 다만, 이에 한정하지 않고, 서버의 종류는 통상의 기술자에게 자명한 수준에서 다양하게 변경 가능하다.Additionally, each of the roles listed above may be performed by one physical server, or may be configured and operated as a plurality of physically separated servers. However, it is not limited to this, and the type of server can be changed in various ways at a level that is obvious to a person skilled in the art.

클라이언트 장치(100)와 서버(200)간 송수신 데이터는 비디오 데이터, 센싱(Sensing) 데이터 및 통신 상태 데이터 중 적어도 하나 이상을 포함한다.Data transmitted and received between the client device 100 and the server 200 includes at least one of video data, sensing data, and communication status data.

보다 구체적으로, 클라이언트 장치(100)는 카메라를 통해 수집된 비디오 데이터, 각종 센서에서 수집된 영상 이외의 센싱(Sensing) 데이터 및 클라이언트 장치(100)의 통신 흐름의 상태를 측정할 수 있는 통신 상태 데이터를 포함한다.More specifically, the client device 100 includes video data collected through cameras, sensing data other than images collected from various sensors, and communication status data that can measure the status of the communication flow of the client device 100. Includes.

일례로, 클라이언트 장치(100)는 자율 주행을 위해 시각 정보를 수집하는 카메라와 주행 중 나타나는 다양한 객체를 인식을 위한 라이다 (RiDAR) 또는 레이더(RADAR) 등의 다양한 센서를 포함할 수 있다.For example, the client device 100 may include various sensors such as a camera that collects visual information for autonomous driving and a LiDAR or RADAR for recognizing various objects that appear while driving.

라이다(RiDAR)는 레이저 펄스를 쏘고 반사되어 돌아오는 시간을 측정하여 반사체의 위치 좌표를 측정하는 레이다 장치이다.RiDAR is a radar device that measures the location coordinates of a reflector by shooting a laser pulse and measuring the time it takes for it to reflect and return.

클라이언트 장치(100)는 라이다(RiDAR) 또는 레이더(RADAR)가 수집하는 신호 데이터를 분석하고, 이를 바탕으로 분석된 물체/객체 정보를 포함하는 센싱(Sensing) 데이터와 카메라에서 촬영되는 비디오 데이터를 서버(200)로 전송하는데, 이때, 주행 환경 파악을 위해 두 데이터는 서로 동기화 되어 전송되어야 한다.The client device 100 analyzes signal data collected by RiDAR or RADAR, and based on this, senses data including object/object information analyzed and video data captured by the camera. It is transmitted to the server 200, and at this time, the two data must be transmitted in synchronization with each other in order to understand the driving environment.

또한, 복수개의 클라이언트 장치(100)가 서버(200)에 접속하여 통신할 수 있는데 이때, 복수개의 클라이언트가 같은 시간에 서로 다른 위치에서 촬영한 비디오 영상과 수집한 센싱(Sensing) 데이터를 전송할 수 있다.Additionally, a plurality of client devices 100 can access and communicate with the server 200. In this case, a plurality of clients can transmit video images taken at different locations at the same time and collected sensing data. .

일례로, 자율 주행을 위해 카메라와 라이다(RiDAR)/레이더(RADAR)를 포함하는 복수개의 클라이언트 장치(100)가 서버(200)와 통신하는 경우, 서버(200)는 동 시점에 각각의 클라이언트 장치(100)가 전송하는 비디오 데이터와 센싱(Sensing)데이터를 수신하여 동기화된 상태로 관리하고, 이를 토대로 실시간으로 주행 환경을 분석해야 한다.For example, when a plurality of client devices 100 including cameras and LiDAR/RADAR communicate with the server 200 for autonomous driving, the server 200 communicates with each client at the same time. Video data and sensing data transmitted by the device 100 must be received and managed in a synchronized state, and the driving environment must be analyzed in real time based on this.

동시성이 보장된 다중 영상과 센싱(Sensing) 데이터의 송수신을 위해 각각의 클라이언트 장치(100)와의 통신 상태를 주기적으로 체크하여 클라이언트 장치(100)의 통신 우선순위를 산출하고, 통신 순서를 제어하여, 통신 흐름을 동적으로 최적화하여, 데이터 병목 현상과 데이터 송수신 지연 문제를 최소화한다. In order to transmit and receive multiple images and sensing data with guaranteed concurrency, the communication status with each client device 100 is periodically checked to calculate the communication priority of the client device 100 and control the communication order, By dynamically optimizing communication flow, data bottlenecks and data transmission/reception delay problems are minimized.

이때, 서버(200)는 클라이언트 장치(100)와의 통신 상태를 체크하기 위해 클라이언트 장치(100)로부터 통신 상태 데이터를 수신한다.At this time, the server 200 receives communication status data from the client device 100 to check the communication status with the client device 100.

통신 상태 데이터는 클라이언트 장치(100)에 설정된 클라이언트 통신 우선순위 및 클라이언트 장치(100)가 송수신한 총 패킷 수 중 적어도 하나 이상의 통신 가중치 측정 인자를 포함한다. 서버(200)는 통신 상태 데이터를 수신하여 통신 가중치를 산출하고, 통신 가중치로 통신 흐름을 판단하여, 각각의 클라이언트 장치(100)와의 통신 순서를 제어한다.The communication status data includes a client communication priority set in the client device 100 and at least one communication weight measurement factor among the total number of packets transmitted and received by the client device 100. The server 200 receives communication status data, calculates a communication weight, determines the communication flow using the communication weight, and controls the communication order with each client device 100.

본 발명은 상술한 동 시점의 복수개의 비디오 데이터와 상기 비디오 데이터와 연관된 센싱(Sensing) 데이터 또는 영상 Frame의 물체/객체 데이터를 동기화하여 송수신함으로써 서버(200)에서 별도의 데이터 동기화 처리가 불필요하고, 이로써, 저 성능 서버에서도 동시성이 보장된 다중 영상 및 정보 데이터 관리가 가능해진다.The present invention synchronizes and transmits and transmits a plurality of video data at the same time as described above and sensing data or object/object data of an image frame, thereby eliminating the need for separate data synchronization processing in the server 200. This makes it possible to manage multiple video and information data with guaranteed concurrency even on low-performance servers.

도 2는 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)에서 서버(200)의 구성도이다.Figure 2 is a configuration diagram of the server 200 in the synchronization transmission and reception system 10 between multiple images and data according to an embodiment of the present invention.

본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)에서 서버(200)는 통신부(210), 동기화 제어부(220), 통신 가중치 산출부(230), 클라이언트 정보 관리부(240) 및 데이터 처리부(250)를 구비한다.In the synchronization transmission and reception system 10 between multiple images and data according to an embodiment of the present invention, the server 200 includes a communication unit 210, a synchronization control unit 220, a communication weight calculation unit 230, and a client information management unit 240. and a data processing unit 250.

통신부(210)는 적어도 하나 이상의 클라이언트 장치(100)와의 접속을 허용하고, 생성된 통신 채널을 통해 비디오 데이터, 센싱(Sensing) 데이터 및 통신 상태 데이터 중 적어도 하나 이상을 포함하는 데이터를 수신한다. 이때, 클라이언트 장치(100)와 서버(200)간의 통신은 TCP/IP 기반의 정의된 통신 규약으로 송수신 한다. The communication unit 210 allows connection with at least one client device 100 and receives data including at least one of video data, sensing data, and communication status data through the created communication channel. At this time, communication between the client device 100 and the server 200 is transmitted and received using a defined communication protocol based on TCP/IP.

정의된 통신 규약은 동 시점의 복수개의 비디오 데이터와 상기 비디오 데이터와 연관된 센싱(Sensing) 데이터 또는 영상 Frame의 물체/객체 데이터를 동기화하여 송수신하기 위한 TCP/IP 패킷 기반 프로토콜일 수 있다.The defined communication protocol may be a TCP/IP packet-based protocol for synchronizing and transmitting and receiving a plurality of video data at the same time and sensing data associated with the video data or object/object data of the video frame.

통신부(210)는 클라이언트 장치(100)와 연결된 통신 채널을 통해 정의된 통신 규약에 따라 패킷 데이터를 수신하고, 파싱(Parsing)하여 동기화 제어부(220)으로 전달하고, 동기화 제어부(220)의 명령에 따라 패킷 데이터를 구성하여 전송한다.The communication unit 210 receives packet data according to a communication protocol defined through a communication channel connected to the client device 100, parses it, transmits it to the synchronization control unit 220, and responds to the commands of the synchronization control unit 220. Packet data is configured and transmitted accordingly.

정의된 통신 규약에 대한 상세 설명은 도 3을 참고하여 후술한다.A detailed description of the defined communication protocol will be described later with reference to FIG. 3.

동기화 제어부(220)는 복수개의 클라이언트 장치(100)가 전송하는 비디오 데이터와 상기 센싱(Sensing) 데이터를 동기화하여 수신한다.The synchronization control unit 220 synchronizes and receives video data transmitted by a plurality of client devices 100 and the sensing data.

보다 구체적으로, 동기화 제어부(220)는 데이터 동기화를 위해 통신 사이클(Cycle) 단위로 데이터 송수신을 제어한다.More specifically, the synchronization control unit 220 controls data transmission and reception on a communication cycle basis for data synchronization.

통신 사이클은 적어도 하나 이상의 비디오 패킷(VIDEO PACKET), 적어도 하나 이상의 정보 패킷(INFO PACKET) 및 적어도 하나 이상의 통신 우선순위 패킷(CP PACKET)을 송수신하는 과정을 포함한다.A communication cycle includes the process of transmitting and receiving at least one video packet (VIDEO PACKET), at least one information packet (INFO PACKET), and at least one communication priority packet (CP PACKET).

비디오 데이터는 클라이언트 장치(100)가 카메라를 통해 수집한 영상 데이터이고, 비디오 패킷(Packet)에 포함되어 전송된다.Video data is image data collected by the client device 100 through a camera, and is transmitted in a video packet.

센싱(Sensing) 데이터는 클라이언트 장치(100)가 센서(Sensor)를 통해 수집한 데이터이고, 정보 패킷(Packet)에 포함되어 전송된다.Sensing data is data collected by the client device 100 through a sensor, and is transmitted in an information packet.

센싱(Sensing) 데이터는 비디오와 연관된 영상 Frame내의 물체/객체 정보를 더 포함할 수 있다.Sensing data may further include object/object information within the image frame related to the video.

통신 상태 데이터는 클라이언트 장치(100)에 설정된 통신 우선순위 및 클라이언트 장치(100)가 하나의 통신 사이클을 수행하는 동안 송수신한 총 패킷 수 중 적어도 하나 이상을 포함하고, 통신 우선순위 패킷(Packet)에 포함되어 전송된다.Communication status data includes at least one of the communication priority set in the client device 100 and the total number of packets transmitted and received while the client device 100 performs one communication cycle, and is included in a communication priority packet (Packet). included and transmitted.

이때, VIDEO PACKET, INFO PACKET, CP PACKET 의 송수신 순서는 본 발명의 실시예에 따라 다양하게 적용될 수 있다.At this time, the transmission and reception order of VIDEO PACKET, INFO PACKET, and CP PACKET can be applied in various ways depending on the embodiment of the present invention.

클라이언트 장치(100)와 서버(200)는 데이터 송수신 시 적어도 하나 이상의 통신 사이클(Cycle)을 포함하고, 통신 연결 시점부터 연결 종료까지 동기화 되어 처리되어야 하는 비디오 데이터 및 센싱(Sensing)데이터의 송수신을 위해 통신 사이클 단위로 데이터를 송수신하고, 처리한다. The client device 100 and the server 200 include at least one communication cycle when transmitting and receiving data, and are used to transmit and receive video data and sensing data that must be processed in synchronization from the time of communication connection to the end of the connection. Data is transmitted, received, and processed in units of communication cycles.

일례로, 자율 주행을 위해 설치된, 카메라와 라이다(RiDAR)/레이더(RADAR)를 포함하는 클라이언트 장치(100)는 카메라로부터 수집된 비디오 데이터를 VIDEO PACKET에 포함하여 서버(200)로 전송한다(단계 1). 다음으로, 비디오 데이터 전송 후 라이다(RiDAR)/레이더(RADAR)로부터 수집한 정보 데이터를 INFO PACKET에 포함하여 서버(200)로 전송한다(단계 2). 이후 클라이언트 장치(100)의 통신 가중치 측정 인자(통신 우선순위, 송수신한 총 패킷 수 등)를 포함하는 통신 상태 데이터를 전송한다(단계 3). 이때 단계 1, 단계 2, 단계 3이 하나의 통신 사이클을 의미한다.For example, the client device 100, which includes a camera and a LiDAR/RADAR installed for autonomous driving, includes video data collected from the camera in a VIDEO PACKET and transmits it to the server 200 ( Step 1). Next, after transmitting the video data, the information data collected from RiDAR/RADAR is included in the INFO PACKET and transmitted to the server 200 (step 2). Thereafter, communication status data including communication weight measurement factors (communication priority, total number of packets transmitted and received, etc.) of the client device 100 is transmitted (step 3). At this time, step 1, step 2, and step 3 mean one communication cycle.

또한, 동기화 제어부(220)는 하나의 통신 사이클이 끝날 때마다 통신 가중치 산출부(230)를 호출하여 클라이언트 장치(100)의 통신 가중치를 산출하고, 이를 적용하여 클라이언트 장치(100)의 통신 우선순위를 갱신한다. 통신 우선순위는 가중치 값이 낮은 순서부터 높은 순서로(오름차순) 지정된다.In addition, the synchronization control unit 220 calls the communication weight calculation unit 230 at the end of one communication cycle to calculate the communication weight of the client device 100 and applies it to determine the communication priority of the client device 100. Update . Communication priorities are specified in order from lowest to highest weight value (ascending order).

이후 갱신된 통신 우선순위에 따라 클라이언트 장치(100)와 데이터를 송수신함으로써 다수의 클라이언트 장치(100)에서 수집되는 비디오 데이터 및 센싱(Sensing) 데이터의 송수신 지연 및 오차를 최소화한다.Thereafter, data is transmitted and received with the client device 100 according to the updated communication priority, thereby minimizing transmission and reception delays and errors in video data and sensing data collected from multiple client devices 100.

통신 가중치 산출부(230)는 클라이언트 장치(100)의 통신 가중치를 계산한다.The communication weight calculation unit 230 calculates the communication weight of the client device 100.

통신 가중치는 다중 클라이언트 환경에서 특정 클라이언트로 데이터 송수신이 쏠리는 병목 현상과 이에 따른 데이터 지연 문제를 최소화하기 위해 서버(200)와 클라이언트 장치(100)간의 송수신 우선순위를 정하기 위해 산출한다.The communication weight is calculated to prioritize transmission and reception between the server 200 and the client device 100 in order to minimize the bottleneck phenomenon in which data transmission and reception is concentrated on a specific client in a multi-client environment and the resulting data delay problem.

일례로, 통신 가중치는 아래의 수식으로 계산할 수 있다.As an example, the communication weight can be calculated using the formula below.

Communication_PriorityCommunication_Priority

= = Data_1Cycle_Send_Or_Receive_Time_Per_Client[ms] Data_1Cycle_Send_Or_Receive_Time_Per_Client[ms] //

Administrator_Custom_Client_Level[1~10]Administrator_Custom_Client_Level[1~10] / /

Client_Communication_Packets_CountClient_Communication_Packets_Count

각 통신 인자에 대한 설명은 아래와 같다.The description of each communication factor is as follows.

Data_1Cycle_Send_Or_Receive_Time_Per_Client[ms]은 하나의 통신 사이클이 완료되는데 걸린 시간을 측정한 값이며 ms단위를 사용한다. Data_1Cycle_Send_Or_Receive_Time_Per_Client[ms] is a measurement of the time it takes to complete one communication cycle and uses the unit of ms.

Aministrator_Custom_Client_Level[1~10]은 클라이언트 장치(100) 또는 서버(200)의 관리자가 지정한 클라이언트 장치(100)의 통신 우선순위이며 1~10 Level로 구성된다. Aministrator_Custom_Client_Level[1~10] is the communication priority of the client device 100 designated by the administrator of the client device 100 or the server 200 and is composed of levels 1 to 10.

Client_Communication_Packets_Count는 하나의 통신 사이클 동안 클라이언트 장치(100)가 송수신하는 총 서브 패킷의 개수이다. Client_Communication_Packets_Count is the total number of subpackets transmitted and received by the client device 100 during one communication cycle.

클라이언트 정보 관리부(240)는 클라이언트 장치(100)의 ID(식별자), 통신 우선순위, 통신 가중치 등 통신에 필요한 각각의 클라이언트 장치(100)의 설정 값을 관리한다.The client information management unit 240 manages setting values of each client device 100 necessary for communication, such as the ID (identifier) of the client device 100, communication priority, and communication weight.

데이터 처리부(250)는 적어도 하나 이상의 클라이언트 장치(100)에서 전송한 동기화 된 비디오 데이터, 센싱(Sensing) 데이터를 다양한 서비스에 활용하기 위해 빅데이터 활용을 위한 데이터 전처리/분석, 머신러닝 모델 학습, 인공지능(AI)을 활용한 예측/판단 등의 데이터 처리를 수행하며, 앞서 열거한 기능 이외 다양한 데이터 처리 기능을 포함할 수 있다.The data processing unit 250 performs data preprocessing/analysis, machine learning model learning, and artificial intelligence for big data utilization in order to utilize synchronized video data and sensing data transmitted from at least one client device 100 for various services. It performs data processing such as prediction/judgment using intelligence (AI), and can include various data processing functions in addition to the functions listed above.

데이터 처리부(250)는 빅데이터, 인공지능(AI) 모델 학습, 인공지능(AI)을 활용한 예측/판단 등의 처리를 위해, 서버(200)와 네트워크로 연결되고 독립적으로 구성된 빅데이터 서버, 인공지능(AI) 처리 서버, 어플리케이션 서버, 미디어 서버 및 웹서비스 서버 중 적어도 하나 이상과 연동하는 인터페이스부를 더 포함할 수 있다.The data processing unit 250 is a big data server connected to the server 200 by a network and configured independently for processing big data, artificial intelligence (AI) model learning, prediction/judgment using artificial intelligence (AI), etc. It may further include an interface unit that interfaces with at least one of an artificial intelligence (AI) processing server, an application server, a media server, and a web service server.

도 3은 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)에서 통신 규약을 정의한 패킷 구성도이며, 도 3을 참조하여 정의된 통신 규약을 상세히 설명한다.Figure 3 is a packet configuration diagram defining a communication protocol in the synchronization transmission and reception system 10 between multiple images and data according to an embodiment of the present invention, and the defined communication protocol is explained in detail with reference to Figure 3.

클라이언트 장치(100)와 통신부(210)는 TCP/IP 프로토콜 기반으로 정의된 통신 규격으로 통신하고, 상기 정의된 통신 규격은 비디오 패킷(Packet), 정보 패킷(Packet) 및 통신 우선순위 패킷(Packet) 중 적어도 하나 이상을 포함한다.The client device 100 and the communication unit 210 communicate using communication standards defined based on the TCP/IP protocol, and the defined communication standards include video packet (Packet), information packet (Packet), and communication priority packet (Packet). Includes at least one of

보다 구체적으로, 정의된 통신 규약은 비디오 데이터를 송수신하기 위한 비디오 패킷(VIDEO PACKET), 비디오와 연관된 영상 Frame내의 물체/객체 정보 또는 센싱(Sensing) 데이터를 송수신하기 위한 정보 패킷(INFO PACKET) 및 클라이언트 장치(100)의 통신 상태 데이터를 송수신하기 위한 통신 우선순위 패킷(Communication Priority Packet, CP PACKET)을 포함하고, 상술한 패킷 이외 필요에 따라 다양한 형태의 데이터를 전송하기 위해 추가로 패킷을 정의하여 포함할 수 있다.More specifically, the defined communication protocol is a video packet (VIDEO PACKET) for sending and receiving video data, an information packet (INFO PACKET) and a client for sending and receiving object/object information or sensing data within the video frame related to the video. Includes a Communication Priority Packet (CP PACKET) for transmitting and receiving communication status data of the device 100, and additionally defines and includes packets to transmit various types of data as needed in addition to the packets described above. can do.

VIDEO PACKET, INFO PACKET 및 CP PACKET은 데이터의 종류에 따라 정의한 메인 패킷(Main Packet)이며, 각각의 메인 패킷은 적어도 하나 이상의 정의된 서브 패킷(Sub Packet)을 포함한다.VIDEO PACKET, INFO PACKET, and CP PACKET are main packets defined according to the type of data, and each main packet includes at least one defined sub packet.

서브 패킷은 START PACKET, LENGTH PACKET, CHECK PACKET 및 DATA PACKET을 포함하고, 상술한 패킷 이외 필요에 따라 다양한 형태의 데이터를 전송하기 위해 추가로 패킷을 정의하여 포함할 수 있다.Subpackets include START PACKET, LENGTH PACKET, CHECK PACKET, and DATA PACKET, and may include additional packets defined to transmit various types of data as needed in addition to the packets described above.

START PACKET은 송신할 패킷의 시작을 의미하고, 상기 패킷을 식별하는 패킷ID, 메인 패킷의 종류(VIDEO PACKET, INFO PACKET, CP PACKET) 및 데이터 소스ID를 포함한다.START PACKET means the start of the packet to be transmitted and includes a packet ID that identifies the packet, the type of main packet (VIDEO PACKET, INFO PACKET, CP PACKET), and a data source ID.

데이터 소스ID란 클라이언트 장치(100)에서 전송하는 비디오 데이터, 비디오와 연관된 영상 Frame내의 물체/객체 정보 또는 센싱(Sensing)데이터, 통신 상태 데이터 등의 데이터 출처를 식별하는 ID이다.The data source ID is an ID that identifies the data source such as video data transmitted from the client device 100, object/object information within an image frame related to the video, sensing data, or communication status data.

일례로, 클라이언트 장치(100)에 연결된 제 1 카메라에서 수집된 비디오 데이터인 경우, 클라이언트 장치(100) 번호 + 'VIDEO' + 제 1 카메라 식별번호로 구성할 수 있다.For example, in the case of video data collected from a first camera connected to the client device 100, it can be composed of the client device 100 number + 'VIDEO' + the first camera identification number.

START PACKET은 서버(200)가 클라이언트 장치(100)로 전송한다.START PACKET is transmitted from the server 200 to the client device 100.

LENGTH PACKET은 DATA PACKET의 크기를 포함하고, 최대 2^32byte 크기로 정의할 수 있다.LENGTH PACKET includes the size of the DATA PACKET and can be defined as a maximum size of 2^32 bytes.

LENGTH PACKET은 클라이언트 장치(100)가 서버(200)로 전송한다.The LENGTH PACKET is transmitted from the client device 100 to the server 200.

CHECK PACKET은 DATA PACKET을 수신할 준비가 되었는지 확인하는 Flag 인자를 포함하고, Flag 인자는 텍스트, 숫자로 정의할 수 있다.CHECK PACKET includes a Flag argument that checks whether the DATA PACKET is ready to be received, and the Flag argument can be defined as text or number.

CHECK PACKET은 서버(200)가 클라이언트 장치(100)로 전송한다.CHECK PACKET is transmitted from the server 200 to the client device 100.

DATA PACKET은 패킷ID, 메인 패킷의 종류(VIDEO PACKET, INFO PACKET, CP PACKET) 및 클라이언트 장치(100)가 전송하고자 하는 데이터를 포함하며, 해당 데이터는 메인 패킷의 종류에 대응하는 비디오 데이터, 비디오와 연관된 영상 Frame내의 물체/객체 정보 또는 센싱(Sensing) 데이터 및 상기 통신 상태 데이터 중 적어도 하나를 포함한다.DATA PACKET includes packet ID, main packet type (VIDEO PACKET, INFO PACKET, CP PACKET), and data that the client device 100 wants to transmit. The data includes video data, video and It includes at least one of object/object information or sensing data within the associated video frame and the communication status data.

DATA PACKET은 클라이언트 장치(100)가 서버(200)로 전송한다.DATA PACKET is transmitted from the client device 100 to the server 200.

도 4는 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 시스템(10)에서 클라이언트 장치(100)의 통신 가중치와 통신 우선순위 산정을 도식화한 도면이다.FIG. 4 is a diagram illustrating calculation of communication weight and communication priority of the client device 100 in the synchronized transmission and reception system 10 between multiple images and data according to an embodiment of the present invention.

도 4를 참조하여 통신 가중치를 산정하고, 산정된 통신 가중치를 사용하여 통신 순서를 제어하는 방법을 설명한다.A method of calculating a communication weight and controlling the communication order using the calculated communication weight will be described with reference to FIG. 4.

Communication_PriorityCommunication_Priority

= = Data_1Cycle_Send_Or_Receive_Time_Per_Client[ms] Data_1Cycle_Send_Or_Receive_Time_Per_Client[ms] //

Administrator_Custom_Client_Level[1~10]Administrator_Custom_Client_Level[1~10] / /

Client_Communication_Packets_CountClient_Communication_Packets_Count

D1CSRTPC: Data_1Cycle_Send_Or_Receive_Time_Per_Client[ms] D1CSRTPC: Data_1Cycle_Send_Or_Receive_Time_Per_Client[ms]

ACCL: Administrator_Custom_Client_Level[1~10] ACCL: Administrator_Custom_Client_Level[1~10]

CCPC: Client_Communication_Packets_Count CCPC: Client_Communication_Packets_Count

상기 통신 가중치 산출식을 적용하여 클라이언트 장치(Client) 1에서 클라이언트 장치(Client) N까지의 통신 가중치를 산정하면, 아래와 같다.By applying the communication weight calculation formula above to calculate the communication weight from client device (Client) 1 to client device (Client) N, it is as follows.

Client1Client1 Client2Client2 Client3Client3 Client4Client4 3.83.8 1.9161.916 6.1256.125 4.14.1 Client5Client5 Client6Client6 Client7Client7 Client8Client8 0.660.66 1.851.85 7.257.25 11.111.1

산출된 통신 가중치를 오름차순으로 정렬하면 통신 가중치가 가장 낮은 클라이언트 장치(Client) 5가 통신 우선순위 1이 되고, 클라이언트 장치(Client) 8은 통신 우선순위가 8이 된다.If the calculated communication weights are sorted in ascending order, Client 5 with the lowest communication weight has communication priority 1, and Client 8 has communication priority 8.

서버(200)는 클라이언트 장치(Client) 5와 가장 먼저 통신을 수행하고, 클라이언트 장치(Client) 8과 가장 나중에 통신을 수행한다.The server 200 communicates with client device (Client) 5 first, and communicates with client device (Client) 8 last.

도 5는 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 방법을 나타낸 순서도이다. Figure 5 is a flowchart showing a method for synchronizing transmission and reception between multiple images and data according to an embodiment of the present invention.

도 5를 참조하여 다중 영상 및 데이터 간 동기화 송수신 방법을 설명한다.A method of synchronizing transmission and reception between multiple images and data will be described with reference to FIG. 5.

다중 영상 및 데이터 송수신 동기화 시스템(10)에 의해 구현되는 다중 영상 및 데이터 간 동기화 방법에 있어서, 클라이언트 장치와 통신부 간의 통신 채널을 연결하는 통신 연결 단계(S310), 상기 통신 채널에서 비디오 패킷을 송수신 하는 단계(S320), 상기 통신 채널에서 정보 패킷을 송수신 하는 단계(S330), 상기 통신 채널에서 통신 우선순위 패킷을 송수신 하는 단계(S340) 및 통신 가중치 산출부가 상기 클라이언트 장치의 통신 가중치를 산출하여 상기 클라이언트 장치의 통신 우선순위를 갱신하는 단계(S350)를 포함한다. In the synchronization method between multiple videos and data implemented by the multi-video and data transmission/reception synchronization system 10, a communication connection step (S310) of connecting a communication channel between a client device and a communication unit, and transmitting and receiving video packets in the communication channel. Step (S320), transmitting and receiving an information packet in the communication channel (S330), transmitting and receiving a communication priority packet in the communication channel (S340), and a communication weight calculation unit calculates the communication weight of the client device and It includes updating the communication priority of the device (S350).

통신 연결 단계(S310)는 통신부(210)가 적어도 하나 이상의 클라이언트 장치(100)와의 접속을 허용하고, TCP/IP기반 통신 채널을 생성하는 단계이다.The communication connection step (S310) is a step in which the communication unit 210 allows connection with at least one client device 100 and creates a TCP/IP-based communication channel.

통신부(210)는 클라이언트 정보 관리부(240)에서 관리하는 클라이언트 장치(100)의 개수와 클라이언트 ID를 확인하고, 해당되는 클라이언트 장치(100)의 접속을 대기하며, 각각의 클라이언트 장치(100)와의 통신 채널을 생성한다.The communication unit 210 checks the number and client ID of the client devices 100 managed by the client information management unit 240, waits for the connection of the corresponding client device 100, and communicates with each client device 100. Create a channel.

이때, 통신부(210)에서는 데이터를 동기화하여 송수신해야하는 복수개의 클라이언트 장치(100)를 내부적으로 관리하고, 해당 클라이언트 장치(100)가 모두 접속할 때까지 대기할 수 있다.At this time, the communication unit 210 internally manages a plurality of client devices 100 that need to synchronize and transmit data, and can wait until all of the client devices 100 are connected.

비디오 패킷 송수신 단계(S320)는 S310에서 생성된 통신 채널을 통해 클라이언트 장치(100)가 수집한 비디오 데이터를 송수신 하는 단계이다.The video packet transmission and reception step (S320) is a step of transmitting and receiving video data collected by the client device 100 through the communication channel created in S310.

첫 비디오 패킷 통신일 경우 서버(200) 내에서 설정된 통신 우선순위 순서대로 클라이언트 장치(100)와 통신을 시도한다.In the case of the first video packet communication, communication with the client device 100 is attempted in the order of communication priorities set within the server 200.

통신부(210)는 클라이언트 장치(100)와 START PACKET, LENGTH PACKET, CHECK PACKET, DATA PACKAET을 포함하는 비디오 패킷(VIDEO PACKET)을 서로 송수신하면서, 클라이언트 장치(100)가 수집한 비디오 데이터를 수신한다. The communication unit 210 receives video data collected by the client device 100 while transmitting and receiving video packets including START PACKET, LENGTH PACKET, CHECK PACKET, and DATA PACKAET with the client device 100.

S320 단계는 적어도 하나 이상의 비디오 패킷(VIDEO PACKET)을 송수신할 수 있고, 더 이상 전송할 비디오 패킷이 없는 경우 정보 패킷(INFO PACKET) 송수신 단계(S330)를 진행한다.In step S320, at least one video packet (VIDEO PACKET) can be transmitted and received, and if there are no more video packets to transmit, the information packet (INFO PACKET) transmitting and receiving step (S330) is performed.

정보 패킷(INFO PACKET) 송수신 단계(S330)는 S310에서 생성된 통신 채널을 통해 클라이언트 장치(100)가 수집한 센싱(Sensing) 데이터 또는 비디오 Frame 내의 물체/객체 정보를 송수신 하는 단계이다.The INFO PACKET transmission and reception step (S330) is a step of transmitting and receiving sensing data collected by the client device 100 or object/object information within the video frame through the communication channel created in S310.

통신부(210)는 클라이언트 장치(100)와 START PACKET, LENGTH PACKET, CHECK PACKET, DATA PACKAET을 포함하는 정보 패킷(INFO PACKET)을 서로 송수신하면서, 클라이언트 장치(100)가 수집한 센싱(Sensing) 데이터 또는 비디오 Frame 내의 물체/객체 정보를 수신한다.The communication unit 210 transmits and receives information packets (INFO PACKET) including START PACKET, LENGTH PACKET, CHECK PACKET, and DATA PACKAET with the client device 100, and receives sensing data collected by the client device 100 or Receives object/object information within the video frame.

S330 단계는 적어도 하나 이상의 정보 패킷(INFO PACKET)을 송수신할 수 있고, 더 이상 전송할 정보 패킷(INFO PACKET)이 없는 경우 통신 우선순위 패킷(CP PACKET) 송수신 단계(S340)를 진행한다.In step S330, at least one information packet (INFO PACKET) can be transmitted and received, and if there are no more information packets (INFO PACKET) to be transmitted, the communication priority packet (CP PACKET) transmission and reception step (S340) is performed.

통신 우선순위 패킷(CP PACKET) 송수신 단계(S340)는 S310에서 생성된 통신 채널을 통해 클라이언트 장치(100)의 통신 상태 데이터를 송수신 하는 단계이다.The communication priority packet (CP PACKET) transmission and reception step (S340) is a step of transmitting and receiving communication status data of the client device 100 through the communication channel created in S310.

통신 가중치 측정 인자는 클라이언트 장치(100)에 설정된 클라이언트 통신 우선순위 및 클라이언트 장치(100)가 송수신한 총 패킷 수를 포함한다.The communication weight measurement factor includes the client communication priority set in the client device 100 and the total number of packets transmitted and received by the client device 100.

통신부(210)는 클라이언트 장치(100)와 START PACKET, LENGTH PACKET, CHECK PACKET, DATA PACKAET을 포함하는 통신 우선순위 패킷(CP PACKET)을 서로 송수신하면서, 클라이언트 장치(100)의 통신 상태 데이터를 수신한다.The communication unit 210 transmits and receives communication priority packets (CP PACKETs) including START PACKET, LENGTH PACKET, CHECK PACKET, and DATA PACKAET with the client device 100, and receives communication status data of the client device 100. .

통신 우선순위 패킷(CP PACKET)의 송수신이 완료되면 하나의 통신 사이클(Cycle)이 완료되고, 통신 우선순위 갱신 단계(S350)를 진행한다.When transmission and reception of a communication priority packet (CP PACKET) is completed, one communication cycle is completed, and a communication priority update step (S350) is performed.

통신 우선순위 갱신 단계(S350)는 클라이언트 장치(100)의 통신 가중치를 산출하여 상기 클라이언트 장치의 통신 우선순위를 갱신한다.In the communication priority updating step (S350), the communication priority of the client device 100 is updated by calculating the communication weight of the client device 100.

동기화 제어부(220)는 갱신된 통신 우선순위를 적용하여 해당 순서대로 클라이언트 장치(100)와 데이터를 송수신한다.The synchronization control unit 220 transmits and receives data to and from the client device 100 in that order by applying the updated communication priority.

한편, 다중 영상 및 데이터 간 동기화 방법은, 데이터 처리 단계(S360)을 더 포함할 수 있다.Meanwhile, the method for synchronizing multiple images and data may further include a data processing step (S360).

동기화 제어부(220)는 복수개의 클라이언트 장치(100)로부터 동기화되어 수신된 비디오 데이터와 센싱(Sensing) 데이터 또는 비디오 Frame 내의 물체/객체 정보를 데이터 처리부(250)로 전달할 수 있다.The synchronization control unit 220 may transmit video data and sensing data received in synchronization from a plurality of client devices 100 or object/object information within the video frame to the data processing unit 250.

데이터 처리 단계(S360)는 동기화된 다중 비디오 데이터와 이와 연관된 센싱(Sensing) 데이터 또는 비디오 Frame 내의 물체/객체 정보를 다양한 서비스에 활용하기 위해 빅데이터 활용을 위한 데이터 전처리/분석, 머신러닝 모델 학습, 인공지능(AI)을 활용한 예측/판단 등의 데이터 처리를 수행한다.The data processing step (S360) involves data preprocessing/analysis, machine learning model learning, and Performs data processing such as prediction/judgment using artificial intelligence (AI).

도 6은 본 발명의 일 실시예에 따른 다중 영상 및 데이터 간 동기화 송수신 방법에서 하나의 통신 사이클(Cycle) 내에서 패킷의 상세 흐름을 나타낸 흐름도이다.Figure 6 is a flowchart showing the detailed flow of packets within one communication cycle in the synchronized transmission and reception method between multiple images and data according to an embodiment of the present invention.

도 6을 참조하여 클라이언트 장치(100)와 서버(200)간 다중 영상 및 데이터 간 동기화 송수신을 위한 패킷의 송수신을 설명한다.Referring to FIG. 6, transmission and reception of packets for synchronized transmission and reception between multiple images and data between the client device 100 and the server 200 will be described.

클라이언트 장치(100)와 서버(200)가 연결되어 통신 채널이 생성되면, 아래와 같이 비디오 패킷(VIDEO PACKET) 송수신 단계를 진행한다.When the client device 100 and the server 200 are connected and a communication channel is created, a video packet (VIDEO PACKET) transmission and reception step is performed as follows.

서버(200)는 START PACKET에 패킷ID, 메인 패킷의 종류(VIDEO PACKET) 및 데이터 소스ID를 포함하여 클라이언트 장치(100)로 전송한다(S410). 이때 데이터 소스ID는 비디오 데이터를 식별할 수 있는 클라이언트 장치(100) 번호 + 'VIDEO' + 제 1 카메라 식별번호의 조합일 수 있고, 서버(200)와 클라이언트 장치(100)간에 상호 정의되어 공유한 ID(식별자)이다.The server 200 transmits the START PACKET including the packet ID, main packet type (VIDEO PACKET), and data source ID to the client device 100 (S410). At this time, the data source ID may be a combination of the client device 100 number that can identify video data + 'VIDEO' + the first camera identification number, and is mutually defined and shared between the server 200 and the client device 100. It is an ID (identifier).

START PACKET을 수신한 클라이언트 장치(100)는 데이터 소스ID를 확인한 후, 패킷ID, 메인 패킷의 종류(VIDEO PACKET) 및 데이터 소스ID에 해당하는 비디오 데이터의 크기를 LENGTH PACKET에 포함하여 서버(200)로 전송한다(S420).After receiving the START PACKET, the client device 100 checks the data source ID and then includes the packet ID, type of main packet (VIDEO PACKET), and size of video data corresponding to the data source ID in the LENGTH PACKET to the server 200. Transmit to (S420).

서버(200)는 수신한 LENGTH PACKET의 데이터 크기를 확인한 후 수신 가능 상태이면, 수신 가능을 나타내는 플래그(Flag)를 포함하여 CHECK PACKET을 클라이언트 장치(100)로 전송한다(S430).The server 200 checks the data size of the received LENGTH PACKET and, if reception is possible, transmits the CHECK PACKET including a flag indicating reception capability to the client device 100 (S430).

클라이언트 장치(100)는 CHECK PACKET에 포함된 플래그를 확인하고, 서버(200)가 데이터 수신이 가능한 상태인 경우, 데이터 소스ID에 해당하는 비디오 데이터를 앞서 LENGTH PACKET을 통해 전송한 데이터 크기만큼 전송한다(S440).The client device 100 checks the flag included in the CHECK PACKET, and if the server 200 is capable of receiving data, it transmits video data corresponding to the data source ID as much as the data size previously transmitted through the LENGTH PACKET. (S440).

전송할 비디오 데이터가 존재하면 S410에서 S440을 반복하고, 더 이상 전송할 비디오 데이터가 없는 경우 정보 패킷(INFO PACKET) 전송을 준비한다.If there is video data to transmit, S410 to S440 are repeated, and if there is no more video data to transmit, an INFO PACKET is prepared to be transmitted.

정보 패킷(INFO PACKET) 전송 단계는 아래와 같이 이루어진다.The INFO PACKET transmission step is performed as follows.

서버(200)는 START PACKET에 패킷ID, 메인 패킷의 종류(INFO PACKET) 및 데이터 소스ID를 포함하여 클라이언트 장치(100)로 전송한다(S510). 이때 데이터 소스ID는 센싱(Sensing) 데이터를 식별할 수 있는 클라이언트 장치(100) 번호 + 'INFODATA' + 제 1 센서(Sensor) 식별번호의 조합일 수 있고, 서버(200)와 클라이언트 장치(100)간에 상호 정의되어 공유한 ID(식별자)이다.The server 200 transmits the START PACKET including the packet ID, main packet type (INFO PACKET), and data source ID to the client device 100 (S510). At this time, the data source ID may be a combination of the client device 100 number that can identify sensing data + 'INFODATA' + the first sensor identification number, and the server 200 and the client device 100 It is an ID (identifier) that is mutually defined and shared between people.

START PACKET을 수신한 클라이언트 장치(100)는 데이터 소스ID를 확인한 후, 패킷ID, 메인 패킷의 종류(INFO PACKET) 및 데이터 소스ID에 해당하는 센싱(Sensing) 데이터의 크기를 LENGTH PACKET에 포함하여 서버(200)로 전송한다(S520).After receiving the START PACKET, the client device 100 checks the data source ID and then includes the packet ID, the type of main packet (INFO PACKET), and the size of the sensing data corresponding to the data source ID in the LENGTH PACKET to the server. Send to (200) (S520).

서버(200)는 수신한 LENGTH PACKET의 데이터 크기를 확인한 후 수신 가능 상태이면, 수신 가능을 나타내는 플래그(Flag)를 포함하여 CHECK PACKET을 클라이언트 장치(100)로 전송한다(S530).The server 200 checks the data size of the received LENGTH PACKET and, if reception is possible, transmits the CHECK PACKET including a flag indicating reception capability to the client device 100 (S530).

클라이언트 장치(100)는 CHECK PACKET에 포함된 플래그를 확인하고, 서버(200)가 데이터 수신이 가능한 상태인 경우, 데이터 소스ID에 해당하는 센싱(Sensing) 데이터를 앞서 LENGTH PACKET을 통해 전송한 데이터 크기만큼 전송한다(S540).The client device 100 checks the flag included in the CHECK PACKET, and if the server 200 is capable of receiving data, the size of the data previously transmitted through the LENGTH PACKET is the sensing data corresponding to the data source ID. Transmit as much (S540).

전송할 비디오 데이터가 존재하면 S510에서 S540을 반복하고, 더 이상 전송할 센싱(Sensing) 데이터가 없는 경우 통신 우선순위 패킷(CP PACKET) 전송을 준비한다.If there is video data to transmit, S510 to S540 are repeated, and if there is no more sensing data to transmit, a communication priority packet (CP PACKET) is prepared to be transmitted.

통신 우선순위 패킷(CP PACKET) 전송 단계는 아래와 같이 이루어진다.The communication priority packet (CP PACKET) transmission step is performed as follows.

서버(200)는 START PACKET에 패킷ID, 메인 패킷의 종류(CP PACKET) 및 데이터 소스ID를 포함하여 클라이언트 장치(100)로 전송한다(S610). 이때 데이터 소스ID는 클라이언트 장치(100)를 식별하는 클라이언트ID일 수 있고, 서버(200)와 클라이언트 장치(100)간에 상호 정의되어 공유한 ID(식별자)이다.The server 200 transmits the START PACKET including the packet ID, main packet type (CP PACKET), and data source ID to the client device 100 (S610). At this time, the data source ID may be a client ID that identifies the client device 100, and is an ID (identifier) mutually defined and shared between the server 200 and the client device 100.

START PACKET을 수신한 클라이언트 장치(100)는 데이터 소스ID를 확인한 후, 패킷ID, 메인 패킷의 종류(CP PACKET) 및 데이터 소스ID에 해당하는 통신 상태 데이터의 크기를 LENGTH PACKET에 포함하여 서버(200)로 전송한다(S620).After receiving the START PACKET, the client device 100 checks the data source ID and includes the packet ID, main packet type (CP PACKET), and size of communication status data corresponding to the data source ID in the LENGTH PACKET to the server (200). ) (S620).

서버(200)는 수신한 LENGTH PACKET의 데이터 크기를 확인한 후 수신 가능 상태이면, 수신 가능을 나타내는 플래그(Flag)를 포함하여 CHECK PACKET을 클라이언트 장치(100)로 전송한다(S630).The server 200 checks the data size of the received LENGTH PACKET and, if reception is possible, transmits the CHECK PACKET including a flag indicating reception capability to the client device 100 (S630).

클라이언트 장치(100)는 CHECK PACKET에 포함된 플래그를 확인하고, 서버(200)가 데이터 수신이 가능한 상태인 경우, 데이터 소스ID에 해당하는 통신 상태 데이터를 앞서 LENGTH PACKET을 통해 전송한 데이터 크기만큼 전송한다(S640).The client device 100 checks the flag included in the CHECK PACKET, and if the server 200 is capable of receiving data, it transmits communication status data corresponding to the data source ID as much as the data size previously transmitted through the LENGTH PACKET. Do it (S640).

이때, 통신 상태 데이터는 클라이언트 장치(100)에 설정된 클라이언트 통신 우선순위 및 클라이언트 장치(100)가 송수신한 총 패킷 수를 포함한다.At this time, the communication status data includes the client communication priority set in the client device 100 and the total number of packets transmitted and received by the client device 100.

통신 우선순위 패킷(CP PACKET) 전송 단계가 완료되면, 하나의 통신 사이클(Cycle)이 완료되고, S410에서 S640까지의 단계가 순차적으로 반복된다.When the communication priority packet (CP PACKET) transmission step is completed, one communication cycle is completed, and steps from S410 to S640 are sequentially repeated.

상기에서는 본 발명에 따른 실시예를 기준으로 본 발명의 구성과 특징을 설명하였으나 본 발명은 이에 한정되지 않으며, 본 발명의 사상과 범위 내에서 다양하게 변경 또는 변형할 수 있음은 본 발명이 속하는 기술분야의 당업자에게 명백한 것이며, 따라서 이와 같은 변경 또는 변형은 첨부된 특허청구범위에 속함을 밝혀둔다.In the above, the configuration and features of the present invention have been described based on the embodiments according to the present invention, but the present invention is not limited thereto, and various changes or modifications may be made within the spirit and scope of the present invention. It is obvious to those skilled in the art, and therefore, it is stated that such changes or modifications fall within the scope of the appended patent claims.

100: 클라이언트 장치
200: 서버
210: 통신부
220: 동기화 제어부
230: 통신 가중치 산출부
240: 클라이언트 정보 관리부
250: 데이터 처리부
S310: 통신 연결 단계
S320: 비디오 패킷 송수신 단계
S330: 정보 패킷 송수신 단계
S340: 통신 우선순위 패킷 송수신 단계
S350: 통신 우선순위 갱신 단계
S360: 데이터 처리 단계
100: Client device
200: server
210: Department of Communications
220: Synchronization control unit
230: Communication weight calculation unit
240: Client information management department
250: data processing unit
S310: Communication connection step
S320: Video packet transmission and reception step
S330: Information packet transmission and reception step
S340: Communication priority packet transmission and reception phase
S350: Communication priority update step
S360: Data processing steps

Claims (10)

클라이언트 장치로부터 비디오 데이터, 센싱(Sensing) 데이터 및 통신 상태 데이터 중 적어도 하나 이상을 포함하는 데이터를 수신하는 통신부; 및
복수개의 상기 클라이언트 장치가 전송하는 상기 비디오 데이터와 상기 센싱(Sensing) 데이터를 동기화하여 수신하는 동기화 제어부;를 구비하는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
a communication unit that receives data including at least one of video data, sensing data, and communication status data from a client device; and
A synchronization control unit that synchronizes and receives the video data and the sensing data transmitted by a plurality of the client devices, comprising:
Synchronized transmission and reception system between multiple images and data.
청구항 1에 있어서,
상기 클라이언트 장치와 상기 통신부는 TCP/IP 프로토콜 기반 정의된 통신 규격으로 통신하고, 상기 정의된 통신 규격은 비디오 패킷(Packet), 정보 패킷(Packet) 및 통신 우선순위 패킷(Packet) 중 적어도 하나 이상을 포함하는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
In claim 1,
The client device and the communication unit communicate using a defined communication standard based on the TCP/IP protocol, and the defined communication standard includes at least one of a video packet, an information packet, and a communication priority packet. containing,
Synchronized transmission and reception system between multiple images and data.
청구항 2에 있어서,
상기 비디오 데이터는,
상기 클라이언트 장치가 카메라를 통해 수집한 영상 데이터이고, 비디오 패킷(Packet)에 포함되어 전송되는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
In claim 2,
The video data is,
Image data collected by the client device through a camera and transmitted in a video packet,
Synchronized transmission and reception system between multiple images and data.
청구항 2에 있어서,
상기 센싱(Sensing) 데이터는,
상기 클라이언트 장치가 센서(Sensor)를 통해 수집한 데이터이고, 정보 패킷(Packet)에 포함되어 전송되는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
In claim 2,
The sensing data is,
Data collected by the client device through a sensor and transmitted in an information packet,
Synchronized transmission and reception system between multiple images and data.
청구항 2에 있어서,
상기 통신 상태 데이터는,
상기 클라이언트 장치에 설정된 클라이언트 통신 우선순위 및 상기 클라이언트 장치가 송수신한 총 패킷 수 중 적어도 하나 이상을 포함하고, 통신 우선순위 패킷(Packet)에 포함되어 전송되는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
In claim 2,
The communication status data is,
Contains at least one of the client communication priority set in the client device and the total number of packets transmitted and received by the client device, and is transmitted in a communication priority packet (Packet),
Synchronized transmission and reception system between multiple images and data.
청구항 2에 있어서,
상기 비디오 패킷, 상기 정보 패킷 및 상기 통신 우선순위 패킷은,
송신할 패킷의 시작을 의미하고, 상기 패킷을 식별하는 패킷ID를 포함하는 START PACKET;
상기 비디오 데이터, 상기 정보 데이터 및 상기 통신 상태 데이터 중 적어도 하나를 포함하는 DATA PACKET;
상기 DATA PACKET의 크기를 포함하는 LENGTH PACKET; 및
상기 DATA PACKET을 수신할 상태인지 확인하는 CHECK PACKET;을 포함하는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
In claim 2,
The video packet, the information packet and the communication priority packet are:
START PACKET, which indicates the start of a packet to be transmitted and includes a packet ID that identifies the packet;
A DATA PACKET containing at least one of the video data, the information data, and the communication status data;
LENGTH PACKET including the size of the DATA PACKET; and
Containing CHECK PACKET to check whether the DATA PACKET is in a state to be received,
Synchronized transmission and reception system between multiple images and data.
청구항 2에 있어서,
상기 클라이언트 장치와 상기 통신부 간의 통신은 적어도 하나 이상의 통신 사이클(Cycle)을 포함하고,
상기 통신 사이클은 적어도 하나 이상의 상기 비디오 패킷, 적어도 하나 이상의 상기 정보 패킷 및 적어도 하나 이상의 상기 통신 우선순위 패킷을 송수신하는 과정을 포함하는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
In claim 2,
Communication between the client device and the communication unit includes at least one communication cycle,
The communication cycle includes transmitting and receiving at least one video packet, at least one information packet, and at least one communication priority packet,
Synchronized transmission and reception system between multiple images and data.
청구항 7에 있어서,
상기 동기화 송수신 시스템은,
상기 통신 사이클을 수행하는데 걸린 시간인 1사이클완료시간, 상기 클라이언트 장치의 통신 우선순위 및 상기 통신 사이클 동안 송수신한 총 패킷 수를 사용하여 통신 가중치를 산정하는 통신 가중치 산출부를 더 포함하는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
In claim 7,
The synchronization transmission and reception system is,
Further comprising a communication weight calculation unit that calculates a communication weight using one cycle completion time, which is the time taken to perform the communication cycle, a communication priority of the client device, and the total number of packets transmitted and received during the communication cycle,
Synchronized transmission and reception system between multiple images and data.
청구항 8에 있어서,
상기 동기화 제어부는,
상기 통신 사이클이 끝날 때 마다 상기 통신 가중치를 적용하여 상기 클라이언트 장치의 통신 우선순위를 갱신하고, 상기 통신 우선순위에 따라 통신 흐름을 제어하는,
다중 영상 및 데이터 간 동기화 송수신 시스템.
In claim 8,
The synchronization control unit,
At the end of the communication cycle, applying the communication weight to update the communication priority of the client device and controlling the communication flow according to the communication priority,
Synchronized transmission and reception system between multiple images and data.
청구항 1에 기재된 다중 영상 및 데이터 송수신 동기화 시스템에 의해 구현되는 다중 영상 및 데이터 간 동기화 방법에 있어서,
클라이언트 장치와 통신부 간의 통신 채널을 연결하는 통신 연결 단계;
상기 통신 채널에서 비디오 패킷을 송수신 하는 단계;
상기 통신 채널에서 정보 패킷을 송수신 하는 단계;
상기 통신 채널에서 통신 우선순위 패킷을 송수신 하는 단계; 및
통신 가중치 산출부가 상기 클라이언트 장치의 통신 가중치를 산출하여 상기 클라이언트 장치의 통신 우선순위를 갱신하는 단계;를 포함하는,
다중 영상 및 데이터 간 동기화 송수신 방법.
In the synchronization method between multiple images and data implemented by the multiple image and data transmission/reception synchronization system described in claim 1,
A communication connection step of connecting a communication channel between a client device and a communication unit;
Transmitting and receiving video packets on the communication channel;
Transmitting and receiving information packets in the communication channel;
Transmitting and receiving a communication priority packet in the communication channel; and
Comprising: a step of a communication weight calculation unit calculating a communication weight of the client device and updating the communication priority of the client device;
Synchronized transmission and reception method between multiple images and data.
KR1020220151823A 2022-11-14 2022-11-14 Synchronous communication system and method between multiple images and data KR20240070238A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020220151823A KR20240070238A (en) 2022-11-14 2022-11-14 Synchronous communication system and method between multiple images and data

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020220151823A KR20240070238A (en) 2022-11-14 2022-11-14 Synchronous communication system and method between multiple images and data

Publications (1)

Publication Number Publication Date
KR20240070238A true KR20240070238A (en) 2024-05-21

Family

ID=91320726

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020220151823A KR20240070238A (en) 2022-11-14 2022-11-14 Synchronous communication system and method between multiple images and data

Country Status (1)

Country Link
KR (1) KR20240070238A (en)

Similar Documents

Publication Publication Date Title
CN1791872B (en) Method and device for multimedia streaming
EP3291551B1 (en) Image delay detection method and system
WO2019205886A1 (en) Method and apparatus for pushing subtitle data, subtitle display method and apparatus, device and medium
CN113037440B (en) Data retransmission processing method and device, computer equipment and storage medium
CN108632305B (en) Cloud storage system, media data storage method and system
CN101132269B (en) Data synchronization method and IPTV content distribution network system using the same
CN108600281B (en) Cloud storage system, media data storage method and system
CA2610579C (en) Broadcast transport stream distribution system, and broadcast transport stream distribution apparatus, user terminal device and distribution method for use in the system
KR101934200B1 (en) Method and system for media synchronization
JP7030984B2 (en) Video transmission methods, video transmission equipment, and video transmission systems, as well as computer-readable storage media.
CN104284098A (en) Method and system for processing video data
CN109168054B (en) Display screen playing system and control method
CN101064768A (en) System and method for playing synchronously dynamic image
CN112104918A (en) Image transmission method and device based on satellite network
US8456532B1 (en) Internet protocol camera transcode avoidance
CN114554250B (en) Video and position synchronization method of unmanned aerial vehicle or unmanned aerial vehicle
CN105635802A (en) Transmission method of digital media data and device
KR20240070238A (en) Synchronous communication system and method between multiple images and data
KR20180032917A (en) Client device and local clock skew compensation method thereof
WO2024021999A1 (en) Synchronization method, system, and electronic device
US20110044332A1 (en) Communication apparatus, communication system, and communication method
CN112887666A (en) Video processing method and device, network camera, server and storage medium
US20140111643A1 (en) Method, apparatus, and system for acquiring visual angle
CN111669605B (en) Method and device for synchronizing multimedia data and associated interactive data thereof
CN115103204B (en) Method and device for realizing edge intelligent application supporting AI engine

Legal Events

Date Code Title Description
E902 Notification of reason for refusal