JPH02206883A - Picture processor - Google Patents
Picture processorInfo
- Publication number
- JPH02206883A JPH02206883A JP1027850A JP2785089A JPH02206883A JP H02206883 A JPH02206883 A JP H02206883A JP 1027850 A JP1027850 A JP 1027850A JP 2785089 A JP2785089 A JP 2785089A JP H02206883 A JPH02206883 A JP H02206883A
- Authority
- JP
- Japan
- Prior art keywords
- data
- window
- calculation
- image processing
- processing apparatus
- 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.)
- Granted
Links
- 238000004364 calculation method Methods 0.000 claims abstract description 84
- 238000001914 filtration Methods 0.000 claims abstract description 11
- 230000008859 change Effects 0.000 claims description 8
- 238000003384 imaging method Methods 0.000 claims description 4
- 239000000284 extract Substances 0.000 claims description 3
- 238000007781 pre-processing Methods 0.000 abstract description 24
- 238000004458 analytical method Methods 0.000 abstract description 3
- 230000015654 memory Effects 0.000 description 43
- 238000010586 diagram Methods 0.000 description 23
- 238000000034 method Methods 0.000 description 23
- 230000008569 process Effects 0.000 description 13
- 230000009466 transformation Effects 0.000 description 12
- 238000003708 edge detection Methods 0.000 description 11
- 238000006243 chemical reaction Methods 0.000 description 7
- 230000006870 function Effects 0.000 description 5
- 238000007792 addition Methods 0.000 description 3
- 101100325756 Arabidopsis thaliana BAM5 gene Proteins 0.000 description 2
- 101150046378 RAM1 gene Proteins 0.000 description 2
- 101100476489 Rattus norvegicus Slc20a2 gene Proteins 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 101001093690 Homo sapiens Protein pitchfork Proteins 0.000 description 1
- 102100036065 Protein pitchfork Human genes 0.000 description 1
- 238000009825 accumulation Methods 0.000 description 1
- 230000001174 ascending effect Effects 0.000 description 1
- 239000013256 coordination polymer Substances 0.000 description 1
- 230000004069 differentiation Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000000630 rising effect Effects 0.000 description 1
- 238000007711 solidification Methods 0.000 description 1
- 230000008023 solidification Effects 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 238000011426 transformation method Methods 0.000 description 1
Landscapes
- Image Analysis (AREA)
Abstract
Description
【発明の詳細な説明】
〔産業上の利用分野〕
本発明は画像処理装置に関するもので、無人走行車両の
制御や被観測物体の動作のリアルタイムな認識などに使
用される。DETAILED DESCRIPTION OF THE INVENTION [Industrial Application Field] The present invention relates to an image processing device, which is used for controlling unmanned vehicles, real-time recognition of the motion of an observed object, and the like.
例えば無人走行ロボットや自動走行車両を制御する場合
には、進行路にあらかじめ表示された識別ラインや、道
路のセンターラインあるいは路肩ラインの画像をカメラ
で取り込み、リアルタイムで画像処理する必要がある。For example, when controlling unmanned robots or autonomous vehicles, it is necessary to use a camera to capture images of identification lines displayed in advance on the road ahead, or the center line or shoulder line of the road, and process the images in real time.
第22図は画像による道路の認識を説明するためのもの
で、同図(a)はカメラで取り込んだ画像、同図(b)
は同図(a)のうち輝度(もしくはその変化割合など)
の高い画素を黒点で示した図である。Figure 22 is for explaining road recognition using images. Figure 22 (a) is an image captured by a camera, Figure 22 (b) is an image captured by a camera.
is the luminance (or its rate of change, etc.) in figure (a)
3 is a diagram showing pixels with high values as black dots. FIG.
同図(a)に示す通り、カメラ画像1には水平線2の無
限遠方向に延びる道路3が写っており、この道路3の両
側には路肩ライン4が描かれ、中央部にはセンターライ
ン5が描かれている。ここで、道路3の路肩ライン4お
よびセンターライン5は他の部分に比べて輝度が高く、
従って同図(b)ではこれらの部分にドツト4’ 、5
’が連続して現れることになる。このようなカメラ画像
1において、道路3の進行方向および曲り形状などを認
識するためには、同図(b)においてドツト4′を結ぶ
曲線の近似直線り、L2.L3などを認識すればよい。As shown in Figure (a), the camera image 1 shows a road 3 extending toward infinity from the horizon 2. Road shoulder lines 4 are drawn on both sides of the road 3, and a center line 5 is drawn in the center. is depicted. Here, the shoulder line 4 and center line 5 of the road 3 have higher brightness than other parts,
Therefore, in the same figure (b), dots 4' and 5 are placed in these parts.
' will appear consecutively. In such a camera image 1, in order to recognize the traveling direction and curved shape of the road 3, an approximate straight line of the curve connecting dots 4', L2. It is sufficient to recognize L3 etc.
従来から、このような近似直線りを求める手法として、
Hough (ハフ)変換と呼ばれる手法が知られてい
る(例えば米国特許第3069654号)。これを第2
3図ないし第25図により説明する。第23図(a)に
示すように、x−y座標系で示される原画像において処
理対象点P(x、y、)が存在するとき、この点Pを通
る直線flcf1.fl、など)は無限に描くことかで
きる。そして、この直線1 1! 、・・・に直交し
b
原点0 (0,0)を通る直線についても、直線N
l! 、・・・ごとに1本づつ描(ことができる。Traditionally, as a method for finding such an approximate straight line,
A technique called Hough transform is known (for example, US Pat. No. 3,069,654). This is the second
This will be explained with reference to FIGS. 3 to 25. As shown in FIG. 23(a), when a processing target point P (x, y,) exists in the original image indicated by the x-y coordinate system, a straight line flcf1. fl, etc.) can be drawn infinitely. And this straight line 1 1! , ... and passing through b origin 0 (0,0), the straight line N
l! You can draw one line for each.
a b
ここで、原点0 (0,0)を通る直線について、直線
IC1,Ibなど)までの長さをρ(ρ、。a b Here, regarding the straight line passing through the origin 0 (0,0), the length to the straight line IC1, Ib, etc.) is ρ (ρ,.
ρ5など)とし、X軸となす角をθ(θ3.θ。ρ5, etc.), and the angle between it and the X axis is θ (θ3.θ.
など)とすると、この原点を通る直線の上記ρ。), then the above ρ of the straight line passing through this origin.
θは、同図(b)のような正弦曲線(サインカーブ)す
なわちHough曲線として表現される。θ is expressed as a sine curve, ie, a Hough curve, as shown in FIG.
ここにおいて、原点0 (0,0)と処理対象点P(x
、y)の距離ρ は、この処理対象p p
181点に関する上記のρ(
ρ3.ρ6.・・・)中で最も長く、
2 2.1/2
ρ1ax−(x+yp
となり、θ−0のときにはρo ”” X 、となる。Here, the origin 0 (0,0) and the processing target point P(x
, y) is the distance ρ of this processing target p p
The above ρ(
ρ3. ρ6. ...) is the longest among them, and becomes 2 2.1/2 ρ1ax-(x+yp, and when θ-0, ρo "" X.
次に、第り4図(a)のように直線り上に並ぶ3点P
−P について、第23図のHough変換を適用
すると、点P1について上記サインカーブ(Hough
曲線)は第24図(b)の点線のようになり、点P に
ついてのサインカーブ番よ同図(b)の−点鎖線のよう
になり、点P3についてのサインカーブは同図(b)の
二点鎖線のようになる。ここで、同図(b)のサインカ
ーブのピーク(ρ 、θ )、(ρ 、θ2)および(
ρ 、θ3)は、それぞれ同図(a)の原点0 (0,
0)と点P 、P 、P の間の距離ρ 〜ρ
と、X軸とのなす角θ 〜θ3とに対応する。Next, three points P lined up in a straight line as shown in Figure 4(a)
-P, when the Hough transformation shown in Fig. 23 is applied, the above sine curve (Hough
The sine curve number for point P becomes like the dotted line in Figure 24(b), and the sine curve for point P3 looks like the dotted line in Figure 24(b). It looks like the two-dot chain line. Here, the peaks (ρ , θ ), (ρ , θ2) and (
ρ, θ3) are respectively at the origin 0 (0,
0) and the points P , P , P , the distance ρ ~ ρ
and the angle θ to θ3 formed with the X axis.
第24図(b)において、3つのHough曲線(サイ
ンカーブ)が交叉する点に着目すると、ここは座標が(
ρ 、θ )となっており、これは同図(a)の直線り
と直交する原点0 (0,0)を通る直線のρ 、θ
と等しくなっている。従って、このようなサインカーブ
の交叉点を求めれば、原画像のx−y直交座標系におい
て描かれるドツト(黒点)の間の曲線の近似直線(但し
、第24図ではこの曲線と近似直線が一致している)を
求めることができる。In Figure 24(b), if we focus on the point where the three Hough curves (sine curves) intersect, we can see that the coordinates here are (
ρ , θ ), which is the same as the ρ , θ of the straight line passing through the origin 0 (0,0), which is perpendicular to the straight line in Figure (a).
is equal to Therefore, if we find the intersection point of such a sine curve, we can find the approximate straight line of the curve between the dots (black dots) drawn in the x-y orthogonal coordinate system of the original image (however, in Fig. 24, this curve and the approximate straight line are ) can be found.
これを第25図により説明すると、まず同図(a)にお
いてx−y座標面(原画像面)にHough変換すべき
ドツト(処理対象点)が多数存在し、これらは曲線上に
並んでいるとする。To explain this with reference to Fig. 25, first, in Fig. 25 (a), there are many dots (processing target points) to be Hough-transformed on the x-y coordinate plane (original image plane), and these are lined up on a curve. shall be.
ここで、同図(a)中において、ドツト間を結ぶ曲線に
は3本の近似直線り、L2.L3を描くことができる。Here, in the same figure (a), there are three approximate straight lines in the curve connecting the dots, L2. Can draw L3.
従って、このドツトの全てについて第23図のようなサ
インカーブへの変換(Hough変換)を実行すると、
第23図(b)のよう、なサインカーブの交叉点が3ケ
所を中心にして得られることになる。この交叉点の座標
は、第25図(a)に示す(ρ、1.θ1、)、(ρt
2’θ )および(ρ θ )であり、従ってこれt
2 13’ t3
をρ、θ、Hの座標系においてHを交叉点の出現開度と
して表わすと、同図(b)の如くになる。Therefore, if all of these dots are converted into sine curves (Hough conversion) as shown in Figure 23, we get
As shown in FIG. 23(b), intersection points of the sine curves are obtained centered on three points. The coordinates of this intersection point are shown in FIG. 25(a) (ρ, 1.θ1,), (ρt
2′θ ) and (ρ θ ), so this t
If 2 13' t3 is expressed in the coordinate system of ρ, θ, H, where H is the degree of appearance of the intersection point, the result will be as shown in FIG. 3(b).
従って、前述の第22図(b)のような道路3の路肩ラ
イン4に対応する曲線の近似直線L1〜L は、第25
図(b)におけるH(交叉点の出現頻度)のピークにお
けるρ、θの値によって求めることが可能になる。Therefore, the approximate straight lines L1 to L of the curve corresponding to the shoulder line 4 of the road 3 as shown in FIG.
This can be determined by the values of ρ and θ at the peak of H (frequency of appearance of crossover points) in FIG.
しかしながら、前述のようなHough変換の手法は、
高速かつリアルタイムな画像処理に適用することは容易
でなかった。なぜなら、第23図においてデータとして
与えられる原画像中の処理対象点Pの座標値(x、y)
にもとづき、p
Hough曲線(サインカーブ)を求めるために、原点
から直線gまでの距離を求めようとすると、p −x
e sin O+ y ”c
os θ −(1)p
を実行しなければならず、例えばθを512分割にする
と三角関数の計算を1024回、乗算を1024回、加
算を512回実行しなければならない。そして、計算対
象となる原画像が例えば512X512の画素から構成
されているとすると、全体の計算回数は極めて膨大なも
のとなり、通常のプロセッサで処理すると処理時間が著
しく長くなってしまう。However, the Hough transformation method described above is
It has not been easy to apply it to high-speed and real-time image processing. This is because the coordinate values (x, y) of the processing target point P in the original image given as data in FIG.
Based on p Hough curve (sine curve), when trying to find the distance from the origin to straight line g,
e sin O+ y ”c
os θ −(1)p must be executed. For example, if θ is divided into 512, trigonometric function calculations must be performed 1024 times, multiplications 1024 times, and additions 512 times. If the original image to be calculated is composed of, for example, 512×512 pixels, the total number of calculations will be extremely large, and processing with a normal processor will significantly increase the processing time.
もちろん、上記(1)式において必要とされるsinθ
およびeO8θの値をROM等に格納しておき、計算所
要時間を短くすることも可能である(例えば、「実時間
Hough変換プロセッサ」昭和60年電子通信学会情
報システム部門全国大会、No、92あるいはFROM
を用いたHough変換ハードウェア」昭和62年電子
情報通信学会創立70周年記念総合全国大会、No。Of course, the sin θ required in the above equation (1)
It is also possible to shorten the time required for calculation by storing the values of and eO8θ in ROM etc. FROM
``Hough conversion hardware using Hough conversion hardware'' 1986 IEICE 70th Anniversary National Conference, No.
1587)。しかしながら、前者の場合に三角関数のデ
ータをROM化しても、(1)式の計算における乗算回
数は従前のままであり、加算時間に比べて乗算時間がか
なり長いことを考慮すると、根本的な解決とはなりえな
い。1587). However, in the former case, even if the trigonometric function data is stored in ROM, the number of multiplications in the calculation of equation (1) remains the same as before, and considering that the multiplication time is considerably longer than the addition time, the fundamental It can't be a solution.
一方、上記の後者の文献FROMを用いたHough変
換ハードウェア」を別の観点から検討すると、ここでは
上記(1)式の演算を行なう演算部を並列化することに
より、全体としての信号処理の高速化を図っている。し
かしながら、このようにするとy −5lnθ、X
’eO8θを求p
めるためのメモリテーブル(ROM)は演算部の並列接
続した数だけ必要になり、ノ1−ドウエア上でシステム
が極めて大規模なものになってしまう。On the other hand, if we consider the latter document ``Hough conversion hardware using FROM'' from a different perspective, we can see that by parallelizing the calculation section that performs the calculation of equation (1) above, the signal processing as a whole can be improved. We are trying to speed it up. However, in this way, y −5lnθ,X
A memory table (ROM) for determining 'eO8θp is required as many as the number of arithmetic units connected in parallel, and the system becomes extremely large in terms of hardware.
また、LSI化にも向かない。ROMをRAM化する方
法もあるが、集積度の点で難点がある。Also, it is not suitable for LSI implementation. Although there is a method of converting ROM into RAM, there is a drawback in terms of the degree of integration.
このため、高速度で走行する車両を画像データにもとづ
きリアルタイム制御したり、高速運動する被観測物体を
画像データにもとづきリアルタイムに認識したりするこ
とは、はとんど不可能であった。また、演算部の並列化
などにより高速化を図ろうとすると、ハードウェアの大
型化は避けることができなかった。さらに、原画像にお
ける処理対象点の分布の特徴の認識を認識容易性の観点
から検討すると、原画像には処理対象点の分布の特徴の
把握が容易な部分と困難な部分があり、この把握困難な
部分も含めて一括処理すると全体的、大局的な傾向を把
握するのが困難になってしまっていた。For this reason, it has been almost impossible to control a vehicle traveling at high speed in real time based on image data, or to recognize an observed object moving at high speed in real time based on image data. Furthermore, when attempting to increase the speed by parallelizing the arithmetic units, it was inevitable that the hardware would become larger. Furthermore, if we examine the recognition of the characteristics of the distribution of processing target points in the original image from the viewpoint of ease of recognition, we find that there are parts of the original image where it is easy to understand the characteristics of the distribution of processing target points and parts where it is difficult to understand. If difficult parts were processed all at once, it would be difficult to grasp the overall, big-picture trends.
そこで本発明は、画像データの処理を高速度でリアルタ
イムに実行することが可能であるだけでなく、ハードウ
ェアを小型化することが可能であって、しかも原画像の
大局的な傾向を容易に把握することが可能な画像処理装
置を提供することを目的とする。Therefore, the present invention not only makes it possible to process image data in real time at high speed, but also makes it possible to downsize the hardware, and also makes it possible to easily determine the global trend of the original image. It is an object of the present invention to provide an image processing device that can grasp the information.
本発明に係る第1の画像処理装置は、撮像手段によって
取り込まれた原画像上の複数の処理対象点から当該原画
像の特徴点を分別、抽出する画像処理装置であって、次
の要素を備える。すなわち、原画像を複数のウィンドウ
に分割するための分割手段と、同一構成のD D A
(DigitalDtrrerentta+^naly
sis;ディジタル微分解析)演算要素を複数直列接続
して構成されるDDA演算手段と、このDDA演算手段
の演算結果をDDA演算要素に対応してウィンドウごと
に記憶する記憶手段と、この記憶手段の記憶内容にもと
づき、原画像の特徴点をウィンドウごとに抽出する手段
とを備えることを特徴とする。A first image processing device according to the present invention is an image processing device that separates and extracts feature points of an original image from a plurality of processing target points on the original image captured by an imaging means, and includes the following elements. Be prepared. That is, a dividing means for dividing the original image into a plurality of windows, and a DDA having the same configuration.
(DigitalDtrrerentta+^naly
sis (digital differential analysis); a DDA calculation means configured by connecting a plurality of calculation elements in series; a storage means for storing calculation results of the DDA calculation means for each window corresponding to the DDA calculation element; The present invention is characterized by comprising means for extracting feature points of the original image for each window based on the stored contents.
また、本発明に係る第2の画像処理装置は、撮像手段に
よって取り込まれた原画像上の複数の処理対象点を結ぶ
曲線の近似直線を導出する画像処理装置であって、次の
要素を備える。すなわち、原画像を複数のウィンドウに
分割する分割手段と、α−β直交座標系で描かれる近似
円の円周上の一点の座標を(α 、β )とし、円周上
の次の点の座標(α 、β )までの回転角をεと
し141 1+ま
たとき(但し、iは正の整数)に、
αtit””α 、β1.ε)
α l
β −f (α 、β1.8)
国 β 1
となる回転運動漸化式を所定回転角ごとに順次にパイプ
ライン方式で演算するDDA演算手段と、このDDA演
算手段により順次に演算されたそれぞれの結果のうち、
少なくともβ1の値をウィンドウごとに記憶する記憶手
段と、この記憶手段の記憶内容にもとづいて得られる複
数の処理対象点ごとのHough曲線の交点から、上記
曲線の近似直線をウィンドウごとに導出する近似直線導
出手段とを備えることを特徴とする。Further, a second image processing device according to the present invention is an image processing device that derives an approximate straight line of a curve connecting a plurality of processing target points on an original image captured by an imaging means, and includes the following elements. . In other words, the dividing means divides the original image into multiple windows, and the coordinates of one point on the circumference of an approximate circle drawn in the α-β orthogonal coordinate system are (α, β), and the coordinates of the next point on the circumference are Let the rotation angle to the coordinates (α, β) be ε, and when 141 1+ (where i is a positive integer), αtit””α, β1. ε) α l β −f (α , β1.8) Country β 1 A DDA calculation means that sequentially calculates the rotational motion recurrence formula for each predetermined rotation angle in a pipeline manner, and this DDA calculation means sequentially calculates Of each calculated result,
A storage means for storing at least the value of β1 for each window, and an approximation for deriving an approximate straight line of the above curve for each window from the intersection of the Hough curves for each of a plurality of processing target points obtained based on the storage contents of this storage means. The method is characterized by comprising a straight line deriving means.
本発明の構成によれば、同一構成のDDA演算回路(演
算要素)を単に直列接続するだけで簡単に演算部を形成
でき、演算に際してメモリテーブルなどを参照すること
が不要であるので、構成が著しく簡単かつ小型になる。According to the configuration of the present invention, a calculation unit can be easily formed by simply connecting DDA calculation circuits (calculation elements) of the same configuration in series, and there is no need to refer to a memory table or the like during calculation. It becomes significantly simpler and smaller.
また、パイプライン方式で回転運動漸化式を実行するよ
うに演算回路を構成することで、計算を高速化すること
が可能になる。さらに、原画像は複数のウィンドウに分
割されて処理されるので、大局的な傾向を容易に把握で
きる。Further, by configuring the arithmetic circuit to execute the rotational motion recurrence formula in a pipeline manner, it is possible to speed up calculation. Furthermore, since the original image is divided into multiple windows and processed, it is easy to grasp the overall trend.
以下、添付図面の第1図ないし第21図にもとづいて、
本発明の詳細な説明する。なお、図面の説明において同
一要素には同一符号を付し、重複する説明を省略する。Below, based on Figures 1 to 21 of the attached drawings,
The present invention will be described in detail. In addition, in the description of the drawings, the same elements are given the same reference numerals, and redundant description will be omitted.
第1図は実施例に係る画像処理装置の全体構成を示すブ
ロック図である。同図において、カメラ11は処理対象
物(例えば道路、高速移動物体など)を撮像して原画像
を取り込むもので、この画像信号は信号入力部12でデ
ィジタル化されてエツジ検出部13に送られる。エツジ
検出部13は後に詳述するように画像信号のエツジを抽
出して濃淡をもったエツジ化データとし、例えば512
X512個の画素信号(エツジ化画素信号)として多値
化メモリ14に送る。多値化メモリ14は画素ごとにエ
ツジ化データを記憶し、一画面のスキャンが終了するご
とにエツジ化データをD/A変換部15に送り、これは
アナログ信号としてCRTデイスプレィ16に与えられ
る。従って、このエツジ化データはCRTデイスプレィ
16で表示される。FIG. 1 is a block diagram showing the overall configuration of an image processing apparatus according to an embodiment. In the figure, a camera 11 captures an original image by capturing an object to be processed (for example, a road, a high-speed moving object, etc.), and this image signal is digitized by a signal input section 12 and sent to an edge detection section 13. . The edge detection unit 13 extracts the edges of the image signal and generates edge data with shading, for example, 512
The signal is sent to the multilevel memory 14 as X512 pixel signals (edged pixel signals). The multilevel memory 14 stores edged data for each pixel, and sends the edged data to the D/A converter 15 each time one screen is scanned, and is applied to the CRT display 16 as an analog signal. Therefore, this edged data is displayed on the CRT display 16.
一方、エツジ検出部13から出力されるエツジ化画素信
号は前処理部17に与えられ、後に詳述するような前処
理が施されたエツジ化画素信号は初期値演算部40を介
してDDA演算部18に与えられる。DDA演算部18
はn個のDDA演算回路18〜18 を有して構成さ
れ、これらOn−1
は互いに直列接続されている。そして、DDA演算部1
8の出力側には近傍フィルタ19とソーティング部20
が接続され、これによって近傍フィルタリング処理とソ
ーティング処理(後に詳述)がされるようになっている
。なお、上記の回路要素はVMEバス21を介してCP
U22に接続され、信号処理動作の制御や処理タイミン
グの同期がとられている。また、前処理部17、DDA
演算部18および近傍フィルタ19はVMEバス23を
介して互いに接続され、DDA演算結果の転送や濃淡値
データの転送の同期制御がなされている。On the other hand, the edged pixel signal output from the edge detection section 13 is given to the preprocessing section 17, and the edged pixel signal subjected to preprocessing as will be described in detail later is subjected to DDA calculation via the initial value calculation section 40. Section 18. DDA calculation unit 18
is composed of n DDA calculation circuits 18 to 18, and these On-1 circuits are connected in series with each other. Then, the DDA calculation unit 1
A neighborhood filter 19 and a sorting section 20 are provided on the output side of 8.
are connected, thereby performing neighborhood filtering processing and sorting processing (described in detail later). Note that the above circuit elements are connected to the CP via the VME bus 21.
It is connected to U22 to control signal processing operations and synchronize processing timing. In addition, the preprocessing section 17, the DDA
The calculation unit 18 and the neighborhood filter 19 are connected to each other via a VME bus 23, and synchronous control of the transfer of DDA calculation results and the transfer of gray value data is performed.
次に、第1図に示す画像処理装置の要部の詳細な構成を
説明する。Next, the detailed configuration of the main parts of the image processing apparatus shown in FIG. 1 will be explained.
第2図はその構成図で、第1図中の前処理部17、初期
値演算部40、DDA演算部18および近傍フィルター
9に対応している。図示の通り、前処理部17はF I
F O(First−In First−Out)ボ
ード17′により実現される。PIFO17’は処理対
象点のX−Y平面での座標値(X 。FIG. 2 is a configuration diagram thereof, which corresponds to the preprocessing section 17, initial value calculation section 40, DDA calculation section 18, and neighborhood filter 9 in FIG. As shown in the figure, the preprocessing section 17
This is realized by an FO (First-In First-Out) board 17'. PIFO 17' is the coordinate value (X) of the point to be processed on the X-Y plane.
Y )をアドレス信号として入力すると共に、エツジ化
された濃淡値データDIをデータ信号として入力する。Y) is input as an address signal, and edged gray value data DI is input as a data signal.
そして、後述のようにこのFIFO17′は、X−Y座
標からx−y座標への座標変換と、複数のウィンドウ設
定と、所定レベルでの閾値処理とを行ない、結果をFI
FO方式に従って順次に出力する。Then, as described later, this FIFO 17' performs coordinate conversion from X-Y coordinates to x-y coordinates, multiple window settings, and threshold processing at a predetermined level, and the results are transferred to the FIFO
Outputs sequentially according to the FO method.
第1図に示す初期値演算部は、2個のフリップフロップ
(F/F)41.42と初期値演算回路43を有し、F
/F41は処理対象点Pのx−y座標における座標値(
x、y)を−時的に格p
納し、F/F42は処理対象点Pの濃淡値データD1を
一時的に格納する。そして、初期値演算回路43は座標
値(x、y)にもとづいて、αp
−β直交座標系における初期値の座標(α0゜β。)を
演算し、回転運動漸化式の演算を可能にする。The initial value calculation section shown in FIG. 1 has two flip-flops (F/F) 41 and 42 and an initial value calculation circuit 43.
/F41 is the coordinate value (
x, y) are temporarily stored, and the F/F 42 temporarily stores the grayscale value data D1 of the processing target point P. Based on the coordinate values (x, y), the initial value calculation circuit 43 calculates the initial value coordinates (α0°β.) in the αp-β orthogonal coordinate system, thereby making it possible to calculate the rotational motion recurrence formula. do.
第1図に示す各段のDDA演算回路188〜18 は
、第2図に示す通りそれぞれ3個のフリップフロップ(
F/F)31.32.33を有し、F/F 31はアド
レス信号α0〜αn−1’β 〜β をそれぞれ−時
的に格納し、F/FOn−1
32は濃淡値データD1をそれぞれ一時的に格納し、F
/F 33は切替部91を介してRAM34(RAM
−RAM )のそれぞれから読み出On−1
されたヒストグラムデータDMO= DM(n−1)を
−時的に格納する。DDA37 (DDAo〜ODA
)はそれぞれ後述の回転運動漸化式を一回転角ごと
に演算するもので、それぞれアドレス信号α 、β を
入力してアドレス信号α1+1゜1 】
β を出力する。加算器であるADD351+1
(ADD −ADD )はFIFO17’からO
n−1
の濃淡値データD1と、RAM34からのあるヒトスゲ
ラムについてのヒストグラムデータDMo〜DH(n−
1)のそれぞれの加算を行なうもので、その出力はバッ
ファ36で一時的に保存された後に、切替部91を介し
てRAM −RAM のそれOn−1
ぞれに送られる。フリップフロップ(F/F)92はF
IFO17’からのウィンドウデータを一時的に格納し
、これを切替部91に送るためのものである。タイミン
グコントローラ25はこれら回路要素における信号処理
のタイミング制御を行なうもので、タイミングパルスφ
、φ 〜S a
φrを出力する。そして、図示しないコマンド/ステー
タス争インタフェース(1/F)に接続されている。The DDA operation circuits 188 to 18 in each stage shown in FIG. 1 each have three flip-flops (
F/F) 31, 32, and 33, F/F 31 temporarily stores address signals α0 to αn-1'β to β, respectively, and F/FOn-1 32 stores gray value data D1. Temporarily store each, F
/F 33 is connected to RAM 34 (RAM
- Temporarily stores the histogram data DMO=DM(n-1) read out from each of the RAMs. DDA37 (DDAo~ODA
) calculates the rotational motion recurrence formula described later for each rotation angle, and inputs address signals α and β and outputs an address signal α1+1°1]β. The adder ADD351+1 (ADD - ADD) inputs data from FIFO17' to O
n-1 gradation value data D1 and histogram data DMo to DH(n-
1), and the output thereof is temporarily stored in the buffer 36 and then sent to each of the RAMs (On-1) through the switching section 91. Flip-flop (F/F) 92 is F
It is used to temporarily store window data from the IFO 17' and send it to the switching section 91. The timing controller 25 controls the timing of signal processing in these circuit elements, and controls the timing pulse φ.
, φ to S a φr. It is connected to a command/status dispute interface (1/F) not shown.
次に、第1図および第2図に示す画像処理装置の全体的
動作の概要を、第3図により説明する。Next, an overview of the overall operation of the image processing apparatus shown in FIGS. 1 and 2 will be explained with reference to FIG. 3.
第3図はこれを説明するフローチャートである。FIG. 3 is a flowchart explaining this.
まず、カメラ11で取り込んだ原画像上の処理対象点ご
との画素信号を信号入力部12を介して入力しくステッ
プ102)、エツジ検出部13でエツジ検出を行なって
(ステップ104)エツジ化データを前処理部17へ入
力する(ステップ106)。以上のステップ102〜1
06の処理は、画素信号が入力されるごとに繰り返され
、結果(エツジ化データ)は順次に信号の前処理部17
にディジタルデータとして送られる。First, a pixel signal for each point to be processed on the original image captured by the camera 11 is inputted via the signal input section 12 (step 102), and the edge detection section 13 performs edge detection (step 104) to generate edge data. Input to the preprocessing section 17 (step 106). Above steps 102-1
The processing of 06 is repeated every time a pixel signal is input, and the result (edge data) is sequentially sent to the signal preprocessing unit 17.
is sent as digital data.
前処理部17では所定(後述)の前処理(ステップ10
8)を実行し、処理の終ったデータを初期値演算部40
へ送っていく(ステップ110)。この前処理について
も、エツジ化データが与えられるごとに順次に繰り返さ
れることになる。The preprocessing unit 17 performs predetermined (described later) preprocessing (step 10
8), and the processed data is sent to the initial value calculation unit 40.
(step 110). This preprocessing is also sequentially repeated each time edged data is provided.
次に、Hough曲線(サインカーブ)を求めるための
回転運動漸化式の演算が、後に説明する如(DDA演算
として実行される(ステップ112)訳であるが、この
演算に先立って、初期値の演算がステップ111におい
て実行される。Next, the calculation of the rotational motion recurrence formula for obtaining the Hough curve (sine curve) is executed as a DDA calculation (step 112), as will be explained later, but prior to this calculation, the initial value is executed in step 111.
そして、このDDA演算部18における演算は処理すべ
き一画面(原画像面)の画素信号のうち、前処理部17
でウィンドウ外あるいは閾値以下のものとして除かれた
画素以外の全ての処理が終了するまで継続され(ステッ
プ114)、終了したらHough曲線の交点に関して
後述のフィルタリング処理(ステップ116)とソーテ
ィング処理(118)が近傍フィルタ19およびソーテ
ィング部20で実行され、最終的な結果として原画像上
の処理対象点をつなぐ曲線の近似直線が求められること
になる。Then, the calculation in the DDA calculation unit 18 is performed on the pixel signals of one screen (original image plane) to be processed by the preprocessing unit 17.
The processing continues until all the pixels other than those excluded as outside the window or below the threshold are completed (step 114), and once completed, filtering processing (step 116) and sorting processing (118), which will be described later, are carried out regarding the intersection of the Hough curves. is executed by the neighborhood filter 19 and the sorting unit 20, and as a final result, an approximate straight line of a curve connecting the processing target points on the original image is obtained.
次に、エツジ検出部13におけるエツジ検出の手法およ
びエツジ化データについて、第4図により説明する。Next, the edge detection method and edged data in the edge detection section 13 will be explained with reference to FIG.
いま、カメラ11で取り込まれた原画像が第4図(a)
のようになっているとし、図中の符号8で示すラインを
X′座標で取り出してみると、輝度Sをアナログ的に示
せば同図(b)のようになっている。すなわち、道路3
の外側部は輝度が低く道路3および路肩も輝度が低いが
、路肩ライン4は輝度が非常に高い。ここで、第4図(
b)のような輝度分布は、実施例では例えば256階調
のディジタルデータとして認識されるが、道路の形状を
正確に認識するためには、このような輝度そのものの分
布の把握では十分ではない。The original image captured by the camera 11 is shown in Figure 4 (a).
If we take out the line indicated by reference numeral 8 in the figure using the X' coordinate, we can see that the luminance S is shown in analog form as shown in figure (b). That is, road 3
The brightness of the outer part of the road 3 and the road shoulder is low, but the brightness of the road shoulder line 4 is very high. Here, in Figure 4 (
In the embodiment, the brightness distribution as shown in b) is recognized as digital data of 256 gradations, but understanding the distribution of brightness itself is not sufficient to accurately recognize the shape of the road. .
そこで、信号入力部12を介して得られた画素信号の輝
度Sを座標X′で微分(dS/dX”)して輝度の変化
割合として把握すると、第4図(C)ようにエツジが明
瞭になり、これを絶対値IdS/dx’lで示すと同図
(d)のようになり、路肩ライン4のエツジを明瞭に認
識するためのエツジ化データ(ディジタルデータ)がエ
ツジ検出部13により得られる。このエツジ検出部13
からのエツジ化データについては、次のステップにおい
て前処理部17で所定の前処理が施される。Therefore, when the brightness S of the pixel signal obtained through the signal input section 12 is differentiated with respect to the coordinate X'(dS/dX'') and understood as the rate of change in brightness, the edges are clearly seen as shown in Figure 4 (C). When this is expressed as an absolute value IdS/dx'l, it becomes as shown in the same figure (d), and the edge detection unit 13 converts the edge data (digital data) to clearly recognize the edge of the road shoulder line 4. This edge detection section 13
In the next step, preprocessing section 17 performs predetermined preprocessing on the edged data.
第5図は前処理部17 (P I FO17’ )にお
ける前処理を説明するためのフローチャートである。FIG. 5 is a flowchart for explaining the preprocessing in the preprocessing section 17 (P I FO 17').
まず、第4図のようにして得られたエツジ化データがエ
ツジ検出部13から前処理部17に入力され(ステップ
122)、これがあらかじめ設定された複数のウィンド
ウのいずれのウィンドウ内のものであるかが判定される
(ステップ124)。First, the edge data obtained as shown in FIG. 4 is input from the edge detection section 13 to the preprocessing section 17 (step 122), and this data is input into any of a plurality of preset windows. It is determined whether (step 124).
このウィンドウは、例えば第4図(a)で符号9により
示す如く1個のみ設定してもよいが、本発明では複数の
ウィンドウを設定する。すなわち、第6図(a)の原画
像1に対して同図(b)のよ)に2個のウィンドウWD
、WD2を設定し、あるいは同図(C)のように3個の
ウィンドウWD −WD3を設定する。また、同図(d
)のようにウィンドウが重なるときには、いずれかのウ
ィンドウ(図ではWDl)を優先させる。Although only one window may be set, for example as shown by reference numeral 9 in FIG. 4(a), in the present invention, a plurality of windows are set. That is, for the original image 1 in FIG. 6(a), there are two windows WD in FIG. 6(b)).
, WD2, or three windows WD - WD3 as shown in FIG. 3(C). Also, the same figure (d
), when windows overlap, one of the windows (WDl in the figure) is given priority.
ここで、いずれのウィンドウWDの内側のエツジ化デー
タであるかは、そのデータ(処理対象点P)のX−Y座
標面における座標値(X、Y)p
により判定でき、いずれのウィンドウ内の工・ソジ化デ
ータであるのかを示す信号は、第2図のFIFE17’
からウィンドウデータとして出力される。そして、これ
らウィンドウ内のエツジ化データに対して、次のステッ
プ126が実行される。Here, which window WD the edged data is inside can be determined by the coordinate value (X, Y) p of the data (processing target point P) on the X-Y coordinate plane. The signal indicating whether it is engineering/solidification data is FIFE17' in Figure 2.
is output as window data. The next step 126 is then executed on the edged data within these windows.
ステップ126では、ウィンドウ内のエツジ化データが
所定の閾値(スレッショルドレベル)以上であるか否か
が、例えばFIFO17’ に付設されたルックアップ
テーブル(LUT)を用いてディジタル的に判定される
。すなわち、第7図に示すように、LUTを設けないと
きはPIF017′の入力データと出力データは1対1
で対応している(同図(a)図示)が、LUTを用いて
スレッショルドレベルを例えば” thに設定すると、
入力データがIth以下のときは出力データは0(ゼロ
)になる。なお、このエツジ化データに含まれる濃淡値
データを256階調で把えたときには、スレッショルド
レベルlthは0〜255の間で任意に設定可能である
。この閾値をアナログ的に示せば、例゛えば第4図(d
)で点線にて示すように設定されるので、ステップ12
6で処理された後のデータは、主として原画像中の路肩
ライン4およびセンターライン5に対応したデータ(デ
ィジタルデータ)となる。このため、後述の信号処理を
すべきデータが主要なもの(例えば道路の路肩ラインや
センターラインに対応したもの)だけになるので、ノイ
ズ成分に影響されることがなくなり、また全体の処理速
度を高速化できる。In step 126, it is digitally determined whether the edged data within the window is equal to or greater than a predetermined threshold value (threshold level) using, for example, a look-up table (LUT) attached to the FIFO 17'. That is, as shown in Fig. 7, when no LUT is provided, the input data and output data of PIF017' are 1:1.
(as shown in figure (a)), but if you use LUT to set the threshold level to ``th'',
When the input data is less than Ith, the output data becomes 0 (zero). Note that when the gradation value data included in this edged data is grasped in 256 gradations, the threshold level lth can be set arbitrarily between 0 and 255. If this threshold value is shown in analog form, for example, in Figure 4 (d
) is set as shown by the dotted line, so step 12
The data processed in step 6 becomes data (digital data) mainly corresponding to the road shoulder line 4 and center line 5 in the original image. Therefore, only the main data (for example, data corresponding to the shoulder line and center line of the road) need to be subjected to signal processing, which will be described later, so it is not affected by noise components and the overall processing speed is reduced. It can be made faster.
次に、ステップ128で座標変換が行なわれる。Next, in step 128, a coordinate transformation is performed.
すなわち、第4図(a)に示すX−Y座標からX−y座
標への変換がなされる。これにより、原画像における処
理対象点の座標(X、Y)はXp
−y座標系における座標(x、y)に変換さp
れる。以上の処理により、Hough変換をするための
前処理が終了する。That is, the X-Y coordinate shown in FIG. 4(a) is converted into the X-y coordinate. As a result, the coordinates (X, Y) of the processing target point in the original image are converted to coordinates (x, y) in the Xp-y coordinate system. The above processing completes the preprocessing for Hough transformation.
なお、第5図においてステップ124〜128の順序は
異なっていてもよい。例えば、ステップ128の座標変
換を最初に行なうようにしてもよいが、データ処理に要
する時間を考慮すると、第5図に示す順序で行なうのが
最も好ましいと考えられる。Note that the order of steps 124 to 128 in FIG. 5 may be different. For example, the coordinate transformation in step 128 may be performed first, but in consideration of the time required for data processing, it is considered most preferable to perform the coordinate transformation in the order shown in FIG.
次に、本実施例におけるHough変換の適用について
、第8図および第9図を参照して具体的に説明する。Next, application of the Hough transform in this embodiment will be specifically explained with reference to FIGS. 8 and 9.
第8図(a)に示す点P(x、y)についp
てHough曲線(サインカーブ)を求めると、これが
同図(C)のようになることは、既に第23図で説明し
た通りである。ところで、このようなサインカーブの軌
跡が同図(b)のような円運動の軌跡に置き換えられる
ことも、三角関数の定理より容易にわかる。言い換えれ
ば、同図(a)の点P(x、y)についてのHough
変換p
を実行して同図(c)のHough曲線を求めることは
、同図(b)のような円運動の円周の軌跡を求めること
と等価である。ここで、同図(b)の円は半径Rが
2 2 ) 1/2 、、、 (2)R■ρ 驕
(x +y
■、ax、p p
であり、円運動を点P(x、y)でのθ−p
O″に対応する点Q(α 、β。)から開始するとする
と、その初期値θ、は
θd−π/2−θlaX
但し、tan θ −y/x ・・・(3)
膳ax p p
である。また、このときρ−X、である。As already explained in Fig. 23, if a Hough curve (sine curve) is obtained for the point P (x, y) shown in Fig. 8 (a), it will become as shown in Fig. 8 (C). be. By the way, it is also easily understood from the theorem of trigonometric functions that the locus of such a sine curve can be replaced with the locus of circular motion as shown in FIG. In other words, Hough about point P (x, y) in figure (a)
Executing the transformation p to obtain the Hough curve shown in FIG. 3(c) is equivalent to obtaining the circumferential locus of circular motion as shown in FIG. 2(b). Here, the radius R of the circle in Figure (b) is 2 2 ) 1/2, (2) y), the initial value θ is θd-π/2-θlaX, where tan θ-y/x...( 3)
Zen ax pp. Also, at this time, ρ-X.
本発明者はこのような事実に着目し、第8図(b)の円
を描くに際して円運動の漸化式を適用し、第8図(a)
の点P(x、y)の同図p
(c)へのHough変換を簡単に行ないうる手法を見
出した。ここで、上記の円運動の漸化式によれば、α−
β直交座標系で座標(α 、β1)として表わされる一
点から一回転角εだけ進んだ点の座標(α 、β
)は、lを正の整数とtit tit
するときに
αtit”f(α 、β 、ε)
α 11
β −f (α 、β 、ε) ・・・(4)国
β 11
として求められる。The inventor focused on this fact and applied the recurrence formula of circular motion when drawing the circle shown in FIG. 8(b),
We have found a method that can easily perform Hough transformation of point P (x, y) to p (c) in the same figure. Here, according to the recurrence formula for circular motion above, α−
The coordinates (α , β
) is obtained as αtit”f (α, β, ε) α 11 β −f (α, β, ε) (4) country β 11 when l is a positive integer.
この(4)式の具体的内容としては、従来からDDAが
知れており、例えば回転角εをε−21(rad)(但
し、m−0,1,2,−)としたときに
a++I ”al −2β1
β −2α +β ・・・(5)ti
t tit i
とするものなどがある。また、より精度が高く計算が容
易なものとして本発明者が見出したものとして、
″″2麿−ニー1
β −2α +β1 (1−2
tit i
・・・ (7)
あるいは
α −α (1−2−”” )
1+l !
一厘 −3Il
+β (−2+ε /6)
−m −3vr
β −α (2+ε /6)tit
t
+β (1−2−””)
■
・・・ (8)
などを用いてもよい。As for the specific content of this equation (4), DDA has been known for a long time, and for example, when the rotation angle ε is set to ε-21 (rad) (however, m-0, 1, 2, -), a++I'' al -2β1 β -2α +β ... (5) ti
There is a method called t tit i. In addition, the inventor has found that the calculation is more accurate and easier, as follows: −2−”” ) 1+l ! Ichirin −3Il +β (−2+ε /6) −m −3vr β −α (2+ε /6)tit
t + β (1-2-"") ■ ... (8) etc. may also be used.
そこで、上記(7)式の漸化式を適用するとして、第2
図の回路の具体的な動作説明に先立ち、この演算方法を
具体的に説明する。Therefore, if we apply the recurrence formula of equation (7) above, the second
Prior to explaining the specific operation of the circuit shown in the figure, this calculation method will be specifically explained.
第9図はそのフローチャートである。まず、第5図に従
ってFIFO17’により前処理がされたデータを入力
しくステップ132)、回転運動漸化式の演算のための
初期値(α 、β0)を求める。第8図において処理対
象点P(x、y)p
に対応するHough曲線をρ−θ空間上の任意のθ′
(−θo)(rad)から描き始めるとすると、その
ときの円運動の開始点は
aom−xpsinθ’+y、cosθ′βo−x、c
osθ’+ypsinθ’ ・ (9)となる。こ
の(α 、β。)は初期値演算部40で計算され、DD
A演算部18にアドレス信号として与えられる。初期値
演算部40では、上記のsinθ’ 、 cosθ′の
値をあらかじめROM (図示せず)に記憶しておき、
これらのデータを参照しながら加算器、乗算器(共に図
示せず)を用いて(9)式の演算を行なえばよい。ここ
において、(9)式の演算は回転運動漸化式の演算に比
べて計算回数が多く、複雑でもあるが、1個の処理対象
点(x、y)に関して1回の演算を行なうp
たけであるので、全体の演算時間はあまり増加させるこ
とがなく、ハードウェアもあまり大きくならない。なお
、処理対象点P(x、y)におp
いてθ’−0@ 90@ 180° 270”から円運
動をスタートさせるときは、この初期値演算は極めて簡
単になる。FIG. 9 is a flow chart thereof. First, data preprocessed by the FIFO 17' according to FIG. 5 is input (step 132), and initial values (α, β0) for calculation of the rotational motion recurrence formula are determined. In Fig. 8, the Hough curve corresponding to the processing target point P(x,y)p is expressed as an arbitrary θ' on the ρ-θ space.
If we start drawing from (-θo) (rad), then the starting point of circular motion is aom-xpsinθ'+y, cosθ'βo-x, c
osθ'+ypsinθ' (9). This (α, β.) is calculated by the initial value calculation unit 40, and DD
It is given to the A calculation unit 18 as an address signal. The initial value calculation unit 40 stores the values of sin θ' and cos θ' in advance in a ROM (not shown),
The calculation of equation (9) may be performed using an adder and a multiplier (both not shown) while referring to these data. Here, although the calculation of equation (9) requires more calculations and is more complicated than the calculation of the rotational motion recurrence equation, it is necessary to perform one calculation for one processing target point (x, y). Therefore, the overall calculation time does not increase much, and the hardware does not increase too much. Note that when starting the circular motion from θ'-0@90@180°270'' at the processing target point P(x,y), this initial value calculation becomes extremely simple.
次に、上記の(9)式によるβ。の値をRAMoにウィ
ンドウに従ってアドレスとして記憶した後に、(7)式
によりα 、β を求める。Next, β according to the above equation (9). After storing the values in RAMo as addresses according to the window, α and β are determined by equation (7).
これは、(9)式で求めたα 、β。を(7)式に代入
すればDDAoの出力から求めることかでき(ステップ
136) 、DDA 、DDA2゜DDA 、・・
・における計算の終了ごとに結果(β 、β 、β 、
・・・)を順次にRAM1゜RAM 、RAM3・・
・にウィンドウに従ってアドレスとして記憶しておく
(ステップ138)。−方、このステップ136とステ
ップ138の間で濃淡値データの累積を行なっていく。These are α and β calculated using equation (9). can be obtained from the output of DDAo by substituting it into equation (7) (step 136), DDA , DDA2゜DDA ,...
The result (β , β , β ,
...) sequentially to RAM1゜RAM, RAM3...
・Memorize the address according to the window.
(Step 138). On the other hand, between step 136 and step 138, the gray value data is accumulated.
すなわち、アドレスβlとしてRAM34 (RAM、
)から読み出されたヒストグラムデータDM1と−FI
FO17′からの濃淡値データDIを加算し、これをR
AM、に再び記憶していく (ステップ137)。That is, the address βl is RAM34 (RAM,
) Histogram data DM1 and -FI read from
Add the gray value data DI from FO17' and add this to R.
AM, it is memorized again (step 137).
そして、円を1/2周するまでこの計算を一回転角εご
とに繰り返しくステップ140)、1/2周したら原画
像上の1つの処理対象点についてのHough曲線が、
上記によって記憶したβ0゜β 、β 、β 、・・・
の値とθ 、θ 、θ2゜・・・の値(回転角ε)より
求められるだけでなく、濃淡値データによる重み付けの
結果(ヒストグラMOMI M(n−1))も求
められる・ムデータD 、D 、・・・D
以下、第9図に示す処理を原画像上の全ての処理対象点
について実行すると、濃淡値データで重み付けがされた
複数のHough曲線がρ−θ座標系で求められること
になり、これらは第24図(b)のような交叉点を有す
ることになる。Then, step 140) repeats this calculation for each rotation angle ε until 1/2 of the circle is circled, and after 1/2 of the circle, the Hough curve for one processing point on the original image becomes
β0゜β , β , β ,... memorized above
It is not only determined from the values of θ, θ, θ2°, etc. (rotation angle ε), but also the result of weighting using grayscale value data (histogram MOMI M(n-1)). D,...D Hereinafter, when the processing shown in Fig. 9 is executed for all processing target points on the original image, multiple Hough curves weighted by gray value data can be obtained in the ρ-θ coordinate system. These will have an intersection point as shown in FIG. 24(b).
次に、第9図のフローチャートに示す動作を、第2図お
よび第10図を参照してより具体的に説明する。Next, the operation shown in the flowchart of FIG. 9 will be explained in more detail with reference to FIGS. 2 and 10.
まず、第9図のステップ132におけるデータの入力は
、第2図のFIFO17’からタイミングコントローラ
25にレディ信号が入力され、次いてリードストローブ
信号がタイミングコントローラ25からFIFO17’
に入力された後に、処理対象点Pの座標(x、y)が
F/F41p
に格納され、その点Pでの濃淡値データDIがF/F4
2に格納され、かつその点PのウィンドウデータWDが
位相を一致させるためF/F 95に格納された後にF
/F 92に格納されることでなされる。そして、タイ
ミングコントローラ25からのタイミングパルスφ に
同期して(X 。First, the data input in step 132 in FIG. 9 involves inputting a ready signal from the FIFO 17' in FIG. 2 to the timing controller 25, and then a read strobe signal from the timing controller 25 to the FIFO 17'
After the coordinates (x, y) of the point P to be processed are stored in the F/F 41p, the gray value data DI at that point P is stored in the F/F 41p.
2, and the window data WD at that point P is stored in F/F 95 in order to match the phase.
This is done by storing it in /F92. Then, in synchronization with the timing pulse φ from the timing controller 25 (X).
p
y )がF/F41から送出され、初期値演算部43で
処理対象点Pの座標値(x、y)からp
漸化式演算の初期値(α 、β。)が求められる。p y ) is sent from the F/F 41, and the initial value calculation unit 43 calculates the initial values (α, β.) of the p recurrence formula calculation from the coordinate values (x, y) of the processing target point P.
ステップ136の漸化式の演算は、初期値演算回路43
からの出力をアドレス信号α 、β0としてF/F 3
1に入力し、かつ処理対象点Pの濃淡値データD、をF
/F42からF/F 32に入力することで行なわれる
。ここで、このF/F31.32へのアドレスおよびデ
ータ入力は、タイミングコントローラ25からのタイミ
ングパルスに同期してなされる。そして、タイミングパ
ルスφ の立ち上り又は立ち下りに同期して、F/F3
1のアドレス信号α 、β0は最初のDDA。 (37
)に入力される。The calculation of the recurrence formula in step 136 is performed by the initial value calculation circuit 43.
The output from F/F 3 is used as address signals α and β0.
1, and the grayscale value data D of the processing target point P are input to F.
This is done by inputting from /F42 to F/F32. Here, addresses and data input to the F/Fs 31 and 32 are performed in synchronization with timing pulses from the timing controller 25. Then, in synchronization with the rising or falling of the timing pulse φ, the F/F3
Address signals α and β0 of 1 are the first DDA. (37
) is entered.
このDDAoでは、第9図のステップ136の処理がな
される。すなわち、前述の(7)式に従った漸化式の演
算が実行され、演算結果(アドレス信号α 、βl)は
次のF/F 31を通ってDDAI (図示せず)に送
られる。ここにおいて、上記漸化式(7)において、基
本的には三角関数の計算や乗算などは含まれておらず、
またメモリテーブル(ROM)の参照なども不要である
ので、演算を容易かつ迅速に行なうことができる。そし
て、これらは円運動を行なわせるにあたって、十分な精
度を有する(誤差が少ない)ものである。In this DDAo, the process of step 136 in FIG. 9 is performed. That is, the calculation of the recurrence formula according to the above-mentioned equation (7) is executed, and the calculation results (address signals α, βl) are sent to the DDAI (not shown) through the next F/F 31. Here, the above recurrence formula (7) basically does not include trigonometric function calculations or multiplications,
Further, since there is no need to refer to a memory table (ROM), calculations can be performed easily and quickly. These have sufficient accuracy (few errors) to perform circular motion.
なお、このDDA はDDA 〜DDA と0
1 n−1
同様に構成され、具体的には第10図のように4個の加
算器51〜54と3個のインバータ61〜63を含んで
構成される。第10図の回路への入力α 、β に対し
ては、出力α 、β は1 l
1+1 1+1
それぞれ前述の(7)式のとおり
2m−1
β −2α +β (1−2)国 1
1
となっている。Note that this DDA is DDA ~ DDA and 0
1 n-1 It is similarly configured, and specifically includes four adders 51 to 54 and three inverters 61 to 63 as shown in FIG. For inputs α and β to the circuit of FIG. 10, outputs α and β are 1 l
1+1 1+1
2m-1 β -2α +β (1-2) Country 1, respectively, as shown in equation (7) above.
1.
F/F 31に格納されたアドレス信号β。はRAMo
(34)にも与えられ、これによってRAMoに格納
されているヒストグラムデータDIIIoが読み出され
る。すなわち、RAMoにはβ0をアドレスとして、回
転角θ。(θ′−〇)に対応する他の処理対象点に関す
るヒストグラムデータD があらかじめ(先行するA
D D Oの演O
算により)記憶されており、従ってアドレス信号β0が
F/F 31からRAMoに与えられることで、RAM
34の読み出し/書き込みを制御するタイミングパルス
φbに同期してRAMoからF/F33にヒストグラム
データDMoが送られることになる。Address signal β stored in F/F 31. is RAMo
(34), and thereby the histogram data DIIIo stored in RAMo is read out. That is, RAMo has the rotation angle θ with β0 as the address. Histogram data D regarding other processing points corresponding to
Therefore, by giving address signal β0 from F/F 31 to RAMo, RAM
The histogram data DMo is sent from the RAMo to the F/F 33 in synchronization with the timing pulse φb that controls reading/writing of the F/F 33.
次に、タイミングコントローラ25からのタイミングパ
ルスφ に同期してF/F 33からADDo (35
)へヒストグラムデータDMoが送られるが、このAD
D、にはF/F 32から演算対象となっている処理対
象点(x、y)の濃p
淡値データDIが与えられている。従って、ADDoで
はそれまでにRA M oに蓄積されていた回転角θ。Next, in synchronization with the timing pulse φ from the timing controller 25, ADDo (35
), but this AD
D is given the dark p-dark value data DI of the processing target point (x, y) which is the calculation target from the F/F 32. Therefore, in ADDo, the rotation angle θ that had been stored in RAM o.
およびアドレスβ。に対応するヒストグラムデータDM
oと、処理されている最中の処理対象点(x、y)の回
転角θ。およびアトp
レスβ。に対応する濃淡値データD1が加算される(第
9図のステップ137)。そして、この加算結果(D
−DMo+D1)はバッファ36にM〇
一時的に保持された後、タイミングパルスφdに同期し
てRAMoに送られ、第9図のステップ138に従った
記憶がθ に対応するRAMoのアドレスβ0に対して
なされることになる。and address β. Histogram data DM corresponding to
o and the rotation angle θ of the processing target point (x, y) that is being processed. and atopresβ. The gray value data D1 corresponding to is added (step 137 in FIG. 9). Then, this addition result (D
-DMo+D1) is temporarily held in the buffer 36, and then sent to RAMo in synchronization with the timing pulse φd, and the memory according to step 138 in FIG. 9 is stored at address β0 of RAMo corresponding to θ. It will be done against.
上記の1のサイクルの処理において重要なことは、本発
明では前述のように原画像に対して複数のウィンドウが
設定されており、従ってRAM34の記憶部の切換え制
御が並行してなされていることである。すなわち、第1
1図に概略を示すように本実施例では、FIFO17’
は座標変換部93、LUT94の他にウィンドウデータ
生成部95を有し、このウィンドウデータ生成部95は
処理対象点Pの座標(X、Y)の値からつP
イントウWD −WDkに対応するウィンドラブ−タ
WDを出力するようになっている。また、RAM34は
このウィンドウWD −WDkに対応してに個の記憶
部を有しており、この記憶部のいずれにデータを記憶す
るかを切替部91を介してウィンドウデータWDで制御
するようになっている。従って、例えば第6図(b)の
如(2個のウィンドウWD、WD2が設定されるときは
、ウィンドウデータについても2種類となり、これは処
理対象点ごとのアドレス信号α 、β オヨび濃淡値デ
ータDIと同期して転送される。このため、RAM34
の各記憶部にはウィンドウごとのデータが格納されるこ
とになる。What is important in the processing of cycle 1 above is that in the present invention, multiple windows are set for the original image as described above, and therefore the switching control of the storage section of the RAM 34 is performed in parallel. It is. That is, the first
As schematically shown in Figure 1, in this embodiment, the FIFO 17'
has a window data generation section 95 in addition to the coordinate conversion section 93 and LUT 94, and this window data generation section 95 generates a window corresponding to P into WD - WDk from the coordinates (X, Y) of the processing point P. It is designed to output a love data WD. Further, the RAM 34 has storage units corresponding to the windows WD to WDk, and which storage unit to store data in is controlled by the window data WD via the switching unit 91. It has become. Therefore, for example, as shown in FIG. 6(b) (when two windows WD and WD2 are set, there are two types of window data, which correspond to the address signals α, β, and gradation values for each point to be processed. It is transferred in synchronization with the data DI.
Data for each window will be stored in each storage unit.
このように本発明では、ウィンドウごとに振り別けられ
てデータが格納されるため、原画像における処理対象点
の分布の大局的傾向を、極めて容易に抽出することがで
きる。例えば、第6図(a)のような道路の認識におい
て、原画像の全体を処理対象にすると、この中には地平
線や建物あるいはガードレールなども含まれることにな
り、これらの近似直線も多く抽出される。このため、道
路の路肩ラインの抽出が困難になる。これに対し、例え
ば第6図(b)のウィンドウW D 2のみを対象に処
理すれば、ここには地平線、建物、ガードレールなどは
ほとんど含まれず、従って路肩ラインの抽出が極めて容
易になる。In this way, in the present invention, data is sorted and stored for each window, so it is possible to extract the global trend of the distribution of processing target points in the original image very easily. For example, when recognizing a road as shown in Figure 6(a), if the entire original image is processed, the horizon, buildings, guardrails, etc. will be included, and many approximate straight lines of these will also be extracted. be done. This makes it difficult to extract the road shoulder line. On the other hand, if only the window W D 2 in FIG. 6(b) is processed, for example, the horizon, buildings, guardrails, etc. are hardly included, and therefore the road shoulder line can be extracted extremely easily.
上記の1サイクルの処理を、DDA演算回路181 (
1−1,2+ ・・・n−1)について説明すると第1
2図のようになる。なお、ウィンドウデータによる切替
時間については省略しである。The above one-cycle processing is performed by the DDA calculation circuit 181 (
1-1, 2+...n-1), the first
It will look like Figure 2. Note that the switching time based on window data is omitted.
まず、処理対象点の座標値(x、y)からp 求めたアドレス信号(初期値)α 、β をα。。First, from the coordinate values (x, y) of the point to be processed, p The obtained address signals (initial values) α and β are α. .
β−α、β−α、β−・・・α、βと
01122 tt
順次に演算した結果としてのアドレス信号α1゜β と
、この処理対象点(x、y)の濃淡値I
pI)
データDIが、それぞれF/F31および32から入力
されて保持され(ステップ202) 、F/F31から
アドレス信号α 、β1がDDA、t、:。β-α, β-α, β-...α, β and 01122 tt The address signal α1°β as a result of sequential calculation and the gray value I of this processing target point (x, y)
pI) Data DI is input from F/Fs 31 and 32 and held (step 202), and address signals α and β1 are sent from F/F 31 to DDA, t,:.
送られた後に、ステップ204でアドレス信号α1.β
にもとづく漸化式の演算がDDA、において実行され
る。そして、結果としてのアドレス信号α 、β
は、1サイクルの処理の終tit i+を
了に同期して、次のDDA演算回路18 中の1+1
DDA の前に設けられたF/F31に送られ1+
す
る。After being sent, in step 204, the address signal α1. β
The calculation of the recurrence formula based on the above is performed in the DDA. And the resulting address signals α,β
is sent to the F/F 31 provided in front of 1+1 DDA in the next DDA calculation circuit 18 in synchronization with the end of one cycle of processing, tit i+.
do.
一方、上記のアドレス信号β1によるヒストグラムデー
タDM1の読み出しがステップ206で実行される。こ
のステップ206は、第2図においてアドレス信号β1
をF/F 31から切替部91を介してRAM、に与え
、アドレスβlのヒストグラムデータDM、を切替部9
1を介してF/F33に格納することでなされる。そし
て、ステップ208でヒストグラムデータDM1の濃淡
値データD1の加算がされる。このステップ208は、
第2図のADD、で実行される。その後、ステップ20
8で加算されたヒストグラムデータDMl−D Ml
+ D +が、ステップ210においてRAM のア
ドレスβ0に書き込みされる。On the other hand, reading of the histogram data DM1 using the address signal β1 is executed in step 206. This step 206 corresponds to the address signal β1 in FIG.
is applied from the F/F 31 to the RAM via the switching unit 91, and the histogram data DM at address βl is applied to the switching unit 9.
This is done by storing it in the F/F 33 via 1. Then, in step 208, the gray value data D1 of the histogram data DM1 is added. This step 208 is
This is executed with ADD in FIG. Then step 20
Histogram data DMl-D Ml added in step 8
+D+ is written in the RAM at address β0 in step 210.
■
このヒストグラムデータの蓄積をより詳しく説明するた
めに、第13図を参照する。(2) To explain the accumulation of histogram data in more detail, refer to FIG. 13.
第13図は第2図のRAM34によるヒストグラムメモ
リの概念を示しており、説明を簡単にするためウィンド
ウの1つについてのみ図示している。図示の通り、ヒス
トグラムメモリはn個のRAM −RAM の領
域を有し、これらはn−n
−1Hou変換のρ−θ空間におけるθとなる漸化式演
算の回転角θ (−〇′)〜θ にそれOn−1
ぞれ対応している。そして、各RAM領域は+511〜
0〜−512のアドレスβ(−ρ)を有し、各アドレス
には16ビツトのヒストグラムデータ(濃淡値)を格納
できるようになっている。FIG. 13 shows the concept of the histogram memory using the RAM 34 of FIG. 2, and only one of the windows is illustrated for simplicity of explanation. As shown in the figure, the histogram memory has n RAM -RAM areas, and these are the rotation angles θ (-〇') to θ in the ρ-θ space of the n-n-1Hou transformation. On-1 corresponds to θ. And each RAM area is +511~
It has addresses β (-ρ) from 0 to -512, and each address can store 16-bit histogram data (shade values).
従って、DDAlで前述の(7)式により回転角θ
に対応するα 、β がアドレス信号!+1
1+1 1+1α1.β1
より計算されたときには、アドレス信号β1がRAM1
に与えられてアドレスβ1のヒストグラムデータD
が読み出される。そして、N(1)
処理対象点の濃淡値データD1との加算がなされて再び
ヒストグラムデータ(DMi+DI)がRAM、のアド
レスβ1に書き込まれる。Therefore, in DDAl, the rotation angle θ is determined by equation (7) above.
α and β corresponding to are address signals! +1
1+1 1+1α1. β1
When the address signal β1 is calculated from RAM1
Histogram data D at address β1 given to
is read out. Then, the histogram data (DMi+DI) is added to the gradation value data D1 of the N(1) processing target point and written to the address β1 of the RAM again.
以上の通り、式(7)に示す漸化式の演算は、アドレス
信号α 、β1を次々と受は渡すことでバイブライン方
式によりなされる。そして、このαl、β からα
、β への演算中にヒス1 1+1
1+1トゲラムデータD の濃淡値データD1によ
る蓄積(累積)がなされるので、1サイクル全体の処理
に要する時間を短くできる。As described above, the calculation of the recurrence formula shown in equation (7) is performed by the Vibrine method by receiving and passing the address signals α and β1 one after another. And from this αl, β
, hiss 1 1+1 during operation to β
Since the 1+1 togerum data D is accumulated (accumulated) using the grayscale value data D1, the time required for the entire processing of one cycle can be shortened.
この1サイクルの処理は、DDA演算部18を構成する
DDA演算回路18〜18 で同時On−1
並行的になされる。すなわち、第14図(a)のように
FIFO17’から
“■、空、■、空、空、■、■、空”
のデータが入力されたときは、1サイクル目では同図(
b)のようになり、2サイクル目では同図(C)のよう
になり、3サイクル目では同図(d)のようになり、以
下同様の処理がなされて、8サイクル目には同図(e)
のようになる。ここで、同図(a)中の(α 、β )
〜(α 、β )01 0f 04 04
は処理対象点p −p の座標値(x y
)1 4 p1’ 91〜(xp4”
F4)にそれぞれ対応するアドレス信号であり、DI
t〜DI4はその処理対象点P1〜P4のそれぞれにお
ける濃淡値データである。また、同図(b)〜(e)に
おけるθ 〜θ はOn−1
初期値(α 、β。)を求めた位置(角度)θ′からの
回転角であり、それぞれ第2図のRAM。This one-cycle processing is performed in parallel by the DDA arithmetic circuits 18 to 18 constituting the DDA arithmetic unit 18. That is, when the data "■, empty, ■, empty, empty, ■, ■, empty" is input from the FIFO 17' as shown in FIG.
In the second cycle, it becomes as shown in (C) in the same figure, and in the third cycle, it becomes as shown in (d) in the same figure, and the same process is performed thereafter, and in the eighth cycle, it becomes as shown in (d) in the same figure. (e)
become that way. Here, (α, β) in the same figure (a)
~ (α, β) 01 0f 04 04 is the coordinate value (x y
)1 4 p1'91~(xp4"
F4) respectively corresponding address signals, and DI
t to DI4 are gray value data at each of the processing target points P1 to P4. Further, in (b) to (e) of the same figure, θ to θ are rotation angles from the position (angle) θ' at which the On-1 initial values (α, β.) were obtained, and are the RAM of FIG. 2, respectively.
〜RAM に対応する。- Corresponds to RAM.
次に、Hough変換を終了した後の近傍フィルタリン
グについて説明する。Next, neighborhood filtering after Hough transformation is completed will be described.
いま、Hough曲線の交点をρ−θ平面で表現したと
きに、第15図(a)のようになったとする。なお、同
図(a)はρ−θ平面の一単位ごとで現われる交叉点に
ついて、原画像における画素(処理対象点)の濃淡値デ
ータ(輝度の変化割合)による重みづけを行なったヒス
トグラムHを、説明をわかりやすくするために等高腺で
表現したものであり、本発明によるヒストグラムとは必
ずしも一致するものではない。Now, when the intersection of the Hough curves is expressed on the ρ-θ plane, it is assumed that it becomes as shown in FIG. 15(a). Note that (a) in the same figure shows a histogram H in which the intersection points appearing in each unit of the ρ-θ plane are weighted by the gray value data (change rate of brightness) of the pixels (processing target points) in the original image. , which is expressed as a contour scale to make the explanation easier to understand, and does not necessarily match the histogram according to the present invention.
ここで、同図(a)の点p1においてヒストグラムが高
(、その他に点p2.p3においてもヒストグラムが高
くなっているものとする。点p1の近傍に着目すると、
そこには点p4.p5などにもヒストグラムの高い部分
が生じていることがわかる。ところが画像処理において
特に重要なのは、互いに離れた点p1〜p3を見出すこ
とであって、例えば点p1は道路の路肩ラインに、点p
2はセンターラインに、そして点p3は前方のカーブし
た道路の路肩ラインに対応している。これに対して、最
大ヒストグラム点p1の近傍の点p4.p5などは路肩
ラインの部分的な曲りなどに対応していることが多く、
画像処理上は主として雑音成分にあたる。Here, it is assumed that the histogram is high at point p1 in FIG.
There is a point p4. It can be seen that high histogram portions also occur in p5 and the like. However, what is particularly important in image processing is to find points p1 to p3 that are far apart from each other. For example, point p1 is located on the shoulder line of the road, and point p
2 corresponds to the center line, and point p3 corresponds to the shoulder line of the curved road ahead. On the other hand, the point p4 near the maximum histogram point p1. P5 etc. often correspond to partial bends in the road shoulder line, etc.
In terms of image processing, this mainly corresponds to a noise component.
そこで、このような雑音成分の影響は例えば8近傍フイ
ルタリングにより少なくされる。すなわち、第15図(
b)のような8近傍フイルタを用意L、F −F
のエリアについてHough曲線の交叉点のヒストグラ
ム同士を比較する。そして、中心のエリアF5に対して
、
F >F −F 、F −Fが成り立
つときに、このエリアF5のデータを検出すべきデータ
とする。具体的には、例えばF1〜F9について1個づ
つのρ−θ面での単位(要素エリア)画素を割り当てた
ときに、交叉点のヒストグラム数が
F 1−6 F 2−8F a −4F4−2 F
5−14、F6−10゜F 7” 7 F g−9F
9讃8となったときは、F >F −F SF
−F5 1 4 θ 9
が成立するので、F5の交叉点を検出すべきデータとす
る。これに対し、
F、−8F2−4 F3−3
F −14、F5−10、F6−7
F7−9 F8−8 F9−2
となったときは、F5<F4であるので、F5のエリア
は検出すべきデータとしない。Therefore, the influence of such noise components is reduced by, for example, 8-neighborhood filtering. In other words, Fig. 15 (
Prepare an 8-neighborhood filter like b) L, F −F
Compare the histograms of the intersections of the Hough curves for the area. Then, when F > F - F and F - F hold for the central area F5, the data of this area F5 is set as the data to be detected. Specifically, for example, when one unit (element area) pixel on the ρ-θ plane is assigned to F1 to F9, the number of histograms of intersection points is F 1-6 F 2-8F a -4F4- 2 F
5-14, F6-10°F 7” 7F g-9F
When it becomes 9 and 8, F > F −F SF
Since −F5 1 4 θ 9 holds true, the intersection point of F5 is set as the data to be detected. On the other hand, when F, -8F2-4 F3-3 F -14, F5-10, F6-7 F7-9 F8-8 F9-2, F5<F4, so the area of F5 is Not considered data to be detected.
上記のようなフィルタリング処理は、第16図のような
近傍フィルタで行なう。すなわち、第13図の如く構成
されるヒストグラムメモリ(RAM34)に信号読出回
路71を付設し、これから読出したデータをラインバッ
ファ72.73を介して9個の格納領域(F t〜F9
)を有するシフトレジスタ74に入力する。そして、シ
フトレジスタのF−F、F6〜F9のヒストグラムデー
タD をコンパレータC−C,C〜M
148
09のそれぞれに入力すると共に、F5のヒストグラム
データDHを全てのコンパレータに入力する。すると、
ヒストグラムメモリ34の各エリアのヒストグラムデー
タが図のようにDM1〜DM9となっているときには、
データDM5の値が他のデータD−D、D −D
と比較される。そして、MI M4 MB
M9
DM5が最大のときにアンドゲート75からピーク信号
が“1”として出力され、このときのデータDM5がピ
ークデータとなる。The above filtering process is performed using a neighborhood filter as shown in FIG. That is, a signal readout circuit 71 is attached to the histogram memory (RAM 34) configured as shown in FIG.
) to a shift register 74 having a Then, the histogram data D of F-F and F6 to F9 of the shift register are transferred to comparators C-C and C-M.
148 and 09, and also inputs the histogram data DH of F5 to all comparators. Then,
When the histogram data in each area of the histogram memory 34 is DM1 to DM9 as shown in the figure,
The value of data DM5 is different from other data D-D, D-D
compared to And MI M4 MB
When M9 DM5 is at its maximum, the AND gate 75 outputs a peak signal as "1", and data DM5 at this time becomes peak data.
以上のフィルタリング処理を行なうことにより、第15
図(a)において点p4.p5の存在に影響されること
なく、第2および第3のヒストグラムの高い点p2.p
3を検出することができる。By performing the above filtering process, the 15th
In figure (a), point p4. The high points of the second and third histograms, p2., are unaffected by the presence of p5. p
3 can be detected.
すなわち、もし上記のフィルタリングを行なわなかった
とすると、第1の高ヒストグラム点p1に次ぐ高ヒスト
グラム点は点p4.p5となり、第2および第3の高ヒ
ストグラム点として求めたい点p2.p3は、第4およ
び第5の高ヒストグラム点となってしまい、後の信号処
理が著しく困難になってしまう。なお、この8近傍フイ
ルタについては前述のウィンドウに対応させたハードウ
ェアを設ける必要がなく、同一の構成のもので全てのウ
ィンドウに対応することができる。That is, if the above filtering were not performed, the next high histogram point after the first high histogram point p1 would be point p4. p5, and the point p2. which is desired to be obtained as the second and third high histogram points. p3 becomes the fourth and fifth high histogram points, making subsequent signal processing extremely difficult. It should be noted that this 8-neighborhood filter does not need to be provided with hardware that corresponds to the above-mentioned windows, and can be used for all windows with the same configuration.
次に、第3図でステップ118として示すソーティング
処理につき、第17図により詳細に説明する。Next, the sorting process shown as step 118 in FIG. 3 will be explained in detail with reference to FIG. 17.
第17図はそのフローチャートである。まず、ソーティ
ング処理のために、それぞれ複数(但し、説明を簡単に
するために4とする)の入力メモリ(転送メモリ)M1
□〜M+4と比較メモリ(結果メそり)MMl〜MM4
を用意し、これを初期化する(ステップ152)。次に
、入力メモリM11にデータを入力しくステップ154
)、この入力データがステップ156で有りとされたと
きはステップ158〜184を実行し、無しとされたと
きはステップ190〜199を実行していく。ここで、
ステップ190,196.199の処理はそれぞれステ
ップ158,160の処理と同一であり、ステップ19
2.198の処理はそれぞれステップ162〜168の
処理と同一であり、ステップ194の処理はステップ1
70〜176の処理と同一である。FIG. 17 is a flow chart thereof. First, for sorting processing, a plurality of input memories (transfer memories) M1
□~M+4 and comparison memory (result memory) MMl~MM4
is prepared and initialized (step 152). Next, step 154 is performed to input data into the input memory M11.
), when this input data is determined to be present in step 156, steps 158 to 184 are executed, and when it is determined to be absent, steps 190 to 199 are executed. here,
The processing in steps 190, 196 and 199 is the same as the processing in steps 158 and 160, respectively, and
2. The processing in step 198 is the same as the processing in steps 162 to 168, and the processing in step 194 is the same as that in step 1.
This is the same as the processing in steps 70-176.
ステップ158,162,170,178ではそれぞれ
対応する入力メモリM1と比較メモリM の内容の大小
を比較し、M1≦MMのときに翼
は人力メモリM1の内容を次に転送する(ステップ16
4,172,180)。これに対し、Ml〉M のとき
には比較メモリMMの内容を次の入バ
カメモリM1に転送する(ステップ166゜174.1
82)共に、入力メモリM1の内容を対応する比較メモ
リMMに入れる(ステップ168.176.184)。In steps 158, 162, 170, and 178, the contents of the corresponding input memory M1 and comparison memory M are compared, and when M1≦MM, the wing transfers the contents of the human memory M1 to the next one (step 16).
4,172,180). On the other hand, when Ml>M, the contents of comparison memory MM are transferred to the next input memory M1 (step 166゜174.1).
82) Together, put the contents of the input memory M1 into the corresponding comparison memory MM (step 168.176.184).
すると、最終的には比較メモリMMl= MM。には、
大きい順にn個の入力データが保持されることになる。Then, finally, comparison memory MMl=MM. for,
n pieces of input data are held in ascending order.
これを具体的に示すと、第18図および第19図のよう
になる。まず第18図(a)のように、入力メモリとし
て4個のメモリMIt〜M+4および比較メモリとして
4個のメモリMMl〜MM4を用意し、これらをペアに
して4段の回路とする。各段の回路は第18図(b)の
ように、ペアの入力メモリM および比較メモリMMと
、スイッチング回路81.82と、これを制御するコン
パ1−タ83で構成される。入力メモリM!に入力され
たヒストグラムデータが比較メモリMMに格納されたデ
ータより大きいときは、コンパレータ83の出力により
スイッチング回路81が図中の実線のようになり、入力
されたデータは比較メモリMMに格納される。同時に、
スイッチング回路82も実線のようになっているので、
比較メモリMMに格納されていたデータは次段に送られ
る。これに対し、入力データ(入力メモリM、)が比較
メモリMMに格納されたデータより小さいときは、コン
パレータ83の制御によりスイッチング回路81.82
は図中の点線のようになり、入力データはそのまま次段
に送られ、比較メモリMMの内容は変化しない。This is specifically shown in FIGS. 18 and 19. First, as shown in FIG. 18(a), four memories MIt to M+4 are prepared as input memories and four memories MMl to MM4 are prepared as comparison memories, and these are paired to form a four-stage circuit. As shown in FIG. 18(b), each stage of circuitry is composed of a pair of input memory M and comparison memory MM, switching circuits 81 and 82, and a comparator 83 for controlling them. Input memory M! When the histogram data input to is larger than the data stored in the comparison memory MM, the output of the comparator 83 causes the switching circuit 81 to change as shown by the solid line in the figure, and the input data is stored in the comparison memory MM. . at the same time,
Since the switching circuit 82 is also shown as a solid line,
The data stored in comparison memory MM is sent to the next stage. On the other hand, when the input data (input memory M,) is smaller than the data stored in the comparison memory MM, the switching circuits 81 and 82 are controlled by the comparator 83.
is as shown by the dotted line in the figure, the input data is sent as is to the next stage, and the contents of the comparison memory MM do not change.
このようなソーティング部において、入力されるデータ
が第19図(a)のように
“5,7,2,8,4.9,3,1,6.8”の10個
であるとする。すると、同図(b)のような初期化操作
を行なった後に、比較メモリMMl〜MM4に格納され
るデータは同図(C)に矢印で示すように変化し、最終
的には
比較メモリM Ml −9
〜 M M 2 ”’ 8
・ MM3−8
″ MM4″″7
の内容が格納されることになる。なお、このソーティン
グ処理についても、ウィンドウに対応させたハードウェ
アを設ける必要がない。また、この処理はソフトウェア
により実行してもよい。In such a sorting section, it is assumed that the input data are 10 pieces of data "5, 7, 2, 8, 4.9, 3, 1, 6.8" as shown in FIG. 19(a). Then, after performing the initialization operation as shown in FIG. 5(b), the data stored in the comparison memories MM1 to MM4 change as shown by the arrows in FIG. The contents of Ml-9 to MM2"'8, MM3-8", MM4""7 will be stored. Note that this sorting process also does not require the provision of hardware compatible with windows. Further, this process may be executed by software.
以上のような一連の処理を実行することにより、本発明
に係る画像処理装置による信号処理の全ステップが終了
する。そして、原画像の処理対象点を結ぶ曲線の近似直
線が、上記のρ、θの値によってウィンドウごとに求ま
ることになる。By executing the series of processes as described above, all steps of signal processing by the image processing apparatus according to the present invention are completed. Then, an approximate straight line of a curve connecting the processing target points of the original image is determined for each window based on the values of ρ and θ.
本発明は上記の実施例に限定されるものではなく、各種
の変形が可能である。The present invention is not limited to the above embodiments, and various modifications are possible.
例えば、ウィンドウの設定は、あらかじめ定められてい
てもよく、処理結果に応じて変更できるようになってい
てもよい。また、FIFOの外側にウィンドウデータ生
成部が構成されていてもよい。For example, the window settings may be predetermined or may be changed depending on the processing results. Further, a window data generation section may be configured outside the FIFO.
Hough曲線の交叉点のヒストグラムを求めるに際し
ては、輝度の変化割合(微分されたエツジ化データの値
)に関する濃淡値データの代りに2値化データを重畳す
ることで、交叉点の集中のみをヒストグラムとして把え
ることもできる。さらに、微分によってエツジ化データ
とせずに、輝度に対応するデータをそのまま濃淡値デー
タとしてディジタル処理し、その後にHough曲線の
交叉点のヒストグラムを求めるようにしてもよい。When obtaining a histogram of intersection points of Hough curves, by superimposing binarized data instead of gray value data regarding the rate of change in brightness (value of differentiated edged data), only the concentration of intersection points can be obtained as a histogram. It can also be understood as Furthermore, instead of converting the data into edge data through differentiation, the data corresponding to the luminance may be digitally processed as gradation value data, and then the histogram of the intersection of the Hough curves may be obtained.
回転運動漸化式の演算は、必ずしも近似円の全周(−周
)について行なうことは必須ではなく、1/2周、1/
4周あるいは178周などとしてもよい。例えば1/4
周の演算をO≦θくπ/2およびπ≦θく3π/2につ
いて実行するだけのDDAを直列に配置して計算を実行
すれば、他の円周(π/2≦θくπ、3π/2≦θく2
π)上の値はこれらから直ちに求めることができる。ま
た、回転角は常に同一とすることは必ずしも必要ではな
く、一部において異ならせることも不可能ではない。ま
た、直線の性質から1/2周(0゜〜180”)をHo
ugh変換の対象としてもよい。It is not necessary to calculate the rotational motion recurrence formula for the entire circumference (-circumference) of the approximate circle, but for 1/2 circumference, 1/2 circumference, etc.
It may be 4 laps or 178 laps. For example 1/4
If the calculation is performed by arranging DDAs in series that perform circumference calculations for O≦θ×π/2 and π≦θ×3π/2, then other circumferences (π/2≦θ×π, 3π/2≦θku2
π) can be immediately determined from these. Further, it is not necessarily necessary that the rotation angles are always the same, and it is not impossible to make them partially different. Also, due to the nature of the straight line, 1/2 circle (0° ~ 180") is Ho
It may also be a target of ugh conversion.
回転運動漸化式を演算するDDAの具体的構成は、第2
0図のようになっていてもよい。すなわち、6個の加算
器51〜56と4個のインバータ61〜63.99と2
個の1/6除算器65゜66で構成する。このDDAに
よれば、前述の(8)式を実行することができる。また
、第21図のように、2個の加算器51.52と1個の
インバータ61で構成してもよい。このようにすれば、
前述の(5)式の演算を実行することができる。The specific configuration of the DDA that calculates the rotational motion recurrence formula is as follows.
It may be as shown in Figure 0. That is, six adders 51 to 56 and four inverters 61 to 63.99 and 2
It consists of 1/6 dividers 65°66. According to this DDA, the above-mentioned equation (8) can be executed. Alternatively, as shown in FIG. 21, it may be configured with two adders 51, 52 and one inverter 61. If you do this,
The calculation of equation (5) above can be executed.
以上、詳細に説明した通り本発明によれば、同一構成の
DDA演算回路を単に直列接続するだけで簡単に演算部
を形成でき、演算に際してメモリテーブルなどを参照す
ることが不要であるので、構成が著しく簡単かつ小型に
なる。また、バイブライン方式で回転運動漸化式を実行
するように演算回路を構成することで、計算を高速化す
ることが可能になる。さらに、原画像は複数のウィンド
ウに分割されるので、大局的な傾向の把握が極めて容易
になる。As described above in detail, according to the present invention, a calculation unit can be easily formed by simply connecting DDA calculation circuits with the same configuration in series, and there is no need to refer to a memory table or the like during calculation. becomes significantly simpler and smaller. In addition, by configuring the arithmetic circuit to execute the rotational motion recurrence formula using the Vibrine method, it is possible to speed up the calculation. Furthermore, since the original image is divided into multiple windows, it is extremely easy to grasp global trends.
第1図は本発明の一実施例に係る画像処理装置の全体構
成を示すブロック図、第2図は第1図の要部の構成を示
すブロック図、第3図はその作用を全体的に示すフロー
チャート、第4図は画像の一例と入力された画素信号の
エツジ検出を説明する図、第5図はエツジ化データの前
処理を説明するフローチャート、第6図はウィンドウの
設定例を示す図、第7図はルックアップテーブルを説明
する図、第8図は本発明の実施例におけるHough変
換を説明する図、第9図は絶倒における回転運動の漸化
式の演算を示すフローチャート、第10図は回転運動漸
化式を演算するDDA、の具体的な構成を示す回路図、
第11図はウィンドウデータによる切替え構成を示す図
、第12図は1サイクルの処理を説明する図、第13図
はヒストグラムメモリの概念図、第14図は実施例にお
けるパイプライン処理を説明する図、第15図は8近傍
フイルタリング処理を説明する図、第16図は近傍フィ
ルタの具体的構成を示す図、第17図はソーティング処
理を説明するフローチャート、第18図はソーティング
部の具体的構成を説明する図、第19図はソーティング
処理を具体的に説明する図、第20図および第21図は
回転運動漸化式を演算するDDA、の具体的構成の他の
例を示す図、第22図は道路の認識を説明する図、第2
3図ないし第25図は、従来のHough変換を説明す
る図である。
1・・・カメラ画像、2・・・水平線、3・・・道路、
4・・・路肩ライン、5・・・センターライン、11・
・・カメラ、12・・・信号入力部、13・・・エツジ
検出部、14・・・多値化メモリ、15・・・D/A変
換部、16・・・CRTデイスプレィ、17・・・前処
理部、17′・・・FIFo、18・・・DDA演算部
とヒストグラムメモリ、18〜18 ・・・DDA演
算回On−1
路とヒストグラムメモリ、19・・・近傍フィルタ、2
0・・・ソーティング部、21.23・・・VMEバス
、22・・・CPU、31,32,33.92・・・フ
リップフロップ(F/F) 、34−RAMo〜RAM
(ヒストグラムメモリ)、35・・・ADD
−ADD (加算器)、36・・・ノくラフOn
−1
ア、37・・・DDA 〜D D A n−t (
D D A演算回路)、40・・・初期値演算部、91
・・・切替部、95・・・ウィンドウデータ生成部。
特許出願人 本田技研工業株式会社
代理人弁理士 長谷用 芳 樹前処理のフロー
チャート
第5図
入力データ
(a)LUTなし
入力データ
(b)LUTあり
ルックアップテーブル(LUT)
第7図
の作用
第
図
第
図
第
図
?l−7.トゲラムメモリの概念
第13図
第
図
ソーティングの説明
第 19 図(2)
斥
図
L2
道路の認識
第22図
第
図
Hough変換の説明
(II)FIG. 1 is a block diagram showing the overall configuration of an image processing device according to an embodiment of the present invention, FIG. 2 is a block diagram showing the configuration of the main parts of FIG. 1, and FIG. 3 shows the overall operation. 4 is a diagram illustrating an example of an image and edge detection of an input pixel signal, FIG. 5 is a flowchart illustrating preprocessing of edged data, and FIG. 6 is a diagram illustrating an example of window settings. , FIG. 7 is a diagram explaining a lookup table, FIG. 8 is a diagram explaining Hough transformation in an embodiment of the present invention, FIG. Figure 10 is a circuit diagram showing the specific configuration of the DDA that calculates the rotational motion recurrence formula,
FIG. 11 is a diagram showing a switching configuration based on window data, FIG. 12 is a diagram explaining one cycle processing, FIG. 13 is a conceptual diagram of a histogram memory, and FIG. 14 is a diagram explaining pipeline processing in an embodiment. , FIG. 15 is a diagram explaining the 8-neighbor filtering process, FIG. 16 is a diagram showing the specific configuration of the neighborhood filter, FIG. 17 is a flowchart explaining the sorting process, and FIG. 18 is the specific configuration of the sorting section. FIG. 19 is a diagram specifically explaining the sorting process, and FIGS. Figure 22 is a diagram explaining road recognition.
3 to 25 are diagrams illustrating conventional Hough transformation. 1... Camera image, 2... Horizon, 3... Road,
4... Road shoulder line, 5... Center line, 11.
. . . Camera, 12 . Preprocessing section, 17'... FIFo, 18... DDA operation section and histogram memory, 18-18... DDA operation circuit On-1 path and histogram memory, 19... Neighborhood filter, 2
0... Sorting section, 21.23... VME bus, 22... CPU, 31, 32, 33.92... Flip-flop (F/F), 34-RAMo~RAM
(histogram memory), 35...ADD
-ADD (adder), 36...Nokuraf On
-1 A, 37...DDA ~D D A n-t (
DDA calculation circuit), 40... initial value calculation section, 91
. . . switching section, 95 . . . window data generation section. Patent Applicant: Honda Motor Co., Ltd. Representative Patent Attorney Yoshiki Hase Pre-processing flowchart Figure 5 Input data (a) Input data without LUT (b) Lookup table with LUT (LUT) Figure 7 Function diagram Diagram Diagram? l-7. Concept of togeram memory Fig. 13 Fig. Explanation of sorting Fig. 19 (2) Diagram L2 Road recognition Fig. 22 Fig. Explanation of Hough transformation (II)
Claims (10)
理対象点の分布の特徴から、これら処理対象点を結ぶ曲
線を分別、抽出する画像処理装置において、 前記原画像を複数のウィンドウに分割する分割手段と、 同一構成のDDA演算要素を複数直列接続して構成され
、前記処理対象点に関して所定の演算を行なうDDA演
算手段と、 このDDA演算手段の演算結果を前記DDA演算要素に
対応して前記ウィンドウごとに記憶する記憶手段と、 この記憶手段の記憶内容にもとづき、前記曲線を前記ウ
ィンドウごとに分別、抽出する手段とを備えることを特
徴とする画像処理装置。1. In an image processing device that separates and extracts a curve connecting processing target points from characteristics of the distribution of a plurality of processing target points on an original image captured by an imaging means, the dividing means divides the original image into a plurality of windows. a DDA calculation means configured by connecting a plurality of DDA calculation elements of the same configuration in series and performs a predetermined calculation on the processing target point; and a calculation result of the DDA calculation means is transmitted to the window in correspondence with the DDA calculation element. An image processing apparatus comprising: a storage means for storing each window; and a means for classifying and extracting the curve for each window based on the stored contents of the storage means.
理対象点を結ぶ曲線の近似直線を導出する画像処理装置
において、 前記原画像を複数のウィンドウに分割する分割手段と、 a−β直交座標系で描かれる近似円の円周上の一点の座
標を(α_i,β_i)とし、前記円周上の次の点の座
標(α_i_+_1,β_i_+_1)までの回転角を
εとしたとき(但し、iは正の整数)に、 α_i_+_1=f_α(α_i,β_i,ε)β_i
_+_1=f_β(α_i,β_i,ε)となる回転運
動漸化式を、前記処理対象点に対して所定回転角ごとに
順次にパイプライン方式で演算するDDA演算手段と、 このDDA演算手段により順次に演算されたそれぞれの
結果のうち、少なくとも前記β_iの値を前記ウィンド
ウごとに記憶する記憶手段と、この記憶手段の記憶内容
にもとづいて得られる前記複数の処理対象点ごとのHo
ugh曲線の交点から、前記近似直線を前記ウィンドウ
ごとに導出する近似直線導出手段と を備えることを特徴とする画像処理装置。2. An image processing device that derives an approximate straight line of a curve connecting a plurality of processing target points on an original image captured by an imaging means, comprising: a dividing means that divides the original image into a plurality of windows; Let the coordinates of one point on the circumference of the approximate circle drawn be (α_i, β_i), and let the rotation angle to the coordinates (α_i_+_1, β_i_+_1) of the next point on the circumference be ε (however, i is positive). ), α_i_+_1=f_α(α_i, β_i, ε) β_i
a DDA calculation means that sequentially calculates a rotational motion recurrence formula such as ___+_1=f_β(α_i, β_i, ε) for each predetermined rotation angle with respect to the processing target point in a pipeline manner; A storage means for storing at least the value of β_i for each window among the respective results calculated in
An image processing apparatus comprising: approximate straight line deriving means for deriving the approximate straight line for each window from the intersection of the ugh curves.
の座標にもとづきウィンドウデータを出力することを特
徴とする請求項2記載の画像処理装置。3. 3. The image processing apparatus according to claim 2, wherein the dividing means outputs window data based on the coordinates of the processing target point on the original image.
1回転角ごとにそれぞれ演算する複数の演算回路を直列
接続して構成されていることを特徴とする請求項2記載
の画像処理装置。4. 3. The image processing apparatus according to claim 2, wherein the DDA calculation means is configured by connecting in series a plurality of calculation circuits that calculate the rotational motion recurrence formula for each rotation angle.
mとしたときに、 α_i_+_1=α_i(1−2^−^2^m^−^1
)−2^−^mβ_iβ_i_+_1=2^−^mα_
i+β_i(1−2^−^2^m^−^1)であること
を特徴とする請求項2記載の画像処理装置。5. The rotational motion recurrence formula sets the rotational angle to ε=2^-^
When m, α_i_+_1=α_i(1-2^-^2^m^-^1
)-2^-^mβ_iβ_i_+_1=2^-^mα_
The image processing apparatus according to claim 2, wherein i+β_i(1-2^-^2^m^-^1).
記回転角に対応させて前記ウィンドウごとに記憶するこ
とを特徴とする請求項2記載の画像処理装置。6. 3. The image processing apparatus according to claim 2, wherein the storage means stores at least the value of β_i for each window in correspondence with the rotation angle.
点の輝度もしくはその変化割合に対応した濃淡値データ
を前記ウィンドウごとに記憶することを特徴とする請求
項2記載の画像処理装置。7. 3. The image processing apparatus according to claim 2, wherein the storage means stores gradation value data corresponding to the brightness or the rate of change of the brightness of the processing target point in the original image for each window.
点の濃淡値データを、前記回転角に対応させて前記ウィ
ンドウごとに記憶することを特徴とする請求項6記載の
画像処理装置。8. 7. The image processing apparatus according to claim 6, wherein the storage means stores the gradation value data of the processing target point in the original image for each window in correspondence with the rotation angle.
ング処理をする近傍フィルタを有することを特徴とする
請求項2記載の画像処理装置。9. 3. The image processing apparatus according to claim 2, wherein the approximate straight line deriving means includes a neighborhood filter that performs neighborhood filtering processing on data regarding the intersection of the Hough curves.
タを重畳したデータについて近傍フィルタリング処理を
する近傍フィルタを有することを特徴とする請求項7記
載の画像処理装置。10. 8. The image processing apparatus according to claim 7, wherein the approximate straight line deriving means includes a neighborhood filter that performs neighborhood filtering processing on data obtained by superimposing the gradation value data on data related to the intersection of the Hough curves.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP1027850A JP2935847B2 (en) | 1989-02-07 | 1989-02-07 | Image processing device |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP1027850A JP2935847B2 (en) | 1989-02-07 | 1989-02-07 | Image processing device |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH02206883A true JPH02206883A (en) | 1990-08-16 |
JP2935847B2 JP2935847B2 (en) | 1999-08-16 |
Family
ID=12232395
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP1027850A Expired - Fee Related JP2935847B2 (en) | 1989-02-07 | 1989-02-07 | Image processing device |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP2935847B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114056920A (en) * | 2021-09-30 | 2022-02-18 | 江西省通讯终端产业技术研究院有限公司 | Machine vision-based laminating machine and sheet stock calibration method and control method thereof |
-
1989
- 1989-02-07 JP JP1027850A patent/JP2935847B2/en not_active Expired - Fee Related
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114056920A (en) * | 2021-09-30 | 2022-02-18 | 江西省通讯终端产业技术研究院有限公司 | Machine vision-based laminating machine and sheet stock calibration method and control method thereof |
Also Published As
Publication number | Publication date |
---|---|
JP2935847B2 (en) | 1999-08-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US5379353A (en) | Apparatus and method for controlling a moving vehicle utilizing a digital differential analysis circuit | |
US5247587A (en) | Peak data extracting device and a rotary motion recurrence formula computing device | |
JPH03294976A (en) | Reference mark pattern detecting device | |
JPH02206883A (en) | Picture processor | |
JPH01281577A (en) | Image processor | |
JPH0232481A (en) | Peak data extractor | |
JPH01281579A (en) | Image processor | |
JPS61193004A (en) | Extracting device for image feature | |
JPH0560147B2 (en) | ||
JPH0346045B2 (en) | ||
JPH01281578A (en) | Image processing system | |
JPS6275205A (en) | Contour extracting device | |
Cucchiara et al. | A real-time hardware implementation of the Hough transform | |
JPH06231249A (en) | Object recognition system | |
JP2859453B2 (en) | Image thinning method | |
Fuller | Optimization and Hardware Implementation of SYBA-An Efficient Feature Descriptor | |
JP2000231640A (en) | Method and device for deciding boundary of article | |
KR0158416B1 (en) | Object locating method using contraction of visual data | |
JPH07113975B2 (en) | Center of gravity detector | |
JPS61208171A (en) | Drawing reader | |
JPH0470665B2 (en) | ||
JPS62186374A (en) | Boundary extracting device | |
JPH03150689A (en) | Numeral recognizing method | |
JPS6383881A (en) | Image processor | |
JPH06243252A (en) | Curve component extracting device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
LAPS | Cancellation because of no payment of annual fees |