// 数字認識
        internal static int recognizeDigit(CvMat image)
        {
            int nonzero = 0;

            nonzero = image.GetCols( image.Cols-2, image.Cols ).CountNonZero();
            if ( image.Rows * 2 == nonzero )
                // 1 右端2列がすべて輝点
                return 1;

            nonzero = image.GetRows( image.Rows-2, image.Rows ).CountNonZero();
            if ( image.Cols * 2 == nonzero )
                // 2 下端2行がすべて輝点
                return 2;

            nonzero = image.GetRows ( 0, 2 ).CountNonZero();
            if ( image.Cols * 2 - 2 < nonzero )
                // 7 上端2行がすべて輝点.ただし1ピクセルまで欠けても良い
                return 7;

            nonzero = image.GetCols ( image.Cols-3, image.Cols-1 ).CountNonZero();
            if ( image.Rows * 2 == nonzero )
                // 4 右端の左2列がすべて輝点
                return 4;

            CvRect rect = new CvRect( 0, 0, 1, image.Rows*2/3 );
            CvMat subarr;
            nonzero = image.GetSubArr ( out subarr, rect ).CountNonZero();
            if ( 0 == nonzero )
                // 3 左端の上部3分の2がすべて暗点
                return 3;

            rect = new CvRect ( 0, image.Rows/2, 3, 2 );
            nonzero = image.GetSubArr ( out subarr, rect ).CountNonZero();
            if ( 0 == nonzero )
                // 5 左端の下半分開始すぐのwidth3 height2 がすべて暗点
                return 5;

            rect = new CvRect ( image.Cols/2, image.Rows/2-1, 1, 3 );
            nonzero = image.GetSubArr( out subarr, rect ).CountNonZero();
            if ( 0 == nonzero )
                // 0 中央列中央3ピクセルがすべて暗点
                return 0;

            rect = new CvRect ( image.Cols-1, 0, 1, image.Rows*2/5 );
            nonzero = image.GetSubArr( out subarr, rect ).CountNonZero();
            if ( 0 == nonzero )
                // 6 右端上部5分の2がすべて暗点
                return 6;

            rect = new CvRect ( image.Cols-1, image.Rows-3, 1, 3 );
            nonzero = image.GetSubArr( out subarr, rect ).CountNonZero();
            if ( 0 == nonzero )
                // 右端下部3ピクセルがすべて暗点
                return 9;

            // 8 上記条件を満たさない
            return 8;
        }
        public CharactersInfo(CvMat _image)
        {
            positions = new List<CvRect>();

            // 画像コピー
            image = _image.Clone();

            // 文字列認識
            // 輝点列検索フラグ.falseなら暗点列を探す
            bool searchingBright = true;
            // 始点
            int left = 0;
            // 終点
            int right;

            for (int col = 0; col < image.Cols; col++)
            {
                // 列の輝点数
                int nonzero = image.GetCol(col).CountNonZero();

                // 探索モードによる分岐
                if ( true == searchingBright)
                {
                    // 輝点列探索中
                    if (0 < nonzero)
                    {
                        // 輝点が1個以上あったなら
                        left = col;
                        // フラグ切り替え
                        searchingBright = false;
                    }
                }
                else
                {
                    // 暗点列探索中
                    if (0 == nonzero)
                    {
                        // 暗点列だったなら
                        right = col;
                        // LowestWidth を満足するか
                        if (CharactersInfo.LowestWidth > right - left)
                        {
                            // 条件を満たさない場合は探索やり直し
                            searchingBright = true;
                            continue;
                        }

                        // 文字と認める
                        CvMat character = image.GetCols( left, right );
                        // 上端輝点行を探す
                        int top = 0;
                        for (int row = 0; row < character.Rows; row++)
                        {
                            if (0 < character.GetRow(row).CountNonZero())
                            {
                                // 輝点発見
                                top = row;
                                break;
                            }
                        }
                        // 下端輝点行を探す
                        int bottom = character.Rows - 1;
                        for (int row = bottom; row > top; row--)
                        {
                            if (0 < character.GetRow(row).CountNonZero())
                            {
                                // 輝点発見
                                bottom = row + 1;
                                break;
                            }
                        }
                        // 文字領域確定
                        positions.Add(new CvRect(left, top, right - left, bottom - top));
                        // 探索フラグ切り替え
                        searchingBright = true;
                    }
                }
            }
        }