ヒステリシス特性による2値化(ランレングスを利用したアルゴリズム)
Namespace: fvalgcliAssembly: fvalgcli (in fvalgcli.dll) Version: 3.1.0.0 (3.1.0.11)
Syntax
C# |
---|
public static int fnFIE_hysteresis_rle_uf(
FHANDLE hMag,
double dTHigh,
double dTLow,
uint uiNoiseEdge,
FHANDLE hImg
) |
Visual Basic |
---|
Public Shared Function fnFIE_hysteresis_rle_uf (
hMag As FHANDLE,
dTHigh As Double,
dTLow As Double,
uiNoiseEdge As UInteger,
hImg As FHANDLE
) As Integer |
Parameters
- hMag
- Type: fvalgcli..::..FHANDLE
エッジ勾配強度画像(type: uc8, s16, us16, double)
- dTHigh
- Type: System..::..Double
閾値の上限
- dTLow
- Type: System..::..Double
閾値の下限
- uiNoiseEdge
- Type: System..::..UInt32
ノイズとみなすエッジの最大面積。uiNoiseEdge より小さいなエッジはノイズとみなし、削除される
- hImg
- Type: fvalgcli..::..FHANDLE
出力画像(type: uc8, bin)
Return Value
Type:
Int32
以下のエラーコードを返します。
エラーコード:f_err | 内容 |
---|
F_ERR_NONE | 正常終了 |
F_ERR_INVALID_PARAM | 不正なパラメータが渡された
- dTLow 、または dTHigh が入力画像のダイナミックレンジを越えている
- dTLow > dTHigh
|
F_ERR_INVALID_IMAGE | 各画像のサイズが違う、不正な画像が渡された \ 画像サイズの横縦いずれかが
3以下, 或いは (2^16 - 1) 以上
|
F_ERR_NOMEMORY | メモリ不足エラー |
F_ERR_NO_LICENCE | ライセンスエラー、または未初期化エラー |
Examples
C# | Copy |
---|
using System;
using System.Collections.Generic;
using System.Text;
using fvalgcli;
namespace TC
{
public partial class FIE
{
[FvPluginExecute]
public void fnFIE_hysteresis_rle_uf()
{
int status = (int)f_err.F_ERR_NONE;
FHANDLE hsrc1 = FHANDLE.Zero;
FHANDLE hdst = FHANDLE.Zero;
try
{
api.fnFIE_load_img_file(TestImageDir + "/testdata/gray_04.bmp", ref hsrc1, f_color_img_type.F_COLOR_IMG_TYPE_UC8);
int width = api.fnFIE_img_get_width(hsrc1);
int height = api.fnFIE_img_get_height(hsrc1);
int channels = api.fnFIE_img_get_channels(hsrc1);
int type = api.fnFIE_img_get_type(hsrc1);
hdst = api.fnFIE_img_root_alloc(type, channels, width, height);
status = api.fnFIE_hysteresis_rle_uf(hsrc1, 128, 100, 10, hdst);
Assert.IsTrue(status == (int)f_err.F_ERR_NONE, "エラーが発生しました。({0})", (f_err)status);
api.fnFIE_save_png(ResultDir + "/fnFIE_hysteresis_rle_uf.png", hdst, -1);
}
finally
{
hsrc1.Dispose();
hdst.Dispose();
}
}
}
} |
Visual Basic | Copy |
---|
Imports System.Collections.Generic
Imports System.Text
Imports fvalgcli
Public Partial Class FIE
<FvPluginExecute> _
Public Sub fnFIE_hysteresis_rle_uf()
Dim status As Integer = CInt(f_err.F_ERR_NONE)
Dim hsrc1 As FHANDLE = FHANDLE.Zero
Dim hdst As FHANDLE = FHANDLE.Zero
Try
api.fnFIE_load_img_file(TestImageDir & "/testdata/gray_04.bmp", hsrc1, f_color_img_type.F_COLOR_IMG_TYPE_UC8)
Dim width As Integer = api.fnFIE_img_get_width(hsrc1)
Dim height As Integer = api.fnFIE_img_get_height(hsrc1)
Dim channels As Integer = api.fnFIE_img_get_channels(hsrc1)
Dim type As Integer = api.fnFIE_img_get_type(hsrc1)
hdst = api.fnFIE_img_root_alloc(type, channels, width, height)
status = api.fnFIE_hysteresis_rle_uf(hsrc1, 128, 100, 10, hdst)
Assert.IsTrue(status = CInt(f_err.F_ERR_NONE), "エラーが発生しました。({0})", CType(status, f_err))
api.fnFIE_save_png(ResultDir & "/fnFIE_hysteresis_rle_uf.png", hdst, -1)
Finally
hsrc1.Dispose()
hdst.Dispose()
End Try
End Sub
End Class |
See Also