US4929938A - Area searching system - Google Patents
Area searching system Download PDFInfo
- Publication number
- US4929938A US4929938A US07/156,117 US15611788A US4929938A US 4929938 A US4929938 A US 4929938A US 15611788 A US15611788 A US 15611788A US 4929938 A US4929938 A US 4929938A
- Authority
- US
- United States
- Prior art keywords
- boundary
- search
- found
- line
- vertically adjacent
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Lifetime
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T11/00—2D [Two Dimensional] image generation
- G06T11/40—Filling a planar surface by adding surface attributes, e.g. colour or texture
Definitions
- the present invention relates to a pattern processing system and more specifically to an area searching system used in a processing for painting the inside of a closed area or contour of a drawn pattern.
- pattern processing systems having a graphic drawing function such as so called personal computers, have been required to have a function of painting an inside of a closed area or contour of a drawn pattern at a high speed.
- the drawn pattern is stored in a memory, and therefore, the closed area to be painted is detected by searching a content of the memory.
- a conventional method has been effective in detecting an area to be painted in the case of a simple configuration of closed pattern, but has needed a long time for searching in the case of a complicated configuration of closed pattern such as a pattern having therein another closed pattern.
- Another object of the present invention is to provide an area searching system capable of searching an area to be painted at a high speed even in the case of a complicated configuration of closed pattern.
- Still another object of the present invention is to provide an area searching system which is capable of searching an area to be painted in the case of a complicated configuration of closed pattern at a high speed and with a small number of additional circuits.
- a system for searching a predetermined boundary of a closed pattern comprising a memory for storing data of a given closed pattern, a reading unit for sequentially reading each pair of vertically adjacent words of each pair of vertically adjacent lines of the given closed pattern from the memory in the same reading direction, a search unit receiving the pair of vertically adjacent words from the reading unit for searching a boundary in each of the pair of vertically adjacent words and for generating data indicative of a position of a boundary found in each of the pair of vertically adjacent words, a comparison unit receiving the boundary position data of the each pair of vertically adjacent words so as to judge in which of the vertically adjacent words the boundary is found earlier than the other, and a processing unit coupled to the comparison unit for determining whether or not the found boundary is the predetermined boundary.
- the search unit firstly conducts a boundary search for both of the pair of vertically adjacent words by detecting a change of a first logic value to a second logic value in the data reading direction, and after a boundary is found in a first line of the pair of vertically adjacent lines, the search unit executes a boundary search for a word of the first line in which the boundary has already been found, by detecting a change of the second logic value to the first logic value in the data reading direction, and on the other hand, the search unit continues the boundary search performed by detecting a change of the first logic value to the second logic value in the data reading direction, for a word of the other line in which the boundary has not yet been found.
- the processing unit controls the searching unit to cause it to conduct, for a word of the first line again, the boundary search performed by detecting a change of the first logic value to the second logic value in the data reading direction. A boundary of the first line found thereafter is judged to be the predetermined boundary.
- FIG. 1A, 1B and 1C illustrate a principle of searching an area to be painted
- FIG. 2A, 2B and 2C illustrate a conventional manner of searching an area to be painted
- FIG. 3 is a block diagram of an embodiment of the area searching system in accordance with the present invention.
- FIG. 4A, 4B and 4C illustrate a first manner in accordance with the present invention for searching an area to be painted
- FIG. 5A, 5B and 5C illustrate a second manner in accordance with the present invention for searching an area to be painted.
- FIG. 1A, 1B and 1C illustrate a principle of searching an area to be painted.
- the simplest example of painting an internal area of a closed pattern can be exemplified by a case of painting an internal area of a perfectly closed rectangle as shown in FIG. 1A.
- FIG. 1A the area of painted is hatched.
- the pattern information indicated in a CRT as shown in FIG. 1A is stored in a memory mapped in the form of a two dimensional plane. Therefore, in the case shown in FIG. 1A, bits corresponding to the rectangle area are written with "0", and the other bits are written with "1".
- a search starting point is set to any point within the rectangular area, and then the bit information is sequentially read out from the memory in a leftward or rightward direction from the search starting point so that a discrimination is made on whether the read-out bit information is "1" or "0".
- the edge or contour of the rectangle is "1"
- a position where the bit information read out of the memory first becomes "1" is a boundary.
- the above mentioned search is made for each one line (i.e., each one horizontal scan line).
- the conventional system is adapted to read the information in a unit of one word (for example 16 bits) and to execute the boundary search in a unit of word.
- the above mentioned conventional method for searching the area can be used without significant problems.
- the above mentioned method is not so effective. For example, assume that bits corresponding to an internal space of a large rectangle area are written with "0", and the other bits corresponding to the outside area of the large rectangle and an internal space of a small rectangle area are written with "1". Also assume that the search starting point is set to A point in FIG. 1B and the search is conducted in a leftward direction.
- information is read out of the memory from a word 1 including the search starting point S for a first line, and a discrimination is made about whether the read information is "1" or "0". If "1" is found, the search is completed. But, in this example, since all the bits of the block has "0", the "1/0 boundary search" is conducted leftwardly from the search starting point S. As a result, a next word 2 is read out and the search is conducted. Then, a boundary point a is found.
- the search goes to the leftward direction search for a second line just above the first line.
- a word 3 on the second line vertically corresponding to the block including the starting point S is read out of the memory, and a discrimination is made about whether the read information is "1" or "0". If "1" is found, the search goes to the rightward direction search. But, in this example, since all bits of the word 3 are "0", the "1/0 boundary search" is conducted in a leftward direction. Namely, words 4, 5 and 6 are sequentially read out of the memory, and the search for "1" is conducted. As seen from FIG. 2A, a boundary B is found in the word 6.
- the search returns to the first line so that words for the first line are read out from the word 2 including the boundary A, and the "0/1 boundary search" is conducted from a bit leftwardly adjacent to the point A. If the boundary is not found in the word 2, the leftwardly adjacent word 7 is read and then a similar search is repeated. As a result, as shown in FIG. 2B, if a boundary C is found when a word 8 is read and the boundary C exists between the boundaries A and B, it is judged that the point A is not a boundary to be detected for the first line. Accordingly, the search, i.e., the "1/0 boundary search" is started again for the first line. Consequentially, a correct boundary D is found.
- the conventional search method is required to continue to the search until "1" or "0" is found in the "1/0 boundary search” or in the "0/1 boundary search", respectively.
- a vain search is often executed as in the case shown in FIG. 2C.
- the search for the words 7 to 11 shown in FIG. 2C is not required if it had been previously known that a further search for the first line is no longer necessary when the boundary B is found for the second line.
- the conventional method has required a long time for search, resulting in a long time of the painting processing.
- the word 2 was read in the first search for the first line, the word 2 is read again in the second search for the same first line. This needs an additional read cycle of the memory. In order to avoid the inconvenience, it can be considered to retain the data already read out of the memory. However, this is not so practical, since a large number of registers are required.
- FIG. 3 there is shown a block diagram of an embodiment of the area searching system in accordance with the present invention.
- the shown system comprises a processing unit 10 for supplying and receiving data from elements explained below and for controlling those elements.
- the processing unit 10 outputs a control signal 20 to a data reading unit 12 and sends and receives data from the data reading unit 12 via a bus 30.
- the data reading unit 12 outputs a read signal 22 to an associated memory 14 storing a pattern information, and reads out two words of data vertically adjacent to each other from the memory 14 via a bus 32.
- the data reading unit 12 outputs the two read-out words of data via a bus 34 to a search unit 16 for searching a boundary of "1" to "0" and/or a boundary of "0" to "1" within the two input words.
- This search unit 16 is coupled to the processing unit 10 via a bus 36, and is controlled by a control signal 24 from the processing unit 10, so as to output information indicative of a position of a boundary found in each of the two words.
- This boundary position information is inputted via bus 38 to a comparison unit 18 which is also coupled to the processing unit 10 via a bus 40.
- This comparison unit 18 is controlled by a signal 26 from the processing unit 10 for detecting in which of the two vertically adjacent words the boundary is found earlier than the other.
- FIG. 4 illustrates a case similar to the case shown in FIG. 2 for making it easier to understand the feature and the advantage of the shown embodiment.
- a line in which a search starting point lies is called a "first line”
- a line just above or vertically upwardly adjacent to the first line is called a "second line”.
- a search that the "1/0 boundary search” is conducted for the first line and the "1/0 boundary search” is conducted for the second line is called a "1/0-1/0 boundary search”.
- another search that the 0/1 boundary search” is conducted for the first line and the "1/0 boundary search” is conducted for the second line is called a "0/1-1/0 boundary search”.
- the search is started with the "1/0-1/0 boundary search". Namely, the reading unit 12 reads out the word 1 of the first line including the starting point S and the word 2 vertically corresponding to the first word 1, and then outputs these read-out words to the search unit 16. The search unit 16 then conducts the "1/0-1/0 boundary search" for the two inputted words. In the example shown in FIG. 4A, since "1" is not found in any of the two words, the reading unit 12 reads out next two words 3 and 4, so that the same search is conducted. At this time, a boundary A is found in the word 3 for the first line.
- the processing unit 10 which in turn controls the search unit 16 to cause it to conduct the "0/1-1/0 boundary search" for the third and fourth words 3 and 4 in the leftward direction search from the A point.
- the boundary is not found in the words 3 and 4. Therefore, a further next pair of words 5 and 6 are read out and the "0/1-1/0 boundary search" is conducted. Succeedingly, a pair of words 7 and 8 are read out and the "0/1-1/0 boundary search" is conducted.
- a boundary C is found in the word 7 for the first line and a boundary B is found in the word 8 for the second line as shown in FIG. 4B.
- the position information of the found boundaries are examined by the comparison unit 18. Since the C point is positioned at the right side of the B point, it can be judged that the C point is not a correct boundary for the first line (the most leftward boundary).
- the A point is judged to be the most leftward boundary for the first line, and then, the leftward search is completed.
- the first and second lines have the leftward boundary at the same position as shown, and a boundary D for the first line is found at the same time when the boundary B is found.
- the correct boundary can be found if the "1/0 boundary search" is conducted for only the first line by masking the data for the second line at a leftside of the B point.
- the first line has an area which should not be painted.
- the system shown in FIG. 3 can effectively search an area to be painted even in the case that the second line has an area which should not be painted.
- the "1/0-1/0 boundary search" is carried out for the read-out words 3 and 4. As a result, a boundary A is found in the word 4 for the second line.
- the "0/1-1/0 boundary search" is executed from the data at the leftside of the point A. But, in the example shown in FIG. 5, since a boundary does not exist in the word 3 and 4, a next pair of words 5 and 6 are read out and the "0/1-1/0 boundary search" is conducted. Succeedingly, a pair of words 7 and 8 are read out and the "0/1-1/0 boundary search" is conducted.
- the A point is judged to be the the most leftward boundary for the second line, and then, the leftward search is completed.
- the system in accordance with the present invention is so constructed to read a pair of words vertically adjacent to each other and to search a boundary in the read-out words at the same time, so that the positions of the found boundaries of the vertically adjacent lines are compared.
- the present invention can exert a great advantage in such a case.
- the boundary of the area to be not painted can be detected, and therefore, area to be not painted can be defined from the detected boundaries of the area to be not painted.
Landscapes
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Image Generation (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Image Analysis (AREA)
Abstract
Description
Claims (3)
Applications Claiming Priority (2)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| JP62031025A JPS63198175A (en) | 1987-02-13 | 1987-02-13 | Area searching method |
| JP62-31025 | 1987-02-13 |
Publications (1)
| Publication Number | Publication Date |
|---|---|
| US4929938A true US4929938A (en) | 1990-05-29 |
Family
ID=12319976
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| US07/156,117 Expired - Lifetime US4929938A (en) | 1987-02-13 | 1988-02-16 | Area searching system |
Country Status (4)
| Country | Link |
|---|---|
| US (1) | US4929938A (en) |
| EP (1) | EP0278528B1 (en) |
| JP (1) | JPS63198175A (en) |
| DE (1) | DE3853891T2 (en) |
Cited By (2)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US5185596A (en) * | 1990-01-23 | 1993-02-09 | Crosfield Electronics Ltd. | Electronic image modification |
| CN111986289A (en) * | 2020-08-20 | 2020-11-24 | 广联达科技股份有限公司 | Searching method and device for closed area and electronic equipment |
Families Citing this family (2)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| DE69031200T2 (en) * | 1989-09-21 | 1997-12-11 | Dainippon Screen Mfg | Method and device for processing an image with multiple areas |
| JPH0767136B2 (en) * | 1989-09-21 | 1995-07-19 | 大日本スクリーン製造株式会社 | Image processing device |
Citations (2)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US4626838A (en) * | 1982-10-18 | 1986-12-02 | Hitachi, Ltd. | Filled shaped generating apparatus |
| US4788538A (en) * | 1986-11-17 | 1988-11-29 | Lotus Development Corporation | Method and apparatus for determining boundaries of graphic regions |
Family Cites Families (1)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| FR2550403A1 (en) * | 1983-08-04 | 1985-02-08 | Thomson Csf | METHOD FOR DISCRIMINATING CONTOURS AND TEXTURES IN A VIDEO IMAGE AND CONTOUR DETECTOR DEVICE FOR IMPLEMENTING SAID METHOD |
-
1987
- 1987-02-13 JP JP62031025A patent/JPS63198175A/en active Pending
-
1988
- 1988-02-15 DE DE3853891T patent/DE3853891T2/en not_active Expired - Fee Related
- 1988-02-15 EP EP88102204A patent/EP0278528B1/en not_active Expired - Lifetime
- 1988-02-16 US US07/156,117 patent/US4929938A/en not_active Expired - Lifetime
Patent Citations (2)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US4626838A (en) * | 1982-10-18 | 1986-12-02 | Hitachi, Ltd. | Filled shaped generating apparatus |
| US4788538A (en) * | 1986-11-17 | 1988-11-29 | Lotus Development Corporation | Method and apparatus for determining boundaries of graphic regions |
Non-Patent Citations (2)
| Title |
|---|
| "Polygon Painting Method", IBM Technical Disclosure Bulletin, vol. 28, No. 7, Dec. 1985, pp. 3080-3081. |
| Polygon Painting Method , IBM Technical Disclosure Bulletin, vol. 28, No. 7, Dec. 1985, pp. 3080 3081. * |
Cited By (2)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US5185596A (en) * | 1990-01-23 | 1993-02-09 | Crosfield Electronics Ltd. | Electronic image modification |
| CN111986289A (en) * | 2020-08-20 | 2020-11-24 | 广联达科技股份有限公司 | Searching method and device for closed area and electronic equipment |
Also Published As
| Publication number | Publication date |
|---|---|
| JPS63198175A (en) | 1988-08-16 |
| DE3853891T2 (en) | 1995-11-30 |
| EP0278528A3 (en) | 1991-11-21 |
| DE3853891D1 (en) | 1995-07-06 |
| EP0278528A2 (en) | 1988-08-17 |
| EP0278528B1 (en) | 1995-05-31 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| US4975873A (en) | Content addressable memory with flag storage to indicate memory state | |
| US5043868A (en) | System for by-pass control in pipeline operation of computer | |
| JPH0664911B2 (en) | Content addressable memory array | |
| EP0125855A2 (en) | Buffer-storage control system | |
| KR930016880A (en) | Electronic device and its fixing information | |
| JPH0218790A (en) | Memory system whose address can be apdointed by content | |
| US6181592B1 (en) | Content addressable memory | |
| US4670836A (en) | Device for detecting an overlap of operands to be accessed | |
| KR940000992A (en) | How Digital Data Processors Work | |
| US4047245A (en) | Indirect memory addressing | |
| US4929938A (en) | Area searching system | |
| US4878189A (en) | Microcomputer having Z-flag capable of detecting coincidence at high speed | |
| JPS63298485A (en) | Image processor | |
| US5386521A (en) | Instruction prefetching circuit with a next physical address precalculating circuit | |
| US5457645A (en) | Pattern recognition system including a circuit for detecting maximum or minimum data elements which determines the standard pattern closest to the input pattern | |
| US5099416A (en) | An operand storage compare (osc) detecting device using column and row signals in a buffer storage | |
| US4031514A (en) | Addressing system in an information processor | |
| US5802384A (en) | Vector data bypass mechanism for vector computer | |
| US4333161A (en) | Data processing apparatus operative on data passing along a serial, segmented store | |
| US5548736A (en) | Method and apparatus overcoming delay introduced by instruction interlocking in pipelined instruction execution | |
| US5151980A (en) | Buffer control circuit for data processor | |
| JPH0246970B2 (en) | MEMORIKA KUCHOHOSHIKI | |
| JP2727947B2 (en) | Address trace method | |
| US5278960A (en) | Information processing apparatus having detecting means for operand overlaps | |
| JPH0115900B2 (en) |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| AS | Assignment |
Owner name: NEC CORPORATION, JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST.;ASSIGNOR:HORIGUCHI, RYUJI;REEL/FRAME:005254/0671 Effective date: 19880318 |
|
| STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
| CC | Certificate of correction | ||
| FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
| FPAY | Fee payment |
Year of fee payment: 4 |
|
| FEPP | Fee payment procedure |
Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
| FEPP | Fee payment procedure |
Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
| FPAY | Fee payment |
Year of fee payment: 8 |
|
| FPAY | Fee payment |
Year of fee payment: 12 |
|
| AS | Assignment |
Owner name: NEC ELECTRONICS CORPORATION, JAPAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NEC CORPORATION;REEL/FRAME:013758/0440 Effective date: 20021101 |