BACKGROUND OF THE INVENTION
[0001] The present invention relates to a document acknowledge system, more particularly,
to horizontal/vertical-run length smoothing algorithm circuit in which a horizontal-run
length smoothing algorithm (H-RLSA) and a vertical run length smoothing algorithm
(V-RLSA) are performed by hardware and a document region divide circuit for dividing
a document region in which the smoothed data is logical-produced by hardware.
[0002] Conventionally, the document acknowledge system scans a document horizontally to
store horizontal data, and then scans the document vertically to store vertical data.
Then, the system performs a horizontal-run length smoothing algorithm process. By
this process, while only binary data "1" succeeded above a predetermined number of
times is maintained naturally, binary data "1" not succeeded above the predetermined
number of times is canceled. For example, provided that the system scans the document,
so that it stores the horizontal data "0001111000111111", and a threshold value is
"5", the smoothed data "0000000000111111" is obtained, since only binary data "1"
succeeded above 5 times is maintained naturally and binary data "1" not succeeded
above 5 times is reset into binary data "0" by the horizontal-run length smoothing
algorithm process.
[0003] Then, the document acknowledge system performs a vertical-run length smoothing algorithm
process. Similarly, by this process, while only binary data "1" succeeded above a
predetermined number of times is maintained naturally, binary data "1" not succeeded
above the predetermined number of times is canceled. The smoothed data obtained from
these processes then are divided by block unit. These divided results allow the document
text and graphic region to be divided in accordance with height and width of the block.
[0004] However, in the above-mentioned coventional document acknowledge system, the horizontal-run
length smoothing algorithm and vertical-run length smoothing algorithm are processed
by software executed by a mircroprocessor and the smoothed data also is logical-produced
by the software. Thus, the microprocessor in the system can be loaded with too much
works, causing its efficiency to be reduced and its process to be run slowly.
SUMMARY OF THE INVENTION
[0005] Therefore, an object of the present invention is to provide a horizontal-run length
smoothing algorithm circuit for smoothing horizontal data not with software executed
by a microprocessor, but with hardware, the horizontal data stored by scanning a document
horizontally.
[0006] Another object of the present invention is to provide a vertical-run length smoothing
algorithm circuit for smoothing vertical data not with software executed by a microprocessor,
but with hardware, the vertical data stored by scanning the document vertically.
[0007] Still another object of the present invention is to provide a document region divide
circuit for dividing a document region in which the smoothed data is logical-produced
by hardware.
[0008] In accordance with the present invention, these objects can be accomplished by providing
a document acknowledge system comprising: a horizontal-run length smoothing algorithm
circuit comprising an address generating counter for counting a system clock signal
φ₁ to output the counted value as an address signal, a horizontal-run length smoothing
algorithm (H-RLSA) memory for storing horizontal data and inputting the address signal
from the address generating counter, a count control unit for applying the system
clock signal φ₁ as a count clock signal and applying low voltage data to the H-RLSA
memory, at write state of the H-RLSA memory and for comparating read data with a reference
signal B⁺ to apply the system clock signal φ₁ as the count clock signal when the read
data and the reference signal B⁺ are the same and to output a comparison enable signal
at initial state of the period that the read data and the reference signal B⁺ are
not the same, at read state of the H-RLSA memory, a read/write control unit for counting
up/down the system clock signal φ₁ outputted from the count control unit in accordance
with the read/write states of the H-RLSA memory and comparating the counted value
with a horizontal threshold value in response to the comparison enable signal when
the comparison enable signal is outputted from the count control unit to output read/write
control signals in response to the comparated results, and a write address setting
unit for subtracting the counted value from the read/write control unit from the output
address value from the address generating counter and then loading the substracted
value into the address generating counter, at initial state of period that the write
control signal is outputted from the read/write control unit;
[0009] a vertical-run length smoothing algorithm circuit comprising a start address setting
unit for storing number of horizontal pixels as an offset value and number of vertical
pixels, generating a carry signal as many as the number of vertical pixels whenever
the read operation is completed, loading with and outputting a start address value,
and incrementing the start address value whenever the carry signal is generated to
output the next vertical column of the start address value, a system clock supplying
unit for supplying a system clock signal φ₁ until the carry signal is generated as
much as the offset value after the start address value is outputted from the start
address setting unit, an address generating counter responsive to the system clock
signal φ₁ for loading with the start address value from the start address setting
unit and outputting an address signal, a vertical-run length smoothing algorithm (V-RLSA)
memory for storing vertical data and inputting the address signal from the address
generating counter, resulting in being accessed, a count control unit for applying
the system clock signal φ₁ as a count clock signal and applying low voltage data to
the V-RLSA memory, at write state of the V-RLSA memory and for comparating read data
with a reference signal B⁺ to apply the system clock signal φ₁ as the count clock
signal when the read data and the reference signal B⁺ are the same and the output
a comparison enable signal at initial state of the period that the read data and the
reference signal B⁺ are not the same, at read state of the V-RLSA memory, a read/write
control unit for counting up/down the system clock signal φ₁ outputted from the count
control unit in accordance with the read/write states of the V-RLSA memory and comparating
the counted value with a horizontal threshold value in response to the comparison
enable signal when the comparison enable signal is outputted from the count control
unit to output read/write control signals in response to the comparated results, and
an address resetting unit for adding the offset value from the start address setting
unit to the address signal value from the address generating counter and then loading
the added value into the address generating counter in response to the system clock
signal φ₁, multiplying the offset value from the start address setting unit by the
counted value from the read/write control unit and then subtracting the multiplied
value from the address signal value from the address generating counter, and loading
the remaining value into the address generating counter at initial state of the period
that the write control signal is outputted from the read/write control unit; and
[0010] a document region divide circuit comprising a horizontal-run length smoothing algorithm
(H-RLSA) circuit, a vertical-run length smoothing algorithm (V-RLSA) circuit, a system
clock and address supplying unit for supplying a system clock signal φ₁ in response
to an end signal ES of the V-RLSA circuit, counting the system clock signal φ₁ to
output the counted value as horizontal/vertical address signals, and stopping supplying
the system clock signal φ₁ when the system clock signal φ₁ was outputted thereform
a predetermined number of times, an address and read/write selecting unit responsive
to the end signal ES of the V-RLSA circuit for selecting any one of the horizontal
address signal of the H-RLSA circuit, the vertical address signal of the V-RLSA circuit
and the counted value from the system clock and address supplying unit to output the
selected signal as horizontal/vertical address signals, selecting one of horizontal
read/write control signals R/W of the H-RLSA circuit and the system clock signal φ₁
to output the selected signal as the horizontal read/write control signals, and selecting
one of vertical read/write control signals R/W of the V-RLSA circuit and the end signal
ES of the V-RLSA circuit to output the selected signal as the vertical read/write
control signals, a horizontal-run length smoothing algorithm (H-RLSA) memory accessed
by the horizontal address signal from the address and read/write selecting unit and
responsive to the horizontal read/write control signals for operating at read/write
states, a vertical-run length smoothing algorithm (V-RLSA) memory accessed by the
vertical address signal from the address and read/write selecting unit operating at
read/write states, an AND gate for ANDing output data from the H-RLSA memory and V-RLSA
memory by bit unit, and a buffer for allowing an output signal from the AND gate to
be passed therethough during a half cycle of the system clock signal φ₁ to apply the
output signal from the AND gate as write data to the H-RLSA memory.
BRIEF DESCRIPTION OF THE DRAWINGS
[0011] The above and other objects, features and advantages of the present invention will
be more clearly understood from the following detailed description taken in conjunction
with the accompanying drawings, in which:
Fig. 1 is a block diagram of a horizontal-run length smoothing algorithm circuit of
the present invention;
Fig. 2 is a block diagram of a vertical-run length smoothing algorithm circuit of
the present invention;
Fig. 3A and 3B illustrate tables of the original pixel data and the smoothed pixel
data by the present invention, respectively;
Fig. 4 illustrates a map of a V-RLSA memory shown in Fig. 2;
Fig. 5 is a flowchart of operation of the circuit shown in Fig. 2;
Fig. 6 is a block diagram of a document region divide circuit of the present invention;
Figs. 7A to 7F are waveform diagrams of respective outputs from components of the
circuit shown in Fig. 6; and
Figs. 8A to 8C illustrate the pixel data of a H-RLSA memory and the V-RLSA memory
of the circuit shown in Fig. 6 and the ANDed data of pixel data of the H-RLSA memory
and the V-RLSA memory, respectively.
DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS
[0012] Fig. 1 is a block diagram of a horizontal-run length smoothing algorithm circuit
of the present invention. As shown in the drawing, the horizontal-run length smoothing
algorithm circuit comprises an address generating counter 110 for counting a system
clock signal φ₁ to output the counted value as an address signal, a horizontal-run
length smoothing algorithm (H-RLSA) memory 120 for storing horizontal data and inputting
the address signal from the address generating counter 110, a count control unit 130
for applying the system clock signal φ₁ as a count clock signal and applying low voltage
data to the H-RLSA memory 120, at write state of the H-RLSA memory 120 and for comparating
read data with a reference signal B⁺ to apply the system clock signal φ₁ as the count
clock signal when the read data and the reference signal B⁺ are the same and to output
a comparison enable signal at initial state of the period that the read data and the
reference signal B⁺ are not the same, at read state of the H-RLSA memory 120, a read/write
control unit 140 for counting up/down the system clock signal φ₁ outputted from the
count control unit 130 in accordance with the read/write states of the H-RLSA memory
120 and comparating the counted value with a horizontal threshold value when the comparison
enable signal is outputted from the count control unit 130 to output read/write control
signals in response to the comparated results, and a write address setting unit 150
for substracting the counted value from the read/write control unit 140 from the output
address value from the address generating counter 110 and then loading the substracted
value into the address generating counter 110, at initial state of period that the
write control signal is outputted from the read/write control unit 140.
[0013] The count control unit 130 comprises a buffer 131 for applying low voltage data to
the H-RLSA memory 120 at write state of the H-RLSA memory 120, a comparator 132 for
comparating the read data with the reference signal B⁺ at read state of the H-RLSA
memory 120, an inverter 133 for inverting an output signal from one output terminal
(A=B) of the comparator 132, an OR gate 134 for ORing an output signal from the inverter
133 and the system clock signal φ₁, an OR gate 135 for ORing the read/write control
signals from the read/write control unit 140 to the H-RLSA memory 120 and the system
clock signal φ₁, an AND gate 136 for ANDing output signals from the OR gates 134 and
135 to apply the ANDed signal as the count clock signal, and a mono-multivibrator
137 responsive to a output signal from the other terminal (A<B) of the comparator
132 for outputting the comparison enable pulse signal.
[0014] Also, the read/write control unit 140 comprises an up/down counter 141 for counting
up/down the system clock signal φ₁ outputted from the count control unit 130 in accordance
with the read/write states of the H-RLSA memory 120, a threshold setting unit 142
for setting the horizontal threshold value, a comparator 143 for comparating the counted
value from the up/down counter 141 with the horizontal threshold value from the threshold
setting unit 142 when the comparison enable signal is outputted from the count control
unit 130, an inverter 144 for inverting a carry signal from the up/down counter 141,
a flip-flop 145 responsive to an output signal from the inverter 144 for outputting
the read control signal and responsive to an output signal from one output terminal
(A<B) of the comparator 143 for outputting the write control signal, and mono-multivibrator
146 responsive to an output signal from the other terminal (A≧B) of the comparator
143 for generating a pulse signal to apply the pulse signal as a clear signal to the
up/down counter 141.
[0015] Also, the write address setting unit 150 comprises a latch 151 responsive to the
write control signal from the read/write control unit 140 for latching the address
signal from the address generating counter 110, a subtracter 152 responsive to the
write control signal from the read/write control unit 140 for subtracting the counted
value from the read/write control unit 140 from an output signal from the latch 151
to apply the subtracted value as load data to the address generating counter 110,
and a mono-multivibrator 153 responsive to the write control signal from the read/write
control unit 140 for generating a pulse signal to apply the pulse signal as a load
control signal to the address generating count 110.
[0016] Fig. 2 is a block diagram of a vertical-run length smoothing algorithm circuit of
the present invention. As shown in the drawing, the vertical-run length smoothing
algorithm circuit comprises a start address setting unit 210 for storing number of
horizontal pixels as an offset value and number of vertical pixels, generating a carry
signal as many as the number of vertical pixels whenever the read operation is completed,
loading with and outputting a start address value, and incrementing the start address
value whenever the carry signal is generated to output the next vertical column of
the start address value, a system clock supplying unit 220 for supplying a system
clock signal φ₁ until the carry signal is generated as much as the offset value after
the start address value is outputted from the start address setting unit 210, an address
generating counter 230 responsive to the system clock signal φ₁ for loading with the
start address value from the start address setting unit 210 and outputting an address
signal, a vertical-run length smoothing algorithm (V-RLSA) memory 240 for storing
vertical data and inputting the address signal from the address generating counter
230, resulting in being accessed, a count control unit 250 for applying the system
clock signal φ₁ as a count clock signal and applying low voltage data of the V-RLSA
memory 240, at write state of the V-RLSA memory 240 and for comparating read data
with a reference signal B⁺ to apply the system clock signal φ₁ as the count clock
signal when the read data and the reference signal B⁺ are the same and to output a
comparison enable signal at initial state of the period that the read data and the
reference signal B⁺ are not the same, at read state of the V-RLSA memory 240, a read/write
control unit 260 for counting up/down the system clock signal φ₁ outputted from the
count control unit 250 in accordance with the read/write states of the V/RLSA memory
240 and comparating the counted value with a horizontal threshold value when the comparison
enable signal is outputted from the count control unit 250 to output read/write control
signals in response to the comparated results, and an address rasetting unit 270 for
adding the offset value from the start address setting unit 210 to the address signal
value from the address generating counter 230 counter 230 in response to the system
clock signal φ₁, multiplying the offset value from the start address setting unit
210 by the counted value from the read/write control unit 260 and then subtracting
the multiplied value from the address signal value from the address generating counter
230, and loading the remaining value into the address generating counter 230 at initial
state of the period that the write control signal is outputted from the read/write
control unit 260.
[0017] The start address setting unit 210 comprises a latch 211 responsive to a horizontal
control signal IO₁ for latching the number of horizontal pixels as the offset value,
a latch 213 responsive to a vertical control signal IO₃ for latching the number of
vertical pixels, an AND gate 218 responsive to the read control signal from the read/write
control unit 260 for allowing the system clock signal φ₁ to be passed therethrough,
a down counter 215 for inputting an output signal from the latch 213 as a load signal
and counting down an output signal from the AND gate 218 to generate the carry signal,
a buffer 217 responsive to the read control signal from the read/write control unit
260 for allowing the carry signal from the down counter 215 to be passed therethrough,
an AND gate 216 for ANDing output signal from the buffer 217 and the vertical control
signal IO₃ to apply the ANDed signal as a load control signal to the down counter
215, an up counter 212 for loading with the start address value in response to a start
control signal IO₂ and counting up the carry signal from the down counter 215, and
a buffer 214 responsive to an output signal from the AND gate 216 for allowing an
output signal from the up counter 212 to be passed therethrough.
[0018] Also, the system clock supplying unit 220 comprises a flip-flop 223 for inputting
the vertical control signal IO₃ as a clock signal to output a high voltage signal,
and AND gate 225 for ANDing the high voltage signal from the flip-flop 223 and a reference
clock signal φ to output the ANDed signal as the system clock signal φ₁, an up counter
224 for counting up the carry signal from the start address setting unit 210, a comparator
221 for comparating the counted value from the up counter 224 with the offset value
from the start address setting unit 210, and a mono-multivibrator 222 responsive to
an output signal from the terminal (A=B) of the comparator 221 for generating a pulse
signal to apply the pulse signal as a clear signal to the flip-flop 223.
[0019] Also, the count control unit 250 comprises a buffer 251 for applying low voltage
data to the V-RLSA memory 240 at write state of the V-RLSA memory 240, a comparator
252 for comparating the read data with the reference signal B⁺ at read state of the
V-RLSA memory 240, an AND gate 253 for ANDing the output signal from the one output
terminal (A=B) of the comparator 252 and the system clock signal φ₁, a selector 254
for selecting one of an output signal from the AND gate 253 and the system clock signal
φ₁ in accordance with the read/write states of the V-RLSA memory 240 to apply the
selected signal as the count clock signal, and a mono-multivibrator 255 responsive
to an output signal from the other terminal (A<B) of the comparator 252 for generating
a pulse signal to apply the pulse signal as the comparison enable signal.
[0020] The read/write control unit 260 comprises an up/down counter 261 for counting up/down
the system clock signal φ₁ outputted from the count control unit 250 in accordance
with the read/write states of the V-RLSA memory 240, a threshold setting unit 264
for setting the vertical threshold value, an AND gate 262 for ANDing the comparison
enable signal from the count control unit 250 and the carry signal from the start
address setting unit 210, a comparator 263 enabled by an output signal from the AND
gate 262 for comparating the counted value from the up/down counter 261 with the vertical
threshold value from the threshold setting unit 264, a mono-multivibrator 266 responsive
to an output signal from one output terminal (A≧B) of the comparator 263 for outputting
a pulse signal, AND gate 267 for ANDing the pulse signal from the mono-multivibrator
266 and the carry signal from the up/down counter 261 to apply the ANDed signal as
a clear signal to the up/down counter 261, an AND gate 265 for ANDing the carry signal
from the up/down counter 261 and a reset signal RST, and a flip-flop 268 responsive
to an output signal from the AND gate 265 for outputting the read control signal and
responsive to an output signal from the other output terminal (A<B) of the comparator
263 for outputting the write control signal.
[0021] Also, the address resetting unit 270 comprises an adder 271 for adding the offset
value from the start address setting unit 210 to the address signal value from the
address generating counter 230, a multiplier 272 for multiplying the offset value
by the counted value from the read/write control unit 260, a subtracter 273 for subtracting
an output signal value of the multiplier 272 from the address signal value of the
address generating counter 230, a mono-multivibrator 274 responsive to the write control
signal from the read/write control unit 260 for generating a pulse signal, an inverter
275 for inverting an output enable signal from the start address setting unit 210,
an inverter 276 for inverting the pulse signal from the mono-multivibrator 274, an
OR gate 277 for ORing output signals from the inverters 275 and 276 and the system
clock signal φ₁, a buffer 278 responsive to an output signal from the OR gate 277
for allowing an output signal from the adder 271 to be passed therethrough to apply
the output signal from the adder 271 as a load signal to the address generating counter
230, and a buffer 279 responsive to the pulse signal from the mono-multivibrator 274
for allowing an output signal from the subtracter 273 to be passed therethrough to
apply the output signal from the subtracter 273 as a load signal to the address generating
counter 230.
[0022] Figs. 3A and 3B illustrate tables of the original pixel data of the V-RLSA memory
240 and the smoothed pixel data by the present invention in the case that the vertical
threshold value is 3, respectively.
[0023] Fig. 4 illustrates a map of a V-RLSA memory 240 shown in Fig. 2 and Fig. 5 is a flowchart
of operation of the vertical-run length smoothing algorithm circuit shown in Fig.
2.
[0024] Fig. 6 is a block diagram of a document region divide circuit of the present invention.
As shown in the drawing, the document region divide circuit comprises a horizontal-run
length smoothing algorithm (H-RLSA) circuit 100, a vertical-run length smoothing algorithm
(V-RLSA) circuit 200, a system clock and address supplying unit 310 for supplying
a system clock signal φ₁ in response to an end signal ES of the V-RLSA circuit 200,
counting the system clock signal φ₁ to output the counted value as horizontal/vertical
address signals, and stopping supplying the system clock signal φ₁ when the system
clock signal φ₁ was outputted therefrom a predetermined number of times, an address
and read/write selecting unit 320 responsive to the end signal ES of the V-RLSA circuit
200 for selecting any one of the horizontal address signal of the H-RLSA circuit 100,
the vertical address signal of the V-RLSA circuit 200 and the counted value from the
system clock and address supplying unit 310 to output the selected signal as horizontal/vertical
address signals, selecting one of horizontal read/write control signals R/W of the
H-RLSA circuit 100 and the system clock signal φ₁ to output the selected signal as
the horizontal read/write control signals, and selecting one of vertical read/write
control signals R/W of the V-RLSA circuit 200 and the end signal ES of the V-RLSA
circuit 200 to output the selected signal as the vertical read/write control signals,
a horizontal-run length smoothing algorithm (H-RLSA) memory 120 accessed by the horizontal
address signal from the address and read/write selecting unit 320 and responsive to
the horizontal read/write control signals for operating at read/write states, a vertical-run
length smoothing algorithm (V-RLSA) memory 240 accessed by the vertical address signal
from the address and read/write selecting unit 320 and responsive to the vertical
read/write control signals for operating at read/write states, an AND gate 330 for
ANDing output data from the H-RLSA memory 120 and V-RLSA memory 240 by bit unit, and
a buffer 340 for allowing an output signal from the AND gate 330 to be passed therethrough
during a half cycle of the system clock signal φ₁ to apply the output signal from
the AND gate 330 as write data to the H-RLSA memory 120.
[0025] The system clock and address supplying unit 310 comprises an OR gate 311 for ORing
the end signal ES of the V-RLSA circuit 200 and a reference clock signal φ, a flip-flop
312 for inputting an output signal from the OR gate 311 as a clock signal to output
the output signal from the OR gate 311 as the system clock signal φ₁, an up counter
313 for counting up the system clock signal φ₁, to output the counted value as the
horizontal/vertical address signals, and a down counter for counting down the system
clock signal φ₁, a predetermined number of times to generate a carry signal to apply
the carry signal as a clear signal to the flip-flop 312.
[0026] Also, the address and read/write selecting unit 320 comprises an inverter 312 for
inverting the end signal ES of the V-RLSA circuit 200, a selector 322 responsive to
the end signal ES of the V-RLSA circuit 200 for selecting one of the horizontal address
signal of the H-RLSA circuit 100 and counted value from the system clock and address
supplying unit 310 to output the selected signal as the horizontal address signal,
a selector 323 responsive to the end signal ES of the V-RLSA circuit 200 for selecting
one of the vertical address signal of the V-RLSA circuit 200 and the counted value
from the system clock and address supplying unit 310 to output the selected signal
as vertical address signal, a selector 324 responsive to the end signal ES of the
V-RLSA circuit 200 for selecting one of horizontal read/write control signals R/W
of the H-RLSA circuit 100 and the system clock signal φ₁ to output the selected signal
as the horizontal read/write control signals, and a selector responsive to the end
signal ES of the V-RLSA circuit 200 for selecting one of vertical read/write control
signals R/W of the V-RLSA circuit 200 and an output signal of the inverter 321 to
output the selected signal as the vertical read/write control signals.
[0027] Figs. 7A to 7F are waveform diagrams of respective outputs from components of the
document region divide circuit shown in Fig. 6; and
[0028] Figs. 8A to 8C illustrate the pixel data of the H-RLSA memory 120 and the V-RLSA
memory 240 of the document region divide circuit shown in Fig. 6 and the ANDed data
of pixel data of the H-RLSA memory 120 and the V-RLSA memory 240, respectively.
[0029] Now, operations of the horizontal/vertical-run length smoothing algorithm circuit
and the document region divide circuit in accordance with the present invention will
be described more detailed.
[0030] In operation, at initial state of powering on, the up/down counter 141 indicated
in FIG. 1 generates at the carry terminal (RC) a carry signal of high voltage which
is in turn inverted by the inverter 144 into a low voltage signal, and then applied
as a present signal to the flip-flop 145. Therefore, the flip-flop 145 outputs a read
control signal of high voltage, thus the H-RLSA memory 120 enters a read state, simultaneously
the buffer 131 enters a cut-off state. Also, the comparator 132 enters an enable state,
simultaneously the latch 151 and the subtracter 152 enter disable states, so that
the mono-multivibrator 153 can not output any pulse signal. In this case, the up/down
counter 141 functions as an up counter.
[0031] Accordingly, the address generating counter 110 counts the system clock signal φ₁
in order to address the locations of the H-RLSA memory 120, sequentially. Also, the
data stored in the addressed location of the H-RLSA memory 120 is read out, the read
out data is in turn applied to the input terminal A of the comparator 132 in order
to be compared with the reference signal B⁺ applied to the other input terminal (B).
At this time, if the data applied to the other input terminal (A) of the comparator
132 is the same high voltage data as that of the reference signal B⁺, a low voltage
signal is outputted from the output terminal (A<B) of the comparator 132, also a high
voltage signal is outputted from the other output terminal (A=B) thereof. The high
voltage signal outputted from the output terminal (A=B) is inverted by the inverter
133 into a low voltage signal which is in turn applied to an input terminal of the
OR gate 134, so that the system clock signal φ₁ is applied to an input terminal of
the AND gate 136 through the OR gate 134. At this time, a high voltage signal outputted
from the flip-flop 145 is also applied to the other input terminal of the AND gate
136 through the OR gate 135, so that the system clock signal φ₁ is applied as a count
clock signal to the up/down counter 141 through the AND gate 136. Accordingly, the
up/down counter 141 counts up the system clock signal φ₁.
[0032] As above described, the address generating counter 110 counts the system clock signal
φ₁ in order to sequentially address the locations of the H-RLSA memory 120, and then
if the data stored in the addressed location of the H-RLSA memory 120 is the same
high voltage data as that of the reference signal B⁺, the up/down counter 141 counts
up the system clock signal φ₁. It is therefore known that the up/down counter 141
counts up the times of the data of high voltage read out from the H-RLSA memory 120.
[0033] On the other hand, if the data stored in the addressed location of the H-RLSA memory
120 is a low voltage data different from the reference signal B⁺, the output signals
from the comparator 132 are inverted so that the low voltage signal is outputted from
the other output terminal (A=B) and the high voltage signal is outputted from the
output terminal (A<B). Also, at initial output state of the high voltage signal from
the output terminal (A<B), a low voltage pulse signal is outputted from the mono-multivibrator
137 which is in turn applied to the comparator 143 as a comparison enable signal.
Thereafter, the comparator 143 compares the counted value from the up/down counter
141 with the horizontal threshold value from the threshold setting unit 142, and then
outputs the comparing result signal at its output terminal (A<B). For example, if
the threshold value is "3", and the counted value from the up/down counter 141 exceeds
"3", the comparator 143 outputs a low voltage signal at its output terminal (A<B),
and a high voltage signal at its other output terminal (A≧B). In initial output state
of the high voltage signal from the output terminal (A≧B), a low voltage pulse signal
is outputted from the mono-multivibrator 146 in order to clear the up/down counter
141, so that the counted value of "O" can be obtained from the counter 141, also the
carry signal is outputted.
[0034] If the data read out from the H-RLSA memory 120 is a low voltage data different from
that of the reference signal B⁺, the output signals of the comparator 132 maintains
the previous state, so that the low voltage signal will be outputted from the other
output terminal (A=B), and the high voltage signal will be outputted from the output
terminal (A<B). Thereafter, the low voltage signal outputted from the other output
terminal (A=B) is inverted by the inverter 133 into a high voltage signal which is
in turn applied to the input terminal of the OR gate 134. Accordingly, the OR gate
134 outputs a high voltage signal at its output terminal, and the OR gate 135 also
outputs a high voltage signal, so that the AND gate 136 continuously outputs a high
voltage signal, resulting in maintaining the counted value from the up/down counter
141 at "O".
[0035] On the other hand, when the threshold value is "3", and the counted value from the
up/down counter 141 is below "3", the comparator 143 enters an enable state. Accordingly,
the comparator 143 outputs a high voltage signal at its output terminal (A<B), and
a low voltage signal at its output terminal (A≧B), also the flip-flop 145, to which
the high voltage signal outputted at the output terminal (A<B) is applied as a clock
signal, outputs a low voltage signal of the write control signal. The H-RLSA memory
120 enters the write state by the low voltage write control signal, simultaneously
the buffer 131 is turned on, so that a low voltage data is applied to the H-RLSA memory
120. At this time, the comparator 132 enters a disable state, resulting in maintaining
its previous output state, and then the latch 151 enters an enable state, the subtracter
152 also enters an enable state. Accordingly, the address signal value outputted from
the address generating counter 110 is latched by the latch 151, thereafter the latched
value from the latch 151 and the counted value from the up/down counter 141 are subtracted
by the subtracter 152. The subtracted value from the subtracter 152 is applied to
the address generating counter 110 as a load signal, also in initial output state
of the low voltage signal from the flip-flop 145, the low voltage pulse signal from
the mono-multivibrator 153 is applied to the address generating counter 110 as a load
control signal, thus the load signal from the subtracter 152 is loaded into the address
generating counter 110, thereafter outputted from the address generating counter 110
in response to the system clock signal φ₁ in order to address the locations of the
H-RLSA memory 120. The addressed location of the H-RLSA memory 120 is a first addressed
location of high voltage, so that the data of low voltage from the buffer 131 is written
into.
[0036] At this time, the up/down counter 141 enters a down-count state by the low voltage
signal which is previously outputted from the flip-flop 145, and in turn applied to
an input terminal of the OR gate 135. Also, the system clock signal φ₁ is applied
as a count clock signal to the up/down counter 141 by way of the OR gate 135 and the
AND gate 136. Therefore, the up/down counter 141 counts down the system clock signal
φ₁ in order to decrement the counted value.
[0037] Thereafter, when the system clock signal φ₁ is again applied to the address generating
counter 110 which counts the system clock signal φ₁, and then addresses the second
location of the H-RLSA memory 120. Therefore, a low voltage data can be written into
the addressed location of the H-RLSA memory 120, also the up/down counter 141 can
count down.
[0038] Consequently, when the counted value from the up/down counter 141 is "O", the up/down
counter 141 can output a high voltage carry signal which is in turn inverted, by the
inverter 144, into a low voltage signal in order to present the flip-flop 145. Thereafter,
the flip-flop 145 can output a high voltage read signal in order that the read operation
can be again carried out.
[0039] Thus, the horizontal-run length smoothing algorithm process is carried out by sequentially
reading out the data in the location of the H-RLSA memory 120 corresponding to the
each of addresses incremented by "1" at a time, and the maintaining the data when
the data is a low voltage data or a high voltage data of a times succeeded above a
predetermined number of times of the threshold value from the threshold setting unit
142, and writing the data, after inverting the data into a low voltage data, into
the H-RLSA memory 120 when the data is a high voltage data of a times succeeded below
a predetermined number of times of the threshold value from the threshold setting
unit 142.
[0040] On the other hand, at initial vertical-run length smoothing algorithm process, the
reset pulse signal (RST) of low voltage is applied to the AND gate 265 shown in FIG.
2, therefore the AND gate 265 outputs a low voltage signal in order to present the
flip-flop 268, the flip-flop 268 can thus output a high voltage read control signal.
Consequently, by the high voltage read control signal, the V-RLSA memory 240 enters
a read state, simultaneously the buffer 251 enters a cut off state, also the comparator
252 enters an enable state. At this time, the selector 254 selects and outputs an
output signal, also the up/down counter 261 functions as an up counter.
[0041] Also, the number of pixels to be horizontally accessed by the horizontal control
signal IO₁ are latched by the latch 211, and then outputted from the latch 211. Furthermore,
the start address signal by the start control signal IO₂ is loaded into the up counter
212, and then outputted from the up counter 212. The number of pixels to be vertically
accessed by the vertical control signal IO₃ of low voltage pulse are also latched
by the latch 213, and then outputted from the latch 213.
[0042] When the vertical control signal IO₃ of low voltage pulse is applied to the AND gate
216, the AND gate 216 outputs a low voltage pulse signal which is in turn applied
to the down counter 215 as a load control signal. Therefore, the number of vertically
directed pixels outputted from the latch 213 are loaded into the down counter 215,
also a low voltage pulse signal outputted from the AND gate 216 is applied to the
buffer 214 as a output enable signal. Thus the start address signal outputted from
the up counter 212 is applied to the address generating counter 230 by way of the
buffer 214, simultaneously the low voltage pulse signal outputted from the AND gate
216 is applied to the buffer 278 by way of the OR gate 277 after being inverted into
a high voltage signal by the inverter 275. Therefore, the buffer 278 enters an output
disable state, and the buffer 279 also enters an output disable state because the
mono-multivibrator 274 outputs a high voltage signal.
[0043] Also, the vertical control signal IO₃ of low voltage pulse is applied to the flip-flop
223 as a clock signal, so that the flip-flop 223 outputs a high voltage signal which
is in turn applied to an input terminal of the AND gate 225. Simultaneously, the reference
clock signal O is supplied as a system clock signal O₁ by way of the AND gate 225.
Therefore, the start address signal outputted from the buffer 214 is loaded into the
address generating counter 230 during low voltage period, and then outputted from
the address generating counter 230 in order to address the location of the V-RLSA
memory 240 corresponding to the start address.
[0044] If the start address loaded into the up counter 212 is set as "1", the location of
the V-RLSA memory 240 corresponding to the start address "1" is addressed, therefore
the data stored in the location corresponding to the start address "1" will be read
out. Also, in this case, the other conditions are supposed to be set as the pixel
data of the V-RLSA memory 240 is as indicated in FIG. 3A, and the map of theV-RLSA
memory 240 is as indicated in FIG. 4, also the offset value of the number of horizontal
pixels latched by the latch 211 is "8", furthermore the number of the vertical pixels
latched by the latch 213 is "9".
[0045] Therefore, the data read out at the location corresponding to the start address "1"
will be the same high voltage data as that of the reference signal B⁺, so that the
comparator 252 outputs a high voltage signal at its output terminal (A=B), and a low
voltage signal at the other output terminal (A<B). Also, the high voltage signal outputted
from the terminal (A=B) is applied to the input terminal of the AND gate 253 in order
that the system clock signal O₁ is applied to the input terminal of the selector 254
through the AND gate 253. At this time, the selector 254 selects the input terminal
(A) for inputting the system clock signal φ₁ applied to the input terminal (A) is
appiled to the up/down counter 261 as a count clock signal. Therefore, the up/down
counter 261 counts up the system clock signal φ₁, and then the counted value "1" can
be obtained.
[0046] Also, the high voltage signal outputted from the flip-flop 268 is applied to an input
terminal of the AND gate 218, so that the system clock signal φ₁ is applied to the
down counter 215 through the AND gate 218 as a count clock signal, and the counted
value by the down counter 215 is "8".
[0047] Also, the start address value "1" outputted from the address generating counter 230
is added, by the adder 271, to the offset value "8" of the latch 211 in order to be
the added value "9", and in turn applied to the buffer 278 which thereafter enters
an output enable state resulting from outputting the low voltage signal from the OR
gate 277 during the low voltage period of the system clock signal φ₁. The output signal
"9" from the adder 271 is loaded into the address generating counter 230 through the
buffer 278, and the loaded signal then addresses the location of the V-RLSA memory
240 corresponding to the address "9" which is the second address of the first column
of the V-RLSA memory 240. Therefore, the data stored in the address "9" is read out.
At this time, if the data is high voltage data as indicated in FIG. 3A, the comparator
252 outputs a high voltage signal at its output terminal (A=B), and a low voltage
signal at its other output terminal (A<B). Therefore, as above described, the counted
value by the up/down counter 261 which counts up the system clock signal φ₁ will be
"2". Also, the counted value by the down counter 215 which counts down the system
clock signal φ₁ will be "7".
[0048] As above described, the address "9" outputted from the address generating counter
230 is address, by the adder 171, to the offset value "8" of the latch 271 in order
to be the added value "17", in turn loaded into the address generating counter 230
through the buffer 278. Thereafter, the loaded signal addresses the location of the
V-RLSA memory 240 corresponding to the address "17" which is the third address of
the first column of the V-RLSA memory 240. Thus the data stored in the location of
the V-RLSA memory 240 corresponding to the address "17" is read out. At this time
if the data is a low voltage as indicated in FIG. 3A, the data is different from the
reference signl B⁺. Therefore, the output signals from the comparator 252 are inverted,
so that the low voltage signal is outputted at the output terminal (A=B), and the
high voltage signal is outputted at the other output terminal (A<B). Thus, the system
clock signal φ₁ can not pass through the AND gate 253, so that the counted value by
the up/down counter 261 will be maintained at the value "2" because the system clock
signal can not be applied to the up/down counter 261. Also, at initial output state
of the high voltage signal from the other output terminal (A<B) of the comparator
252, the multivibrator 255 outputs a low voltage pulse signal, resulting in a low
voltage pulse signal output from the AND gate 262. The low voltage pulse signal from
the AND gate 262 is in turn applied to the comparator 263 as a comparison enable signal.
Therefore, the comparator 263 enters an enable state, so that the counted value from
the up/down counter 261 is compared with the vertical threshold value from the threshold
setting unit 264. At this time, if the counted value from the up/down counter 261
exceeds the threshold value from the threshold setting unit 264, the comparator 263
will output a high voltage signal at its output terminal (A≧B), and a low voltage
signal at its other output terminal (A<B). Also, if the counted value from the up/down
counter 261 is below the threshold value from the threshold setting unit 264, the
comparator 263 will output a high voltage signal at the other output terminal (A<B),
and a low voltage signal at the output terminal (A≧B).
[0049] For example, if the threshold value from the threshold setting unit 264 is "3", and
the counted value from the up/down counter 261 is "2", the comparator 263 will output
a high voltage signal at the other output terminal (A<B), and a low voltage signal
at the output terminal (A≧B). The high voltage signal outputted from the other output
terminal (A<B) of the comparator 263 is applied to the flip-flop 268 as a clock signal,
so that the flip-flop 268 outputs a write control signal of low voltage by which the
system clock signal φ₁ can not pass through the AND gate 218. Therefore the system
clock signal φ₁ can not be applied to the down counter 215, simultaneously the V-RLSA
memory 240 enters a write state by the low voltage signal, and the buffer enters an
enable state. Thus the low voltage signal is applied to the V-RLSA memory 240, and
the comparator 252 enters a disable state, also the selector 254 selects and outputs
the system clock signal φ₁ which is previously applied to the input terminal (B) thereof.
At this time, the up/down counter 261 functions as a down counter.
[0050] At initial state of the period that a low voltage signal is outputted from the flip-flop
268, the mono-multivibrator 274 also outputs a low voltage signal by which the buffer
279 enters its output enable state, thereby causing the output signal from the subtracter
273 to be applied to the address generating counter 261. At this time, the multiplier
272 multiplies the counted value "2" from the up/down counter 261 by the offset value
"8" from the latch 211 to obtain the product "16" which in turn is subtracted from
the address value "17" of the address generating counter 230 by the subtracter 273.
As a result, the subtracter 273 outputs a "1" value signal. At this time, the low
voltage pulse signal outputted from the mono-multivibrator 274 is inverted into a
high voltage signal by the inverter 276. This high voltage signal is applied via the
OR gate 277 to the buffer 273, thereby causing the buffer 273 to enter its output
disenable state. Accordingly, "1" value output signal from the subtracter 273 is loaded
into the address generating counted 230 via the buffer 279, so that the location of
the V-RLSA memory 240 corresponding to the address "1" which is the start address
of the V-RLSA memory 240 is addressed. Then, the low voltage signal outputted from
the buffer 251 is written into the location corresponding to the address "1".
[0051] On the other hand, the system clock signal φ₁ is applied via the selector 254 to
the up/down counter 261 which in turn counts down said signal, so that the counted
value "1" can be obtained.
[0052] Thereafter, a "9" value signal outputted from the address 217 is loaded into the
address generating counter 230 via the buffer 278, so that the location of the V-RLSA
memory 240 corresponding to address "9" which is the second address of the first column
of the V-RLSA memory 240 is addressed. As a result, a low voltage signal is written
into the location corresponding to the address "9".
[0053] At this time, the up/down counter 261 counts down again the system clock signal φ₁
as mentioned above, thereby the counted value thereof to be "O" and a low voltage
carry signal to be outputted. By the low voltage signal, the AND gate 267 outputs
a low voltage signal which clears the up/down counter 261. Also, the AND gate 265
outputs a low voltage signal which presets the flip-flop 268. As a result, the flip-flop
268 outputs a high voltage signal as a read control signal. Thus, a read operation
will be carried out, as mentioned above.
[0054] That is, locations of the V-RLSA memory 240 are sequentially addressed. The addressing
starts at the location corresponding to the address "17". Data read out from the addressed
locations is at low voltage state, as shown in the table of Fig. 3A, so that the output
signal from the comparator 252 is maintained at the previous state in which low voltage
signal is outputted from the output terminal (A=B) and high voltage signal is outputted
from the output terminal (A<B). As a result, no system clock signal φ₁ is applied
to the up/down counter 261, thereby causing the up/down counter 261 to maintain the
counted value "O". At this time, the system clock signal φ₁ is applied via the AND
gate 218 to the down counter 215 which in turn counts down said signal φ₁, thereby
causing the counted value thereof to be "6".
[0055] When data read out from the sequentially-addressed locations of the first column
of the V-RLSA memory 240 is maintained at low voltage state, the up/down counter 261
maintains continuously the counted value "O" and the down counter 215 counts down
by "1" at a time.
[0056] On the other hand, when data read out from the sequentially-addressed locations of
the first column of the V-RLSA memory 240 is maintained at high voltage state, output
signal from the comparator 252 is inverted. Thereby, the comparator 252 is maintained
at a state that the output terminal (A=B) thereof to output a high voltage signal
and the output terminal (A<B) thereof to output a low voltage signal. As a result,
system clock signal φ₁ is applied to the up/down counter 261, thereby the up/down
counter 216 to count up from "O", by "1" at a time and the down counter 215 to count
down by "1" at a time.
[0057] After data has been read out from all (that is, "9") locations corresponding to addresses
of the first column of the V-RLSA 240, the counted value from the down counter 215
is "O", thereby causing the down counter 215 to output a low voltage carry signal.
By this low voltage signal, the AND gate 262 output a low voltage signal which enables
the comparator 263. As a result, the comparator 263 compares the counted value from
the up/down counter 261 with the vertical threshold value from the threshold setting
unit 264. At this time, when the counted value from the up/down counter 261 is "4"
as high voltage state of data is continued 4 times, as shown in the table of Fig.
3A, the comparator 263 outputs a low voltage signal at the output terminal (A<B) thereof
and a high voltage signal at the output terminal (A≧B) thereof. At initial state of
the period that this high voltage signal is outputted, the mono-multivibrator 266
outputs a low voltage pulse signal, thereby causing the AND gate 267 to output a low
voltage signal which clears the up/down counter 261.
[0058] The low voltage carry signal outputted from the down counter 215 is also applied
as a clock signal to the up counter 212, thereby causing the counted value from the
up counter 212 to be incremented by "1". That is, the output signal from the up counter
212 has "2" value. The low voltage carry signal is also applied via the buffer 217
to the AND gate 216, thereby causing the AND gate 216 to output a low voltage signal.
As a result, "9" value, the number of vertical pixels latched by the latch 213 is
loaded into the down counter 215, on the other hand, "2" value of the output signal
from the up counter 212 is loaded into the address generating counter 230 via the
buffer 214, so that the location of the V-RLSA memory 240 corresponding to address
"2" which is the first address of the second column of the V-RLSA memory 240 is addressed.
Subsequent operations are carried out in the same manner as mentioned above.
[0059] On the other hand, the low voltage carry signal outputted from the down counter 215
is also applied as a clock signal to the up counter 224 which in turn counts up said
clock signal. The counted value from the up counter 224 is compared with "8" value,
the offset value from the latch 211, by the comparator 221. When the counted value
from the up counter 224 is "8" value as processing for all columns of the V-RLSA 240
has been carried out, the comparator 221 outputs a high voltage signal at the output
terminal (A=B) thereof. At initial state of the period that this high voltage signal
is outputted, the mono-multivibrator 222 outputs a low voltage pulse signal which
is in turn applied as clock signal to the flip-flop 223. As a result, the flip-flop
223 outputs low voltage signal which is in turn applied to one input terminal of the
AND gate 225, so that reference clock signal φ can not pass through the AND gate 225,
thereby causing the AND gate 225 to input no system clock signal φ₁. Thus, the above
operation will be finished.
[0060] As apparent from the flowchart of Fig. 5, pixel data is read out from the addressed
locations of the V-RLSA memory 240, in order to determine its voltage state. When
pixel data is at high voltage state, the counted value from the up/down counter 261
is incremented by "1". Then, a location corresponding to the value obtained by adding
the offset value from the latch 211 to the current address value is addressed, so
that next pixel data is read out. If this pixel data is at low voltage and the previous
pixel data is also at low voltage, next pixel data is read out, under the condition
that the counted value of the up/down counter 261 maintains "O" value. On the other
hand, when only the previous pixel data is at high voltage, the counted value from
the up/down counter 261 is compared with the vertical threshold value from the threshold
setting unit 264. If the counted value from the up/down counter 261 is not less than
the vertical threshold value, next pixel data is read out, under the condition that
the counted value from the up/down counter 261 maintains "O" value. If the counted
value from the up/down counter 261 is less than the vertical threshold value, the
counted value from the up/down counter 261 is multipiled by the offset value from
the latch 211. Then, the product is subtracted from the current address value, so
that a location of the V-RLSA memory 240 corresponding to the obtained value is addressed.
After pixel data read out from the location is maintained at low voltage state, the
counted value of the up/down counter 261 is decremented by "1". Then, when the counted
value from the up/down counter 261 is not "O", the offset value from the latch 211
is added to the current address value, so that next location of the V-RLSA memory
240 corresponding to the obtained value is addressed. Thereafter, subsequent operations
for maintaining pixel data at low voltage state are repeatedly carried out. When the
counted value from the up/down counter 261 is "O", next location of the V-RLSA memory
240 is addressed and next pixel is read out from said addressed location, as mentioned
above.
[0061] By the above operations, vertical pixel data shown in Fig. 3A is smoothed as shown
in Fig. 3B.
[0062] On the other hand, logical combination of pixel data processed by vertical/horizontal-run
length smoothing algorithm processes is carried out by a circuit shown in Fig. 6.
[0063] During the period that a horizontal-run length smoothing algorithm process is carried
out by the H-RLSA circuit 100, the V-RLSA circuit 200 does not output a low voltage
end signal ES, that is, outputs a high voltage signal. As a result, the OR gate 311
outputs continuously high voltage signal, irrespective of reference clock signal φ,
thereby causing the flip-flop 312 to output no system clock signal φ₁.
[0064] By the high voltage signal, each of selectors 322 to 325 selects a signal which is
inputted to its input terminal A and in turn outputs it.
[0065] Accordingly, address signal outputted from the H-RLSA circuit 100 is applied via
the selector 322 to the H-RLSA memory 120, so that a location of the H-RLSA memory
120 corresponding to the address signal is addressed. On the other hand, read/write
control signals R/W outputted from the H-RLSA circuit 100 are applied via the selector
324 to the H-RLSA memory 120, thereby causing read and write operations of the H-RLSA
memory 120 to be controlled.
[0066] During the period that a vertical-run length smoothing algorithm process is carried
out by the V-RLSA circuit 200, address signal outputted from the V-RLSA circuit 200
is applied via the selector 323 to the V-RLSA memory 240, so that a location of the
V-RLSA memory 240 corresponding to the address signal is addressed. Also, read/write
control signals R/W outputted from the V-RLSA circuit 200 are applied via the selector
325 to the V-RLSA memory 240, thereby causing read and write operations of the V-RLSA
memory 240 to be controlled.
[0067] On the other hand, when the vertical-run length smoothing algorithm process is completed,
the V-RLSA circuit 200 outputs low voltage end signal ES. This low voltage end signal
ES is applied to one input terminal of the OR gate 311, so that reference clock signal
O is applied via the OR gate 311 to the flip-flop 312 as a clock signal. As a result,
the flip-flop 312 outputs system clock signal O₁ which is in turn applied to the down
dounter 314 and the up counter 313 as a count clock signal. The system clock signal
O₁ is also applied to the input terminal (B) of the selector 324 and the output enable
terminal (OE) of the buffer 340.
[0068] By the low voltage end signal ES, each of selectors 322 to 325 selects a signal which
is inputted to its input terminal B and outputs it. The low voltage end signal ES
is inverted into a high voltage signal and in turn applied to the input terminal (B)
of the selector 324. Accordingly, the up counter 313 counts system clock signal φ₁
as shown in Fig. 7B and outputs the counted signal to the H-RLSA memory 120 and the
V-RLSA memory 240 via the selectors 322 to 323, respectively. As a result, locations
of the H-RLSA memory 120 and the V-RLSA memory 240 corresponding to the counted value
are sequentially addressed. At this time, the system clock signal φ₁ is applied via
the selector 324 to read/write control signals as shown in Fig. 7C, thereby causing
the H-RLSA memory 120 to be at its read state during the high voltage period of the
system clock signal φ₁ and at its write state during the low voltage period of the
system clock signal φ₁. On the other hand, the high voltage signal applied to the
input terminal (B) of the selector 325 is applied to the V-RLSA memory 240 as a read
control signal, as shown in FIG. 7D, thereby causing the V-RLSA memory 240 to be maintained
at its read state.
[0069] As locations of the H-RLSA memory 120 and the V-RLSA memory 240 corresponding to
the same counted value of the up counter 313 are addressed as stated above, the data
of the addressed location of the H-RLSA memory 120 is read out during the high voltage
period of the system clock signal φ₁ and the data of the addressed location of the
V-RLSA memory 240 is directly read out, such data which are read out from the addressed
locations of the H-RLSA memory 120 and the V-RLSA memory 240 corresponding to the
same counting value are ANDed by bit unit at the AND gate 330 and are applied to the
buffer 340.
[0070] On the other hand, the system clock signal φ₁ is applied to the buffer 340 as output
enable control signal shown in Fig. 7E, sequentially as the buffer 340 enters the
output enable state during the low voltage period of the system clock signal φ₁, thus
the data which is inputted into the buffer 340 is outputted as shown in Fig. 7F. At
this time, as the H-RLSA memory 120 enters write state when the system clock signal
φ₁ is low voltage signal, the data which is outputted from the buffer 340 is written
into the addressed location of the H-RLSA memory 120. Namely, the pixel data of the
H-RLSA memory 120 shown in Fig. 8A and the pixel data of the V-RLSA memory 240 shown
in Fig. 8B are ANDed and written into the H-RLSA memory 120 as shown in Fig. 8C. On
the other hand, the down counter 314 counts down the system clock signal φ₁, accordingly
when the system clock signal φ₁ of the predetermined number of times which is required
to complete the performance of the above ANDed combination is outputted, the low voltage
carry signal is outputted from the down counter 314 to clear the flip-flop 312, and
then no system clock signal φ₁ is outputted, thereby the above operation can be completed.
[0071] As previously stated above, in accordance with the present invention, the horizontal/vertical-run
length smoothing algorithm processes are performed directly by a hardware not by a
microprocessor's program, and the data which is performed by the horizontal/vertical-run
length smoothing algorithm processes is logical-program. Therefore, the document acknowledge
system of the present invention performs tasks much faster than the prior arts do
and increases the using efficiency of microprocessors by reducing tasks thereof.
[0072] While preferred embodiments of the present invention have been illustrated, it will
be understood that those are by way of illustration only, and that various changes
and modifications may be made within the contemplation of the invention and within
the scope of the claims.
1. A document acknowledge system having a horizontal-run length smoothing algorithm circuit
comprising:
an address generating counter for counting a system clock signal to output the
counted value as an address signal,
a horizontal-run length smoothing algorithm (H-RLSA) memory for storing horizontal
data and inputting the address signal from said address generating counter,
a count control unit for applying the system clock signal as a count clock signal
and applying low voltage data to said H-RLSA memory, at write state of said H-RLSA
memory and for comparating read data with a reference signal to apply the system clock
signal as the count clock signal when the read data and the reference signal are the
same and to output a comparison enable signal at initial state of the period that
the read data and the reference signal are not the same, at read state of said H-RLSA
memory,
a read/write control unit for counting up/down the system clock signal outputted
from said count control unit in accordance with the read/write states of said H-RLSA
memory and comparating the counted value with a horizontal threshold value in response
to the comparison enable signal when the comparison enable signal is outputted from
said count control unit to output read/write control signals in response to the comparated
results, and
a write address setting unit for subtracting the counted value from said read/write
control unit from the output address value from said address generating counter and
then loading the subtracted value into said address generating counter, at initial
state of period that the write control signal is outputted from said read/write control
unit.
2. The system in accordance with Claim 1, wherein said count control unit comprises a
buffer for applying low voltage data to said H-RLSA memory at write state of said
H-RLSA memory, a comparator for comparating the read data with the reference signal
at read state of said H-RLSA memory, an inverter for invering an output signal from
one output terminal (A=B) of said comparator, an OR gate for ORing an output signal
from said inverter and the system clock signal, an OR gate for ORing the read/write
control signals from said read/write control unit to said H-RLSA memory and the system
clock signal, an AND gate for ANDing output signals from said OR gates to apply the
ANDed signal as the count clock signal, and a mono-multivibrator responsive to a output
signal from the other terminal (A<B) of said comparator for outputting the comparison
enable pulse signal.
3. The system in accordance with Claim 1, wherein said read/write control unit comprises
an up/down counter for counting up/down the system clock signal outputted from said
count control unit in accordance with the read/write states of said H-RLSA memory,
a threshold setting unit for setting the horizontal threshold value, a comparator
for comparating the counted value from said up/down counter with the horizontal threshold
value from said threshold setting unit in response to the comparison enable signal
when the comparison enable signal is outputted from said count control unit, an inverter
for invering a carry signal from said up/down counter, a flip-flop responsive to an
output signal from said inverter for outputting the read control signal and responsive
to an output signal from one ouput terminal (A<B) of said comparator for outputting
the write control signal, and a mono-multivibrator responsive to an output signal
from the other terminal (A≧B) of said comparator for generating a pulse signal to
apply the pulse signal as a clear signal to said up/down counter.
4. The system in accordance with Claim 1, wherein said write address setting unit comprises
a latch responsive to the write control signal from said read/write control unit for
latching the address signal from said address generating counter, a subtracter responsive
to the write control signal from said read/write control unit for subtracting the
counted value from said read/write control unit from an output signal from said latch
to apply the subtracted value as load data to said address generating counter, and
a mono-multivibrator responsive to the write control signal from said read/write control
unit for generating a pulse signal to aply the pulse signal as a load control signal
to said address generating counter.
5. A document acknowledge system having a vertical-run length smoothing algorithm circuit
comprising:
a start address setting unit for storing number of horizontal pixels as an offset
value and number of vertical pixels, generating a carry signal as many as the number
of vertical pixels whenever read operation is completed, loading with and outputting
a start address value, and incrementing the start address value whenever the carry
signal is generated to output the next vertical column of the start address value,
a system clock supplying unit for supplying a system clock signal until the carry
signal is generated as much as the offset value after the start address value is outputted
from said start address setting unit,
an address generating counter responsive to the system clock signal for loading
with the start address value from said start address setting unit and outputting an
address signal,
a vertical-run length smoothing algorithm (V-RLSA) memory for storing vertical
data and inputting the address signal from said address generating counter, resulting
in being accessed,
a count control unit for applying the system clock signal as a count clock signal
and applying low voltage data to said V-RLSA memory, at write state of said V-RLSA
memory and for comparating read data with a reference signal to apply the system clock
signal as the count clock signal when the read data and the reference signal are the
same and to output a comparison enable signal at initial state of the period that
the read data and the reference signal are not the same, at read state of said V-RLSA
memory,
a read/write control unit for counting up/down the system clock signal outputted
from said count control unit in accordance with the read/write states of said V-RLSA
memory and comparating the counted value with a horizontal threshold value in response
to the comparison enable signal when the comparison enable signal is outputted from
said count control unit to output read/write control signals in response to the comparated
results, and
an address resetting unit for adding the offset value from said start address setting
unit to the address signal value from said address generating counter and then loading
the added value into said address generating counter in response to the system clock
signal, multiplying the offset value from said start address setting unit by the counted
value from said read/write control unit and then subtracting the multiplied value
from the address signal value of said address generating counter, and loading the
remaining value into said address generating counter at initial state of the period
that the write control signal is outputted from said read/write control unit.
6. The system in accordance with Claim 5, wherein said start address setting unit comprises
a latch responsive to a horizontal control signal for latching the number of horizontal
pixels as the offset value, a latch responsive to a vertical control signal for latching
the number of vertical pixels, an AND gate responsive to the read control signal from
said read/write control unit for allowing the system clock signal to be passed therethrough,
a down counter for inputting an output signal from said latch as a load signal and
counting down an output signal from said AND gate to generate the carry signal, a
buffer responsive to the read control signal from said read/write control unit for
allowing the carry signal from said down counter to be passed therethrough, and AND
gate for ANDing an output signal from said buffer and the vertical control signal
to apply the ANDed signal as a load control signal to said down counter, an up counter
for loading with the start address value in response to a start control signal and
counting up the carry signal from said down counter, and a buffer responsive to an
output signal from said AND gate for allowing an output signal from said up counter
to be passed therethrough.
7. The system in accordance with Claim 5, wherein said system clock supplying unit comprises
a flip-flop for inputting the vertical control signal as a clock signal to output
a high voltage signal, an AND gate for ANDing the high voltage signal from said flip-flop
and a reference clock signal to output the ANDed signal as the system clock signal,
an up counter for counting up the carry signal from said start address setting unit,
a comparator for comparating the counted value from said up counter with the offset
value from said start address setting unit, and a mono-multivibrator responsive to
an output signal from one terminal (A=B) of said comparator for generating a pulse
signal to apply the pulse signal as a clear signal to said flip-flop.
8. The system in accordance with Claim 5, wherein said count control unit comprises a
buffer for applying low voltage data to said V-RLSA memory at write state of said
V-RLSA memory, a comparator for comparating the read data with the reference signal
at read state of said V-RLSA memory, an AND gate for ANDing the output signal from
the one output terminal (A=B) of said comparator and the system clock signal, a selector
for selecting one of an output signal from said AND gate and the system clock signal
in accordance with the read/write states of said V-RLSA memory to apply the selected
signal as the count clock signal, and a mono-multivibrator responsive to an output
signal from the other terminal (A<B) of said comparator for generating a pulse signal
to apply the pulse signal as the comparison enable signal.
9. The system in accordance with Claim 5, wherein said read/write control unit comprises
an up/down counter for counting up/down the system clock signal outputted from said
count control unit in accordance with the read/write states of said V-RLSA memory,
a threshold setting unit for setting the vertical threshold value, an AND gate for
ANDing the comparison enable signal from said count control unit, a comparator enabled
by an output signal from said AND gate for comparating the counted value from said
up/down counter with the vertical threshold value from said threshold setting unit,
a mono-multivibrator responsive to an output signal from one output terminal (A≧B)
of said comparator for outputting a pulse signal, AND gate for ANDing the pulse signal
from said mono-multivibrator and the carry signal from said up/down counter to apply
the ANDed signal as a clear signal to said up/down counter, and AND gate for ANDing
the carry signal from said up/down counter and a reset signal, and a flip-flop responsive
to an output signal from said AND gate for outputting the read control signal and
responsive to an output signal from the other output terminal (A<B) of said comparator
for outputting the write control signal.
10. The system in accordance with Claim 5, wherein said address resetting unit comprises
an adder for adding the offset value from said start address setting unit to the address
signal value from said address generating counter, a multiplier for multiplying the
offset value by the counted value from said read/write control unit, a subtracter
for subtracting an output signal value from said multiplier from the address signal
value from said address generating counter, a mono-multivibrator responsive to the
write control signal from said read/write control unit for generating a pulse signal,
an inverter for inverting an output enable signal from said start address setting
unit, an inverter for inverting the pulse signal from said mono-multivibrator, an
OR gate for ORing output signals from said inverters and the system clock signal,
a buffer responsive to an output signal from said OR gate for allowing an output signal
from said adder to be passed therethrough to apply the output signal from said adder
as a load signal to said address generating counter, and a buffer responsive to the
pulse signal from said mon-multivibrator for allowing an output signal from said subtracter
to be passed therethrough to apply the output signal from said subtacter as a load
signal to said address generating counter.
11. A document acknowledge system having a document region divide circuit comprising:
a horizontal-run length smoothing algorithm (H-RLSA) circuit,
a vertical-run length smoothing algorithm (V-RLSA) circuit,
a system clock and address supplying unit for supplying a system clock signal in
response to an end signal of said V-RLSA circuit, counting the system clock signal
to output the counted value as horizontal/vertical address signals, and stopping supplying
the system clock signal when the system clock signal was outputted therefrom a predetermined
number of times,
an address and read/write selecting unit responsive to the end signal of said V-RLSA
circuit for selecting any one of the horizontal address signal of said H-RLSA circuit,
the vertical address signal of said V-RLSA circuit and the counted value from said
system clock and address supplying unit to output the selected signal as horizontal/vertical
address signals, selecting one of horizontal read/write control signals of said H-RLSA
circuit and the system clock signal to output the selected signal as the horizontal
read/write control signals, and selecting one of vertical read/write control signals
of said V-RLSA circuit and the end signal of said V-RLSA circuit to output the selected
signal as the vertical read/write control signals,
a horizontal-run length smoothing algorithm (H-RLSA) memory accessed by the horizontal
address signal from said address and read/write selecting unit and responsive to the
horizontal read/write control signals for operating at read/write states,
a vertical-run length smoothing algorithm (V-RLSA) memory accessed by the vertical
address signal from said address and read/write selecting unit and responsive to the
vertical read/write control signals for operating at read/write states,
an AND gate for ANDing output data from said H-RLSA memory and V-RLSA memory by
bit unit, and
a buffer for allowing an output signal from said AND gate to be passed therethrough
during a half cycle of the system clock signal to apply the output signal from said
AND gate as write data to said H-RLSA memory.
12. The system in accordance with Claim 11, wherein said system clock and address supplying
unit comprises an OR gate for ORing the end signal of said V-RLSA circuit and a reference
clock signal, a flip-flop for inputting an output signal from said OR gate as a clock
signal to output the output signal from said OR gate as the system clock signal, an
up counter for counting up the system clock signal to output the counted value as
the horizontal/vertical address signals, and a down counter for counting down the
system clock signal a predetermined number of times to generate a carry signal to
apply the carry signal as a clear signal to said flip-flop.
13. The system in accordance with Claim 11, wherein said address and read/write selecting
unit comprises an inverter for inverting the end signal of said V-RLSA circuit, a
selector responsive to the end signal of said V-RLSA circuit for selecting one of
the horizontal address signal of said H-RLSA circuit and the counted value from said
system clock and address supplying unit to output the selected signal as the horizontal
address signal, a selector responsive to the end signal of said V-RLSA circuit for
selecting one of the vertical address signal of said V-RLSA circuit and the counted
value from said system clock and address supplying unit to output the selected signal
as vertical address signal, a selector responsive to the end signal of said V-RLSA
circuit for selecting one of horizontal read/write control signals of said H-RLSA
circuit and the system clock signal to output the selected signal as the horizontal
read/write control signals, and a selector responsive to the end signal of said V-RLSA
circuit for selecting one of vertical read/write control signals of said V-RLSA circuit
and an output signal of said inverter to output the selected signal as the vertical
read/write control signals.