Flexible Architecture for Real-time Processing of Multiple Video Signals by Awad, Mohamed et al.
Noname manuscript No.
(will be inserted by the editor)
Flexible Architecture for Real-time Processing of Multiple
Video Signals
Mohamed Awad · Islam T. Abougindia · Ahmed Elliethy · Hussein A.
Aly
Received: date / Accepted: date
Abstract Simultaneous processing of multiple video
sources requires each pixel in a frame from a video
source to be processed synchronously with the pixels
at the same spatial positions in corresponding frames
from the other video sources. However, simultaneous
processing is challenging as corresponding frames from
different video signals provided by multiple sources have
time-varying delay because of the electrical and me-
chanical restrictions inside the video sources hardware
that cause deviation in the corresponding frame rates.
Researchers overcome the aforementioned challenges ei-
ther by utilizing ready-made video processing systems
or designing and implementing a custom system tai-
lored to their specific application. These video process-
ing systems lack flexibility in handling different applica-
tions requirements such as the required number of video
sources and outputs, video standards, or frame rates
of the input/output videos. In this paper, we present
a design for a flexible simultaneous video processing
architecture that is suitable for various applications.
The proposed architecture is upgradeable to deal with
multiple video standards, scalable to process/produce
a variable number of input/output videos, and compat-
ible with most video processors. Moreover, we present
Mohamed Awad
Military Technical College, Cairo, Egypt
E-mail: awad.mrms@gmail.com
Islam T. Abougindia
Military Technical College, Cairo, Egypt
E-mail: iabougindia@ieee.org
Ahmed Elliethy
Military Technical College, Cairo, Egypt
E-mail: a.s.elliethy@mtc.edu.eg
Hussein A. Aly
Military Technical College, Cairo, Egypt
E-mail: haly@ieee.org
in details the analog/digital mixed-signals and power
distribution considerations used in designing the pro-
posed architecture. As a case study application of the
proposed flexible architecture, we utilized the architec-
ture for a realization of a simultaneous video process-
ing system that performs video fusion from visible and
near-infrared video sources in real time. We make avail-
able the source files of the hardware design along with
the bill of material (BOM) of the case study to be a
reference for researchers who intend to design and im-
plement simultaneous multi-video processing systems.
Keywords multi-video simultaneous processing ·
multi-video synchronization · real-time video fusion
1 Introduction
Simultaneous processing of multiple video sources has
been the core of many state-of-the-art vision applica-
tions such as multi-view 3D-Televisions [1–3], augmented
reality [4,5] and fusion-based video enhancement [6,7].
These applications require simultaneous processing of
multiple video sources where each pixel in a frame from
a video source is processed synchronously with the pix-
els at the same spatial positions in the corresponding
frames from the other video sources [7].
Generally speaking, simultaneous processing of mul-
tiple video sources faces several challenges. First, the
frame rate of a video produced from a video source
commonly has a small deviation because of the electri-
cal and mechanical restrictions inside the video source
hardware [13], and this causes a time-varying deviation
among the frame rates of the multiple input videos. Sec-
ond, the video signals generated from multiple sources
can not be started at exact time without using a cus-
tom external hardware synchronization signal, therefore
ar
X
iv
:2
00
1.
02
04
8v
1 
 [e
es
s.I
V]
  2
9 D
ec
 20
19
2 Mohamed Awad et al.
Architecture scalability number of number of video different different startup deviation in independence of
input output format spatial temporal delay temporal output format
videos videos resolutions resolutions resolution from input
Custom [8] 7 9 1 4K-UHD 3 3 7 7 3
Patent [9] 7 2 1 Unspecified 3 3 7 7 7
Patent [10] 7 4 1 Unspecified 7 7 7 7 7
Patent [11] 7 3 3 Unspecified 7 7 7 7 7
Patent [12] 7 4 2 Unspecified 7 7 3 7 7
Proposed 3 Any Any Any 7 3 3 3 3
Table 1 Comparison among the proposed architecture and different architectures for simultaneous processing of multiple video
signals.
there is an inevitable delay between the start of the cor-
responding frames from the sources. Third, when the
input analog videos are decoded into appropriate dig-
ital formats (such as BT.656 [14]) to be suitable for
processing, the previous problems appears in the pro-
duced digital video signals making them not suitable
for simultaneous processing. Finally, Dealing with the
massive amount of data provided by the different video
sources greatly increases the complexity specially for
time critical applications that require fast processing
for the input videos.
To implement a system that performs simultane-
ous processing of multiple video sources, a ready made
and direct solution is to use one of the market avail-
able video processing hardware cards aided with neces-
sary components to overcome the aforementioned chal-
lenges associated with simultaneous processing. Such
type of cards are widely used as in [15–23]. Another so-
lution is to design and implement a custom video pro-
cessing platform tailored to specific application such as
the patents in [9–12, 24–27]. For example, Guo et al.
proposed a multi-video processing board that stitches
videos from different sources into one larger video to
be displayed on 4K ultra high definition (UHD) dis-
play [8]. However, both solutions (the ready made and
custom one) are not flexible enough to handle modifi-
cations in design requirements of an application such
as the desired number, the required video standards, or
the frame rates of the input/output videos.
In this paper, we propose a design of a flexible archi-
tecture that is suitable for various applications requir-
ing simultaneous processing of multiple video signals.
The proposed architecture has several advantages. The
proposed architecture is compatible with most video
processors, deal with multiple video standards and fea-
tures, and scalable to process and provide variable num-
ber of input and output videos. Moreover, the proposed
architecture handles the challenges associated with si-
multaneous processing and takes into account the mixed-
signal considerations, since we deal with both analog
and digital video signals, as well as power distribu-
tion considerations. In Table 1, we compare the pro-
posed architecture with different previous architectures
for simultaneous processing of multiple video signals in
terms of the scalability of the architecture, the number
of input and output video signals, the independence of
the output video format from the input one, the video
standards that the architecture deal with, the ability to
process different spatial and temporal resolutions, and
the ability to handle the startup delay and the deviation
in the temporal resolution. This comparison motivated
us to design the proposed architecture as flexible to be
used for implementing various applications of simulta-
neous processing of multiple video signals.
As a case study, we use the proposed architecture
for a realization of a video processing system that per-
forms real time visible-near infrared video fusion [28].
Academically, this paper provides key guidelines for de-
signing a system that performs simultaneous process-
ing of multiple input videos to be a reference for re-
searchers who intend to design and implement such
systems. Upon publication, we make the source files
of the hardware design together with the bill of mate-
rial (BOM) of the case study available online (at the
authors website) for use by researchers in the field.
The rest of the paper is organized as follows. We
present the problems facing simultaneous multi-video
processing systems in Section 2. In Section 3, we present
the proposed flexible architecture. Section 4 presents
the considerations of analog/digital mixed-signals and
power distribution that we take into account in the
design of the proposed architecture. In Section 5, we
present a case study that utilizes the proposed flexible
architecture for realization of a video processing system
that performs real time visible-near infrared video fu-
sion. The experimental results of the implemented case
study are presented in Section 6. Finally, the paper is
concluded in Section 7.
2 Problems Affecting Simultaneous
Multi-Video Processing
There are two problems facing the simultaneous pro-
cessing of multiple input video signals. The first prob-
lem is the delay between the start of the corresponding
Flexible Architecture for Real-time Processing of Multiple Video Signals 3
(a)
(b)
Fig. 1 Waveforms of the four input interlaced NTSC video
signals. Figures (a) and (b) present waveforms of the same
signals captured at different time instances. Each video sig-
nal is formed as a stream of fields separated by vertical sync
portions.
frames from the input videos. The second problem is
that the frame rate for a video signal is not constant
over time which causes a time-varying deviation among
the frame rates of the multiple input video signals.
When the video signals are decoded, the two problems
also affect the produced digital formatted video sig-
nals. The mentioned problems are verified experimen-
tally for both analog and digital video signals by using
three Swann C510R color cameras [29], a Pioneer DVD-
V8000 player [30], a TVP5150 video decoder [31], and
a Keysight MSOS054A mixed signal oscilloscope [32].
The three cameras and the DVD player act as four
different and independent analog video sources that
provide interlaced NTSC video signals (all with frame
rates of approximately 30 fps). We separately discuss
the mentioned problems associated with simultaneous
multiple video processing in the following subsections.
2.1 Startup Delay
Practically speaking, the start of corresponding frames
in videos provided by different sources constitute in-
evitable delay. The delay occurs as the video signals
from different sources can not be started at exact time
(a)
(b)
Fig. 2 Digital synchronization clocks generated from two
TVP5150 video decoders, where each decoder takes a NTSC
video signal as an input. Figures (a) and (b) present the syn-
chronization clocks at different time instances.
Fig. 3 Measured frequencies of the two synchronization
clocks in Fig. 2. The minimum, mean and maximum frequen-
cies are measured using 300 samples for each clock.
without using a custom external hardware synchroniza-
tion signal. We conducted an experiment to verify the
delay problem. We powered on the three cameras and
the DVD player simultaneously and captured the four
analog NTSC video signals using the mixed signal os-
cilloscope. The waveforms of the four video signals were
captured, and we show two different time instance snap-
shots in Fig. 1 (a) and (b). Each video signal is formed
as a stream of fields separated by vertical sync por-
tions. As shown in Fig. 1 (a), the corresponding frames
(fields) of the four video signals do not start together
which is clarified form the vertical sync portions shown
in the figure.
2.2 Deviation of Frame Rates
The video generated from a video source has a small
variation of frame rate over time due to internal elec-
trical or mechanical hardware limitations of the video
source [13]. This small variation causes a time-varying
deviation among the frame rates of the multiple input
video signals. As shown in Fig. 1 (a) and (b), the time-
varying deviation of the frame rates causes the time dif-
ference among the starts of corresponding frames/fields
in the four video signals to be not constant over time.
4 Mohamed Awad et al.






	





	






	






	

	

	

 



!


!


!





 
 
 
 






Fig. 4 The proposed general architecture of multiple inputs/outputs simultaneous video processing system.
2.3 Deviation of Digital Clock Rates
To be suitable for processing, the input video signals
needed to be decoded into corresponding digital for-
matted video signals. Commonly, a video decoder sam-
ples an input along video signal using a synchronization
clock into the same number of digital samples for ev-
ery frame/field such that each sample is synchronized
with a clock edge. Because of the time-varying frame
rate of the input video signal, the video decoder uses a
genlock circuit to accurately tune the rate of the syn-
chronization clock such that the digital samples of a
frame/field are produced in the same time interval of
the corresponding input frame/filed [13]. When dealing
with multiple input videos, the time-varying synchro-
nization clock for every video poses a leading challenge
for simultaneous processing due to the lack of unique
clock. Furthermore, the startup delay problem is moved
to the decoded digitally formatted signals because the
input video signals are not simultaneously started as
we indicated previously.
We verify the above problems by decoding two in-
put analog NTSC video signals from two Swann C510R
cameras to a corresponding two BT.656 [14] digital video
signals using two TVP5150 video decoders [31]. The
video decoder typically produces 900900 samples per
frame along with a synchronization clock. We captured
the synchronization clocks of the two decoded video sig-
nals at two different time instances using the logic an-
alyzer embedded in the mixed signal oscilloscope and
plot them in Fig. 2 (a) and (b). We also measure the
rates of the two clocks as shown in Fig. 3, which displays
the min, max, and mean frequencies of every clock. As
shown in the figures, the clock rate of a digital video
is not constant over time and there is a clear deviation
among the rates of the clocks of the two digital videos.
3 Proposed Flexible Architecture of
Simultaneous Multi-Video Processing
In this paper, we are concerned with a simultaneous
multi-video processing system that accepts K input
video signals from different sources and provide pro-
cessed H output video signals. We propose a flexible
architecture that enables a video processor to perform
simultaneous processing of the multiple input video sig-
nals. The architecture takes the K inputs {V1, . . . , VK}
from different video sources, converts them to K dig-
itally formatted video signals {Vˆ1, . . . , VˆK} each with
startup delay di and a time-varying clock rate ci(t),
synchronizes the converted K signals to produce K syn-
chronized video signals {Vˆ S1 , . . . , Vˆ SK} that are ready for
processing by a video processor, and encodes the pro-
cessed video signals into H video outputs {U1, . . . , UH}.
Fig. 4 shows the proposed general architecture. As shown
in the figure, the proposed architecture consists of four
main stages: decoding, synchronization, processing, and
encoding which are presented next.
3.1 Video Decoding
The decoding stage contains all the decoders that are
used to convert the input video signals to digitally for-
mated form suitable for digital processing. As shown in
Fig. 4, the K input video signals are passed to corre-
sponding K video decoders. Each decoder takes an in-
put video signal Vi with a standard such as NTSC, PAL,
SECAM, DVI or HDMI, and produces an appropriate
n-bits digitally formated video Vˆi in a standard protocol
such as BT.656, BT.709, BT.2020 [14,33], along with a
synchronization clock ci(t). The control module shown
in Fig. 4 configures each video decoder according to the
standard of the input video and the required digital for-
mat of the converted output video through an interface
Flexible Architecture for Real-time Processing of Multiple Video Signals 5
such as serial bus protocol, e.g., inter-integrated circuit
I2C or serial peripheral interface SPI standards.
3.2 Video Synchronization
The K-digitally formatted video signals Vˆi produced
by the decoders are not suitable for simultaneous pro-
cessing since each video has different startup delay (di)
and a time-varying clock rate (ci(t)) as we presented
in Section 2. To synchronize the digital video signals,
we adopt a synchronization module that takes one of
the digital videos as a reference video and synchronizes
the rest K − 1 videos according to the clock rate of the
reference video. Without loss of generality, we present
the synchronization module below based on the usage
of Vˆ1 as the reference video.
As shown in Fig. 5, the synchronization module con-
sists of K frame start detectors (FSD) and K − 1 cir-
cular first-in-first-out (FIFO) buffers, each with a size
equal to the frame size of a digital video signal1. The ith
FIFO buffer holds one frame from the (i + 1)th digital
video signal such that the first pixel is saved at the first
location of the buffer and subsequent pixels are saved in
the subsequent locations. A video frame from a digital
video signal is written to a FIFO buffer using the clock
rate of that digital video signal such that one pixel is
written per clock. The writing of a frame is triggered by
the frame start which is detected by the corresponding
FSD. To ensure that the pixels at the same spatial posi-
tions output from the buffers at the same time, the read
operation is performed with same clock rate co(t) which
equal to the clock rate of the reference video (c1(t) in
this case as we use Vˆ1 as the reference video). Addition-
ally, the read operation is started simultaneously across
all buffers at the frame start of the reference video to
make sure that the synchronized signals have zero de-
lays.
Note that, the synchronization module guarantees
that individual pixels in the same spatial positions in
all buffers are delivered at the same time to the process-
ing module. However, these pixels are not necessary re-
lated to the same temporal frame. For instance, if co(t)
is the slowest clock rate among the clock rates of the
K videos, i.e., co(t) = min(ci(t);∀i ∈ {1, . . . ,K}), then
individual pixels in same spatial position in all buffers
are correspond to future frames with respect to the cor-
responding pixel (in the same spatial position) in the
buffer of the reference video. This temporal difference
between pixels does not have any impact on the de-
sired process of the proposed architecture because of
the temporal redundancy nature of the video signals.
1 We assume that the frame sizes of all videos are the same


	


	



 	











	



 	





























Fig. 5 General architecture of the synchronization module.
The inputs of the module are K different n-bits video signals
Vˆi, where i = 1, 2, ...,K, and their corresponding sampling
clocks ci(t). While, the outputs of the module are K synchro-
nized video signals Vˆ Si and all of them are sampled by the
same clock co(t).
Specifically, the current frame has a lot in common with
the next and former frames, so pixels at same spatial
positions across few temporal frames of a video are ap-
proximately similar.
3.3 Video Processing
In the processing stage, the video processor is used to
perform H desired functions on the K synchronized dig-
itally formatted video signals Vˆ Si and produce H pro-
cessed digital output videos. In general, the video pro-
cessor contains three main modules: interfacing, pro-
cessing and output formatter modules, as shown in Fig. 4.
The interface module decodes the digital video signal
into raw video data consisting of the pixel values inside
each frame along with the embedded horizontal and
vertical synchronization signals of the video. For ex-
ample, the BT.656 digitally formated video consists of
raw 4:2:2 YCbCr values with embedded horizontal and
vertical sync. The video processing module represents
mainly the core of the system, and it carries out the
implementation of the desired video processing appli-
cation on the input pixel values. The output formatter
is responsible for reformatting the processed raw video
data into a digital format, such as BT.656.
6 Mohamed Awad et al.
3.4 Video Encoding
The encoding stage contains all the encoders that are
used to convert the processed digital videos to appro-
priate video format in order to be displayed on the
desired displays as intended. As shown in Fig. 4, the
H-processed digital formatted video signals are passed
to H-video encoders. The clock needed to encode the
video outputs is the temporal clock co(t) selected from
the synchronization module. The control module shown
in Fig. 4 configures each video encoder according to the
standard protocol of the input digitally formated video
and the required format of the converted output video
through an interface such as serial bus protocol, e.g.,
inter-integrated circuit I2C or serial peripheral inter-
face SPI standards.
4 Design Considerations of The Proposed
Architecture
4.1 Mixed-Signal Design Considerations
The proposed flexible architecture in Fig. 4 shows the
existence of sensitive analog signals at the inputs of
the decoders, Vi, and the outputs of the encoders, Ui,
in addition to the existence of digital signals, such as
Vˆi and Vˆ
S
i , between the mentioned modules and the
video processor. Thus, the proposed architecture is con-
sidered as a mixed-signal system. There are two main
issues hindering performance of the mixed-signal sys-
tems. First, the analog signals are highly susceptible
to transient noise due to electromagnetic interference
(EMI) and crosstalk. Such noise is caused by the large
number of traces with different mechanical dimensions
covering large area, and thus might form a considerable
antenna effect [34]. The electromagnetic field passing
over a trace causes undesired stimulated electrical cur-
rent to flow in that trace. Second, digital signals are
noisy due to fast clock switching and therefore it may
inject considerable noise into the other analog signals
on the proposed architecture.
In order to design our architecture to comply with
mixed-signal considerations and to maintain high video
quality, we took into account two main principles of
electromagnetic compatibility (EMC) and EMI.
1. Currents should be returned to their sources over
the minimal possible loop area as locally and com-
pactly as possible, otherwise a loop antenna will be
created [35].
2. Only one reference plane should be included in the
system, otherwise a dipole antenna will be created
as a result of using two references [35].
We make our system less susceptible to EMI by re-
ducing the coupling and using decoupling filter capac-
itors. Additionally, proper grounding is used to divert
EMI away from the analog signals by providing low-
impedance path. Furthermore, we avoid parasitic an-
tenna structures by reducing loops of circulating cur-
rents.
Taking into consideration the aforementioned EMC
and EMI principles, we solved some of the mixed-signal
issues using the ground plane isolation. A ground plane
serves as the return path for currents from the different
modules besides reducing the EMI and crosstalk electri-
cal noise. As shown in Fig. 4, we split the ground plane
into two separated planes one for the analog signals
ground (AGND) and the other for the digital signals
ground (DGND) to keep the analog part away from the
digital switching effects. Splitting the ground plane was
not an easy choice because routing a trace over the split
would greatly increase the interference and crosstalk
noises [35]. Thus, modules placement and partitioning
were performed efficiently to avoid routing traces from
a ground plane to another as shown in Fig. 4. The de-
sign modularity facilitated partitioning of the proposed
architecture. Thus, the architecture was divided into
two parts. One contains all the traces that carry analog
signals and transfer them to and from the decoders and
encoders ICs. Similarly, the other part contains the con-
nectors of the video processor as well as all the traces
that carry digital signals and transfer them to and from
the decoders and encoders ICs. The only way to transfer
signals between the analog and digital planes is through
the mixed signals decoders and encoders ICs, not over
the split between the two different planes. According to
the aforementioned EMC and EMI principles, we tied
the two analog and digital ground planes together at a
single tie point for each decoder IC, to avoid generating
a dipole antenna due to the use of two ground planes.
4.2 Power Distribution Considerations
ICs of the video decoders and encoders require mostly
one or more of the three standard voltage levels which
are 1.8, 3.3 and 5 DC Volts either for analog or digital
parts. The analog DC voltages can be driven from an
external DC power supply, while the digital DC volt-
ages can be supplied from the video processor power
pins. A noisy power supply may considerably affect the
performance of the system because power is distributed
everywhere, thus power source noise will propagate all
over the circuit. Such noise source may be the external
power supply noise or the degradation of power driven
from different sources. In the design of the proposed ar-
chitecture, we isolated and reduced the effect of these
Flexible Architecture for Real-time Processing of Multiple Video Signals 7




 





	






	


	


	



	


	
Fig. 6 Power planes distribution in the proposed architecture with-respect-to the video decoders, encoders and the three
low-dropout (LDO) voltage regulators required for making the different voltages and power sources stable. The LDO voltage
regulator ICs are well placed to avoid crossing a power trace between two different power planes.
possible noises using appropriate strategies such as us-
ing voltage regulation, ferrite beads and power planes.
Such strategies enabled us to handle the errors that may
occur due to any of the aforementioned noise sources
during system operation.
The power lines/planes are responsible for transfer-
ring power from the external power sources to the load
devices. Each power line/plane contains noise in the
form of high frequency EMI and undesired power spikes.
Thus, we used a ferrite bead for each power line/plane
in order to isolate these noises from reaching the loaded
devices. Each ferrite bead is used with a couple of by-
pass capacitors to form a high frequency suppression
filter that reduces EMI. Additionally, the ferrite beads
withstand the sudden changes in the input current and
the unwanted power spikes and transients.
We used a low-dropout (LDO) linear voltage regu-
lator at each voltage source because the ICs, in general,
are very sensitive to any supply voltage variations. LDO
is a DC linear voltage regulator that can regulate the
output voltage even if the supply voltage is very close
to the output voltage. The performance of the ICs may
be affected if the supply voltage variation exceeds cer-
tain limits according to the datasheets of the ICs. Fur-
thermore, the output of a voltage source is not ideally
stable due to: (1) environmental conditions and (2) in-
terference with other different signals [36] that causes
an additive or subtractive noise to the voltage level. An
LDO voltage regulator provides a constant DC voltage
level independent on the amount of load current, so that
any change in the output of the voltage sources will be
isolated from the voltage supply pins of the ICs. The
dropout voltage of a regulator is the minimum differ-
ence between the input and output voltages, therefore
we preferred LDO over normal voltage regulators. As
shown in Fig. 6, at least three LDO voltage regulator
ICs are required for the proposed architecture. LDO(1)
takes the analog domain input DC voltage (AV1) from
external DC power supply and outputs regulated DC
voltage levels (AV2) necessary for the video decoders
within the required supply voltage variations. While,
LDO(2) and LDO(3) take digital domain DC voltage
(DV2) from the video processor and provide DC volt-
age levels (DV1) and (DV3) required for the video de-
coders and encoders, respectively. The required number
of LDOs is determined according to the maximum re-
quired load current Imax sufficient such that all the load
devices connected to each LDO work properly, and can
formulated as
Imax = I1 + I2 + ... + IL, (1)
where L is the number of load devices connected to an
LDO and I1, I2, ... , IL are the load currents for each
device requiring the LDO. If Imax exceeds the maxi-
mum current derive capability of the LDO, additional
LDOs should be added accordingly until the total out-
put current covers Imax.
For the supply voltage levels required to derive the
loads properly, we used split power planes, as shown
in Fig. 6. This is because using thin traces to transfer
power between the sources and different ICs in the ar-
chitecture may cause voltage drop in the levels of the
power signals due to the trace equivalent resistivity, be-
cause the area of a trace carrying a signal is inversely
proportional to the impedance of that trace. In other
words, a trace will resist the power that it carries, which
in turn may affect performance of the load devices that
expect certain power level delivered from the LDO volt-
age regulators [36]. The area of each used power plane
was as maximum as possible to provide a uniform dis-
tribution for all power signals and hence decrease the
chance of signal crossing to facilitate the routing be-
tween different modules. Fig. 6 shows how we carefully
partitioned the proposed architecture in the case study
that will be presented in Section 5. As shown in Fig. 6,
we carefully placed the different LDO voltage regulator
8 Mohamed Awad et al.
modules with-respect-to the video decoders, encoders
and video processor in order to avoid overlapping two
different power planes or having a trace crossing the
split between two different planes. There exist another
great advantage of having power planes at a dedicated
layer(s) as well as the ground planes at another dedi-
cated layer(s), based on the process used for fabrication.
This advantage is that any two facing areas of copper
pours create a large parallel plate decoupling capacitor
that prevents noise from being coupled from one circuit
to another through the power supply. Even though this
parasitic capacitor might impact the signal bandwidth,
but it is acceptable for such application.
5 Case-Study: Fusion Based Video
Enhancement
We present in this paper a case study that utilizes the
proposed flexible architecture for realization of a real
time visible-near infrared video fusion approach [28]2.
The fusion approach adaptively injects complementary
details from a near infrared (NIR) frame into the visible
(VS) one for the same scene in order to compensate for
missing details and obtain an enhanced visible image.
In the following subsections, we present detailed archi-
tecture and design considerations of the implemented
case study.
5.1 Case-Study Architecture
The main design requirements that we need to fulfill
for our case study are two video inputs (K = 2), one
video output (H = 1), three main DC supply voltage
levels of 1.8, 3.3 and 5 Volts for power requirements,
a video processor, and programmable decoder/encoder
ICs. We present the case study design in Fig. 7. The
inputs are two analog NTSC/PAL video signals con-
nected via two BNC sockets and the output is an analog
NTSC/PAL video signal. In this case study, we used an
FPGA device as a video processor in addition to imple-
ment the synchronization and control modules shown
in Fig. 4. Specifically, the FPGA is used for (a) im-
plementing the synchronization module (presented in
Sec. 3.2), (b) controlling the decoder/encoder ICs, and
(c) performing the actual processing (which is the video
2 The FPGA implementation of the fusion approach [28]
is proposed by some of the authors of this paper. Therefore,
this paper brings the previous work to real-time realization.
We modified the FPGA implementation in [28] to be suit-
able for video fusion, because the original implementation
was proposed for image fusion only. Details of the design and
the FPGA implementation of the video fusion is a subject of
another article contribution.
fusion in this case). We conclude the main tasks that
run on the FPGA device in Fig. 8. In the following, we
separately illustrate the main stages of the implemented
case study.
5.1.1 Video Decoding
We chose two TVP5150 low power video decoder ICs
from Texas Instruments [31] to convert the NTSC/PAL
analog video signals into ITU-R BT.656 digital video
format that consists of 8-bits 4:2:2 luminance-chrominance
(YCbCr) [37]. The decoders require an external 14.31818
MHz crystal oscillator (AS-14.31818-18-SMD) to gener-
ate the required sampling clock as shown in Fig. 7.
5.1.2 Video Synchronization
The two digital video streams provided by the decoders
are synchronized using the synchronization module pre-
sented in Sec. 3.2. We implement the synchronization
module using an FPGA device. The synchronization
module consists of three submodules: two frame start
detectors (FSD) and a single circular first-in-first-out
(FIFO) buffer of size 720 × 480 bytes (the size of one
BT.656 frame), as shown in Fig. 9. An FSD is used to
detect beginning of every frame from the input digital
stream. In the case study, we selected Vˆ1 as the refer-
ence video i.e, co(t) = c1(t) and we buffer Vˆ2. As shown
in Fig. 9, the FSD of Vˆ2 triggers the start of the writ-
ing operation to ensure that first location in the FIFO
contains the first pixel followed by the sequential pixels
of the current frame from Vˆ2. The FSD of Vˆ1 triggers
the start of the reading operations to ensure that the
first output pixel from the FIFO corresponds to the first
pixel of the current frame from Vˆ2. This provides a new
version of Vˆ2 but synchronized with Vˆ1 and both are
with the same clock rate of co(t).
The FSD is presented in Fig. 10. The FSD first de-
tects the start of active video (SAV) byte that occurs in
each line of the video at the start of the active pixels in
the line. This byte contains horizontal sync (H sync),
vertical sync (V sync) and field ID (F id) indicator bits.
The V sync bit has a value of 0 when the upcoming
bytes in the stream contain active pixels and has a value
of 1 when the upcoming bytes represent vertical blank-
ing. Therefore, a 1 to 0 transition in the V sync bit
indicates a start of a new frame. To detect the start of
a frame, the V sync bit is extracted from the SAV byte
using a V-sync-extractor block and passed to a falling-
edge-detector block to detect the start of a frame.
Flexible Architecture for Real-time Processing of Multiple Video Signals 9

	




	
	

	


	


	

  

 











	



	








	



	
	
	

	



 




Fig. 7 Overall architecture of the case-study implemented using the proposed video processing general architecture. The two
input video signals are entered via BNC connectors and converted from NTSC/PAL analog form to BT.656 8-bits digital video
steams using two TVP5150 decoders. The connected FPGA device then performs the required processing on the digital video
streams and provide the result to be converted into analog NTSC/PAL form using ADV7171 encoder and the output is exited
via a BNC connector. The programming of decoders and encoders is done by the FPGA device using I2C serial interfaces.
 	

	


  

	



 !
""

!"!
#

	

Fig. 8 Tree diagram of the main tasks running on the FPGA
device that is used in the case-study.


	


	



 	

























Fig. 9 Block diagram of the synchronization module. The
inputs of the module are two different 8-bits video streams,
Vˆ1 and Vˆ2, and their corresponding synchronization clocks,
c1 and c2. While, the outputs of the module are two synchro-
nized video streams, Vˆ S1 and Vˆ
S
2 , and one synchronization
clock co for both synchronized video streams.

	







 



 




	
Fig. 10 Block diagram of the frame start detector (FSD)
used in the synchronization module shown in Fig. 9.
5.1.3 Video Processing
In order to perform the video fusion application, we
selected the video processor to be an FPGA device be-
cause FPGA devices are suitable for embedded video
processing systems as they consist of registers and com-
putational logic units that can perform parallel, concur-
rent and pipelined operations [38]. The used FPGA de-
vice in the case study is the Altera Cyclone IV EP4CE22F17C6
FPGA device [39] mounted on the DE0-Nano board.
The FPGA device also is responsible for controlling the
functionality of the decoders and the encoder using I2C
serial interface as shown in Fig. 7. Note that, in our case
study, the decoded digital video signals are passed to
the FPGA using two connectors. Although the connec-
tors are compatible with the used FPGA kit, any other
kits can be connected to the proposed implementation
using different connectors.
5.1.4 Video Encoding
We chose the ADV7171 video encoder IC [40] to convert
the digital output from the FPGA device from ITU-R
BT.656 8-bits 4:2:2 YCbCr format to an NTSC/PAL
analog video signal in order to be displayed on a screen
via a BNC connector as shown in Fig. 7. The ADV7171
encoder also modulates the luminance and chrominance
(Y/C) components to generate the composite video sig-
nal. To operate properly, the encoder is fed by the ref-
erence clock that was selected by the synchronization
module (co(t)).
5.2 Design Considerations of The Case-Study
In the implementation of our case-study, each decoder
requires three different voltage levels which are analog
domain DC 1.8 V supplied via the analog power plane
and digital domain DC 1.8 and 3.3 V supplied via the
digital power plane. The encoder requires only digital
domain 5 V DC voltage. Fig. 11 shows the split power
planes for the required analog and digital domains volt-
age levels for the used ICs as recommended in Section 4.
10 Mohamed Awad et al.



  

                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   
                                                                                                                                                                   

	


	
 	
 	

                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             



                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             



                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             


Fig. 11 Power planes distribution in the implemented case-study. The LDO voltage regulator ICs are well placed to avoid
crossing a power trace between two different power planes.
An external DC power supply is used to provide the
analog domain DC voltage, while the digital domain DC
voltages are supplied from the 5 V DC output pin of the
FPGA kit as shown in Fig. 12. We choose two AP7312-
1833W6-7 LDO voltage regulators [41], for LDO 1 and
LDO 2, with 5 V input and two regulated outputs of
1.8 and 3.3 V as shown in Fig. 11 and Fig. 12. We also
choose an MCP1700T-5002T/TT three terminal LDO
voltage regulator [42] for LDO 3 with 5 V input and 5
V regulated output. Besides achieving the modularity,
we selected the aforementioned LDO voltage regulators
to accomplish scalability because the maximum current
derive capability for the AP7312 and MCP1700T LDOs
are 150 and 250 mA, respectively. On the other side,
the maximum load current of the used decoders and
encoder ICs are 32.9 and 37 mA, respectively [31, 40].
Thus using (1), a single AP7312 LDO can source cur-
rent to around 4 encoders, while a single MCP1700T
LDO can source current to around 6 decoders.
In order to achieve complete signal isolation, the
14.31818 MHz crystal oscillators and its associated traces
are kept with acceptable clearance of eight to ten times
the associated trace width from any adjacent analog sig-
nals specially the analog input video signals. This clear-
ance is employed to prevent the high frequency digital
switching clock from affecting the analog signals and it
is about ten times the width of the used traces [31]. We
used two crystal oscillators (AS-14.31818-18-SMD) in-
stead of only one to make the board partitioning easier,
besides using of only one crystal oscillator may cause
clock skew between the two video decoders.
6 Experimental Results
In this section, we present the realization of the fu-
sion based video enhancement system (case study) pre-
sented in Sec. 5. We use two analog cameras to feed the
fusion system with the visible and near-infrared video
signals. Two monitors are used to view the input visi-
Power Consumption Total
2× AP7312 45 mW
1.5695 W
2× TVP5150 230 mW
MCP1700 44.5 mW
ADV7171 1.25 W
Table 2 Power consumption values for the main devices of
the implemented system according to their corresponding
datasheets.
Power Consumption Total
Analog DC Supply 350 mW
1.85 W
Digital DC Supply 1.5 W
Table 3 Measured power consumption values for the input
voltage supplies of the implemented system.
ble video and the output fused enhanced video as shown
in Fig. 15 and Fig. 16. We design the schematics and
layout of the realization of our case study using AU-
TODESK EAGLE PCB design software [43]. Printed-
circuit-board (PCB) of the proposed system was im-
plemented using the following specifications: fill mate-
rial of FR-4 TGBO, dimension of (14.9 cm × 9.4 cm),
thickness of 1.6 mm, copper thickness of 1 oz, quali-
fication of 1pc class2-A600 with no special fabrication
requirements, and with two copper layers containing
all the video decoders, encoders, voltage regulators, in-
put/output and video processor kit connectors along
with all other supplementary components as shown in
Fig. 13. In Fig. 14, we present the implemented system
integrated with the DE0-Nano [39] FPGA kit.
The output video was provided in real-time at frame
rate of 30 fps for standard NTSC input videos. Table 2
presents the average power consumed by the main de-
vices of the proposed system: two AP7312 LDO regula-
tors, two TVP5150 video decoders, an MCP1700 LDO
regulator, and an ADV7171 video encoder. In Table 3,
we present the average power consumption measured at
both analog and digital voltage supplies to the proposed
system.
Flexible Architecture for Real-time Processing of Multiple Video Signals 11
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             

	








                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
                                                                                                                                                                    
	

                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             

	




                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             
                                                                                                             

	

	





	



 	



 

Fig. 12 The three low-dropout (LDO) voltage regulators used for making the different voltages and power sources stable.
LDO 1 accepts analog 5 V from the external power supply through a barrel jack connector and provides a fixed analog 1.8 V
to the two decoders. LDO 2 accepts digital 5 V from the FPGA board through the pin-headers connector and provides fixed
digital 1.8 and 3.3 V to the two decoders. Similarly, LDO 3 accepts digital 5 V, but it provides stable 5 V to the encoder.
(a)
(b)
Fig. 13 Printed-circuit-board (PCB) (a) top and (b) bottom
layers of the implemented dual-channel video processing sys-
tem.
7 Conclusion
In this paper, we propose a flexible architecture that
enables a video processor to perform simultaneous pro-
cessing of multiple input video signals. The architecture
takes K inputs from multiple video sources, converts
them to K digitally formatted video signals each with
different startup delay and time-varying clock rate, syn-
chronizes the converted K digital video signals to be
ready for processing by a video processor, and encodes
the processed video signals into H video outputs. The
Fig. 14 Structure of the implemented dual-channel video
processing system.

	




     
     
     
     
     
                   
                   
                   
                   
                   
	
	
     
     
     
     
     
                   
                   
                   
                   
                   
	
	
	
	


	
Fig. 15 Setup of the dual-channel real-time video processing
system.
Fig. 16 The complete dual-channel real-time video process-
ing system that performs the implementation in [28] of the
VS-NIR fusion based enhancement approach in [44].
proposed architecture has many advantages of being
compatible with most video processors, modular, up-
12 Mohamed Awad et al.
gradeable to deal with multiple video standards and
features, can be used for various video processing im-
plementations, scalable to process and provide variable
number of input and output videos, and takes into ac-
count all mixed-signal and power distribution consid-
erations. As a case study of the proposed architecture,
we utilize the proposed architecture for a realization of
a real time video fusion system that combines near in-
frared and visible video sources to produce an enhanced
video. The fusion system produces output video in real-
time at frame rate of 30 fps for standard NTSC input
videos.
References
1. M.M. Fouad, H.A. Aly, Adv. Electr. Electron. Eng. 14(2),
196 (2016)
2. M.W. Park, G.H. Park, IEEE Trans. Consum. Electron.
58(2), 535 (2012). DOI 10.1109/TCE.2012.6227458
3. I. Ahmad, IEEE Distrib. Syst. Online 8(3), 6 (2007). DOI
10.1109/MDSO.2007.13
4. A.S. Elliethy, H.A. Aly, G. Sharma, in Proc. SPIE Stereo-
scopic Displays and Applications, vol. 9011 (2014), vol.
9011, p. 90111U. DOI 10.1117/12.2040837
5. R. Van Krevelen, R. Poelman, Int. J. of Virtual Reality
9(2), 1 (2010)
6. C. Ancuti, C.O. Ancuti, T. Haber, P. Bekaert, in Proc.
IEEE Conf. Computer Vision Pattern Recognition (2012),
pp. 81–88. DOI 10.1109/CVPR.2012.6247661
7. E.P. Bennett, J.L. Mason, L. McMillan, IEEE Trans. Im-
age Process. 16(5), 1185 (2007)
8. X. Guo, X. Wei, Y. Liu, in Proc. IEEE Int. Congress
on Image and Signal Process. Biomed. Eng. and Informat.
(2017), pp. 1–6. DOI 10.1109/CISP-BMEI.2017.8301926
9. D.P. Cheney, L.D. Curley, W.R. Lee, L.D. Richardson,
R.S. Svec. Integrated video processing system hav-
ing multiple video sources and implementing picture-in-
picture with on-screen display graphics (2003)
10. S. Yamazaki. Method and device for processing multiple
video signals (1991)
11. M.A. Ogrinc, R.A. Card, C.R. Burns, C.P. Clarke, R.L.
Collier, K.M. Collins, S.E. Crane, C. Hersh, B.C. Knit-
tel, S.T. Mayer, et al. Real time video image processing
system (1995)
12. D. Tian, F. Zou, A. Vetro. Method and system for pro-
cessing multiview videos for view synthesis using motion
vector predictor list (2014)
13. K. Jack, Video demystified: a handbook for the digital engi-
neer, 4th edn. (Elsevier, 2004)
14. Radiocommunication Sector of ITU. BT.656: Interface
for digital component video signals in 525-line and 625-
line television systems operating at the 4:2:2 level of rec-
ommendation ITU-R BT.601. BT Series, Broadcasting
service (television) (2007)
15. M.M. El-Hashash, H.A. Aly, J. of Real-Time Image Pro-
cess. 16(4), 1117 (2019). DOI 10.1007/s11554-016-0603-1
16. A.A. Khalifa, H.A. Aly, Opt. Eng. 54(12), 123102 (2015)
17. A.G. Khodary, H.A. Aly, in Proc. IEEE Global Conf.
Signal and Inf. Process. (2014), pp. 703–706. DOI
10.1109/GlobalSIP.2014.7032209
18. C. Desmouliers, S. Aslan, E. Oruklu, J. Saniie, F.M. Val-
lina, in Proc. IEEE Int. Conf. Electro Inf. Technol. (2010),
pp. 1–6. DOI 10.1109/EIT.2010.5612173
19. Y. Said, T. Saidani, F. Smach, M. Atri, H. Snoussi, in
Proc. Int. Conf. on Image and Signal Process. (2012), pp.
85–92
20. L. Touil, L. Kechiche, B. Ouni, Int. J. of Embedded Syst.
and Appl. 4(1) (2014)
21. F.J. Toledo, J.J. Martinez, J.M. Ferrandez, in Proc. 3rd
Southern Conf. on Programmable Logic (2007), pp. 171–
176. DOI 10.1109/SPL.2007.371743
22. J.G. Pandey, A. Karmakar, C. Shekhar, in Proc. IEEE
Int. Conf. Devices, Circuits Syst. (2012), pp. 191–194. DOI
10.1109/ICDCSyst.2012.6188702
23. J. Muller, J. Muller, R. Tetzlaff, in Proc. IEEE Int. Work-
shop Cellular Nanosc. Netw. Appl. (2014), pp. 1–2. DOI
10.1109/CNNA.2014.6888618
24. R.J. Taylor. Video processing system (1979)
25. S.W. Fu, H.P. Sit, S. Ahmad, S.L. Honey, A. Ullal, J.L.
Edwards. Video processing system (2010)
26. T. Beckwith. Video processing system (1995)
27. J. Bennett, J. Karaoguz. Video processing system with
simultaneous multiple outputs each with unique formats
(2006)
28. M. Awad, A. Elliethy, H.A. Aly, in Proc. IEEE Int. Conf.
Image Processing (2018), pp. 3968–3972. DOI 10.1109/
ICIP.2018.8451602
29. Swann, Professional CCTV Camera C-510R With Infra-
Red. URL https://www.manualslib.com/manual/869833/
Swann-C510r.html
30. Pioneer, DVD-V8000 Reference Level Professional DVD
Player (2008). URL https://www.pioneerelectronics.
com/PUSA/Professional/Pro-Video/DVD-V8000
31. Texas Instruments, Ultralow-Power NTSC/PAL/SECAM
Video Decoder TVP5150AM1 (2013)
32. Keysight, MSOS054A High-Definition Oscillo-
scope: 500 MHz, 4 Analog plus 16 Digital Chan-
nels (2019). URL https://www.keysight.com/en/
pdx-x202074-pn-MSOS054A/
33. M. Nilsson, BT Media and Broadcast Research Paper
(2015)
34. N.L. Eastman, in The 1996 IEEE Wescon Conf. (1996),
pp. 297–301. DOI 10.1109/WESCON.1996.554004
35. H.W. Ott, Printed Circuit Design Mag. 18(6), 8 (2001)
36. D. Brooks, Printed Circuit Design Mag., CMP Media
publication (2000)
37. BT.656: Interface for digital component video signals in
525-line and 625-line television systems operating at the
4:2:2 level of recommendation ITU-R BT.601. https:
//www.itu.int/rec/R-REC-BT.656/en (2007). Accessed:
2019-04-28
38. M.B. Gokhale, P.S. Graham, Reconfigurable computing:
Accelerating computation with field-programmable gate ar-
rays, 1st edn. (Springer US, NM, U.S.A., 2005)
39. Terasic, DE0-Nano Development and Education Board
(2012). URL https://www.terasic.com.tw/cgi-bin/page/
archive.pl?No=593
40. Analog Devices, Digital PAL/NTSC Video Encoder
with 10-Bit SSAF and Advanced Power Management
ADV7170/ADV7171 (2008). URL http://www.analog.
com/en/products/adv7171.html
41. Diodes Inc., Dual 150mA low quiescent current fast
transient low dropout linear regulator AP7312-1833W6-
7 (2011). URL https://www.diodes.com/products/
power-management/low-dropout-regulators/part/AP7312
42. Microchip Inc., Low quiescent current LDO MCP1700T-
5002T/TT (2013). URL https://www.microchip.com/
wwwproducts/en/MCP1700
43. Eagle cadsoft PCB design software. Autodesk. URL
https://www.autodesk.com/products/eagle
Flexible Architecture for Real-time Processing of Multiple Video Signals 13
44. A. Elliethy, H. Aly, in Proc. IEEE Global Conf. Signal and
Inf. Process. (2017), pp. 156–160
