Detector.smali 
.class public final Lcom/dcloud/zxing2/pdf417/detector/Detector;
.super Ljava/lang/Object;
# static fields
.field private static final BARCODE_MIN_HEIGHT:I = 0xa
.field private static final INDEXES_START_PATTERN:[I
.field private static final INDEXES_STOP_PATTERN:[I
.field private static final MAX_AVG_VARIANCE:F = 0.42f
.field private static final MAX_INDIVIDUAL_VARIANCE:F = 0.8f
.field private static final MAX_PATTERN_DRIFT:I = 0x5
.field private static final MAX_PIXEL_DRIFT:I = 0x3
.field private static final ROW_STEP:I = 0x5
.field private static final SKIPPED_ROW_COUNT_MAX:I = 0x19
.field private static final START_PATTERN:[I
.field private static final STOP_PATTERN:[I
# direct methods
.method static constructor <clinit>()V
    .registers 2
    const/4 v0, 0x4
    new-array v1, v0, [I
    .line 1
    fill-array-data v1, :array_22
    sput-object v1, Lcom/dcloud/zxing2/pdf417/detector/Detector;->INDEXES_START_PATTERN:[I
    new-array v0, v0, [I
    .line 2
    fill-array-data v0, :array_2e
    sput-object v0, Lcom/dcloud/zxing2/pdf417/detector/Detector;->INDEXES_STOP_PATTERN:[I
    const/16 v0, 0x8
    new-array v0, v0, [I
    .line 8
    fill-array-data v0, :array_3a
    sput-object v0, Lcom/dcloud/zxing2/pdf417/detector/Detector;->START_PATTERN:[I
    const/16 v0, 0x9
    new-array v0, v0, [I
    .line 10
    fill-array-data v0, :array_4e
    sput-object v0, Lcom/dcloud/zxing2/pdf417/detector/Detector;->STOP_PATTERN:[I
    return-void
    :array_22
    .array-data 4
        0x0
        0x4
        0x1
        0x5
    .end array-data
    :array_2e
    .array-data 4
        0x6
        0x2
        0x7
        0x3
    .end array-data
    :array_3a
    .array-data 4
        0x8
        0x1
        0x1
        0x1
        0x1
        0x1
        0x1
        0x3
    .end array-data
    :array_4e
    .array-data 4
        0x7
        0x1
        0x1
        0x3
        0x1
        0x1
        0x1
        0x2
        0x1
    .end array-data
.end method
.method private constructor <init>()V
    .registers 1
    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V
    return-void
.end method
.method private static copyToResult([Lcom/dcloud/zxing2/ResultPoint;[Lcom/dcloud/zxing2/ResultPoint;[I)V
    .registers 6
    const/4 v0, 0x0
    .line 1
    :goto_1
    array-length v1, p2
    if-ge v0, v1, :cond_d
    .line 2
    aget v1, p2, v0
    aget-object v2, p1, v0
    aput-object v2, p0, v1
    add-int/lit8 v0, v0, 0x1
    goto :goto_1
    :cond_d
    return-void
.end method
.method public static detect(Lcom/dcloud/zxing2/BinaryBitmap;Ljava/util/Map;Z)Lcom/dcloud/zxing2/pdf417/detector/PDF417DetectorResult;
    .registers 4
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Lcom/dcloud/zxing2/BinaryBitmap;",
            "Ljava/util/Map<",
            "Lcom/dcloud/zxing2/DecodeHintType;",
            "*>;Z)",
            "Lcom/dcloud/zxing2/pdf417/detector/PDF417DetectorResult;"
        }
    .end annotation
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/dcloud/zxing2/NotFoundException;
        }
    .end annotation
    .line 1
    invoke-virtual {p0}, Lcom/dcloud/zxing2/BinaryBitmap;->getBlackMatrix()Lcom/dcloud/zxing2/common/BitMatrix;
    move-result-object p0
    .line 3
    invoke-static {p2, p0}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->detect(ZLcom/dcloud/zxing2/common/BitMatrix;)Ljava/util/List;
    move-result-object p1
    .line 14
    invoke-interface {p1}, Ljava/util/List;->isEmpty()Z
    move-result v0
    if-eqz v0, :cond_16
    .line 15
    invoke-virtual {p0}, Lcom/dcloud/zxing2/common/BitMatrix;->rotate90()Lcom/dcloud/zxing2/common/BitMatrix;
    move-result-object p0
    .line 16
    invoke-static {p2, p0}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->detect(ZLcom/dcloud/zxing2/common/BitMatrix;)Ljava/util/List;
    move-result-object p1
    .line 19
    :cond_16
    invoke-interface {p1}, Ljava/util/List;->isEmpty()Z
    move-result v0
    if-eqz v0, :cond_24
    .line 20
    invoke-virtual {p0}, Lcom/dcloud/zxing2/common/BitMatrix;->rotate90()Lcom/dcloud/zxing2/common/BitMatrix;
    move-result-object p0
    .line 21
    invoke-static {p2, p0}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->detect(ZLcom/dcloud/zxing2/common/BitMatrix;)Ljava/util/List;
    move-result-object p1
    .line 24
    :cond_24
    invoke-interface {p1}, Ljava/util/List;->isEmpty()Z
    move-result v0
    if-eqz v0, :cond_32
    .line 25
    invoke-virtual {p0}, Lcom/dcloud/zxing2/common/BitMatrix;->rotate90()Lcom/dcloud/zxing2/common/BitMatrix;
    move-result-object p0
    .line 26
    invoke-static {p2, p0}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->detect(ZLcom/dcloud/zxing2/common/BitMatrix;)Ljava/util/List;
    move-result-object p1
    .line 29
    :cond_32
    new-instance p2, Lcom/dcloud/zxing2/pdf417/detector/PDF417DetectorResult;
    invoke-direct {p2, p0, p1}, Lcom/dcloud/zxing2/pdf417/detector/PDF417DetectorResult;-><init>(Lcom/dcloud/zxing2/common/BitMatrix;Ljava/util/List;)V
    return-object p2
.end method
.method private static detect(ZLcom/dcloud/zxing2/common/BitMatrix;)Ljava/util/List;
    .registers 10
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(Z",
            "Lcom/dcloud/zxing2/common/BitMatrix;",
            ")",
            "Ljava/util/List<",
            "[",
            "Lcom/dcloud/zxing2/ResultPoint;",
            ">;"
        }
    .end annotation
    .line 30
    new-instance v0, Ljava/util/ArrayList;
    invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
    const/4 v1, 0x1
    const/4 v2, 0x0
    move v3, v2
    move v4, v3
    :goto_9
    move v5, v4
    .line 34
    :goto_a
    invoke-virtual {p1}, Lcom/dcloud/zxing2/common/BitMatrix;->getHeight()I
    move-result v6
    if-ge v3, v6, :cond_7f
    .line 35
    invoke-static {p1, v3, v4}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->findVertices(Lcom/dcloud/zxing2/common/BitMatrix;II)[Lcom/dcloud/zxing2/ResultPoint;
    move-result-object v4
    .line 37
    aget-object v6, v4, v2
    if-nez v6, :cond_54
    const/4 v6, 0x3
    aget-object v7, v4, v6
    if-nez v7, :cond_54
    if-nez v5, :cond_20
    goto :goto_7f
    .line 46
    :cond_20
    invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator;
    move-result-object v4
    :cond_24
    :goto_24
    invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
    move-result v5
    if-eqz v5, :cond_50
    invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
    move-result-object v5
    check-cast v5, [Lcom/dcloud/zxing2/ResultPoint;
    .line 47
    aget-object v7, v5, v1
    if-eqz v7, :cond_40
    int-to-float v3, v3
    .line 48
    aget-object v7, v5, v1
    invoke-virtual {v7}, Lcom/dcloud/zxing2/ResultPoint;->getY()F
    move-result v7
    invoke-static {v3, v7}, Ljava/lang/Math;->max(FF)F
    move-result v3
    float-to-int v3, v3
    .line 50
    :cond_40
    aget-object v7, v5, v6
    if-eqz v7, :cond_24
    .line 51
    aget-object v5, v5, v6
    invoke-virtual {v5}, Lcom/dcloud/zxing2/ResultPoint;->getY()F
    move-result v5
    float-to-int v5, v5
    invoke-static {v3, v5}, Ljava/lang/Math;->max(II)I
    move-result v3
    goto :goto_24
    :cond_50
    add-int/lit8 v3, v3, 0x5
    move v4, v2
    goto :goto_9
    .line 58
    :cond_54
    invoke-interface {v0, v4}, Ljava/util/List;->add(Ljava/lang/Object;)Z
    if-nez p0, :cond_5a
    goto :goto_7f
    :cond_5a
    const/4 v3, 0x2
    .line 64
    aget-object v5, v4, v3
    if-eqz v5, :cond_6d
    .line 65
    aget-object v5, v4, v3
    invoke-virtual {v5}, Lcom/dcloud/zxing2/ResultPoint;->getX()F
    move-result v5
    float-to-int v5, v5
    .line 66
    aget-object v3, v4, v3
    invoke-virtual {v3}, Lcom/dcloud/zxing2/ResultPoint;->getY()F
    move-result v3
    goto :goto_7b
    :cond_6d
    const/4 v3, 0x4
    .line 68
    aget-object v5, v4, v3
    invoke-virtual {v5}, Lcom/dcloud/zxing2/ResultPoint;->getX()F
    move-result v5
    float-to-int v5, v5
    .line 69
    aget-object v3, v4, v3
    invoke-virtual {v3}, Lcom/dcloud/zxing2/ResultPoint;->getY()F
    move-result v3
    :goto_7b
    float-to-int v3, v3
    move v4, v5
    move v5, v1
    goto :goto_a
    :cond_7f
    :goto_7f
    return-object v0
.end method
.method private static findGuardPattern(Lcom/dcloud/zxing2/common/BitMatrix;IIIZ[I[I)[I
    .registers 16
    .line 1
    array-length v0, p6
    const/4 v1, 0x0
    invoke-static {p6, v1, v0, v1}, Ljava/util/Arrays;->fill([IIII)V
    .line 2
    array-length v0, p5
    move v2, v1
    .line 8
    :goto_7
    invoke-virtual {p0, p1, p2}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
    move-result v3
    if-eqz v3, :cond_18
    if-lez p1, :cond_18
    add-int/lit8 v3, v2, 0x1
    const/4 v4, 0x3
    if-ge v2, v4, :cond_18
    add-int/lit8 p1, p1, -0x1
    move v2, v3
    goto :goto_7
    :cond_18
    move v2, p4
    move v3, v1
    move p4, p1
    :goto_1b
    const v4, 0x3ed70a3d    # 0.42f
    const v5, 0x3f4ccccd    # 0.8f
    const/4 v6, 0x2
    const/4 v7, 0x1
    if-ge p1, p3, :cond_60
    .line 14
    invoke-virtual {p0, p1, p2}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
    move-result v8
    xor-int/2addr v8, v2
    if-eqz v8, :cond_32
    .line 16
    aget v4, p6, v3
    add-int/2addr v4, v7
    aput v4, p6, v3
    goto :goto_5d
    :cond_32
    add-int/lit8 v8, v0, -0x1
    if-ne v3, v8, :cond_57
    .line 19
    invoke-static {p6, p5, v5}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->patternMatchVariance([I[IF)F
    move-result v5
    cmpg-float v4, v5, v4
    if-gez v4, :cond_45
    new-array p0, v6, [I
    aput p4, p0, v1
    aput p1, p0, v7
    return-object p0
    .line 22
    :cond_45
    aget v4, p6, v1
    aget v5, p6, v7
    add-int/2addr v4, v5
    add-int/2addr p4, v4
    add-int/lit8 v4, v0, -0x2
    .line 23
    invoke-static {p6, v6, p6, v1, v4}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
    .line 24
    aput v1, p6, v4
    .line 25
    aput v1, p6, v8
    add-int/lit8 v3, v3, -0x1
    goto :goto_59
    :cond_57
    add-int/lit8 v3, v3, 0x1
    .line 30
    :goto_59
    aput v7, p6, v3
    xor-int/lit8 v2, v2, 0x1
    :goto_5d
    add-int/lit8 p1, p1, 0x1
    goto :goto_1b
    :cond_60
    sub-int/2addr v0, v7
    if-ne v3, v0, :cond_73
    .line 35
    invoke-static {p6, p5, v5}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->patternMatchVariance([I[IF)F
    move-result p0
    cmpg-float p0, p0, v4
    if-gez p0, :cond_73
    new-array p0, v6, [I
    aput p4, p0, v1
    sub-int/2addr p1, v7
    aput p1, p0, v7
    return-object p0
    :cond_73
    const/4 p0, 0x0
    return-object p0
.end method
.method private static findRowsWithPattern(Lcom/dcloud/zxing2/common/BitMatrix;IIII[I)[Lcom/dcloud/zxing2/ResultPoint;
    .registers 25
    move/from16 v0, p1
    const/4 v1, 0x4
    new-array v2, v1, [Lcom/dcloud/zxing2/ResultPoint;
    move-object/from16 v10, p5
    .line 3
    array-length v3, v10
    new-array v11, v3, [I
    move/from16 v12, p3
    :goto_c
    const/4 v13, 0x0
    const/4 v14, 0x1
    if-ge v12, v0, :cond_5c
    const/4 v7, 0x0
    move-object/from16 v3, p0
    move/from16 v4, p4
    move v5, v12
    move/from16 v6, p2
    move-object/from16 v8, p5
    move-object v9, v11
    .line 5
    invoke-static/range {v3 .. v9}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->findGuardPattern(Lcom/dcloud/zxing2/common/BitMatrix;IIIZ[I[I)[I
    move-result-object v3
    if-eqz v3, :cond_59
    move/from16 v18, v12
    move-object v12, v3
    move/from16 v3, v18
    :goto_26
    if-lez v3, :cond_40
    add-int/lit8 v15, v3, -0x1
    const/4 v7, 0x0
    move-object/from16 v3, p0
    move/from16 v4, p4
    move v5, v15
    move/from16 v6, p2
    move-object/from16 v8, p5
    move-object v9, v11
    .line 8
    invoke-static/range {v3 .. v9}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->findGuardPattern(Lcom/dcloud/zxing2/common/BitMatrix;IIIZ[I[I)[I
    move-result-object v3
    if-eqz v3, :cond_3e
    move-object v12, v3
    move v3, v15
    goto :goto_26
    :cond_3e
    add-int/2addr v15, v14
    goto :goto_41
    :cond_40
    move v15, v3
    .line 16
    :goto_41
    new-instance v3, Lcom/dcloud/zxing2/ResultPoint;
    aget v4, v12, v13
    int-to-float v4, v4
    int-to-float v5, v15
    invoke-direct {v3, v4, v5}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
    aput-object v3, v2, v13
    .line 17
    new-instance v3, Lcom/dcloud/zxing2/ResultPoint;
    aget v4, v12, v14
    int-to-float v4, v4
    invoke-direct {v3, v4, v5}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
    aput-object v3, v2, v14
    move v3, v14
    move v12, v15
    goto :goto_5d
    :cond_59
    add-int/lit8 v12, v12, 0x5
    goto :goto_c
    :cond_5c
    move v3, v13
    :goto_5d
    add-int/lit8 v4, v12, 0x1
    if-eqz v3, :cond_d3
    const/4 v15, 0x2
    new-array v3, v15, [I
    .line 26
    aget-object v5, v2, v13
    invoke-virtual {v5}, Lcom/dcloud/zxing2/ResultPoint;->getX()F
    move-result v5
    float-to-int v5, v5
    aput v5, v3, v13
    aget-object v5, v2, v14
    invoke-virtual {v5}, Lcom/dcloud/zxing2/ResultPoint;->getX()F
    move-result v5
    float-to-int v5, v5
    aput v5, v3, v14
    move-object/from16 v16, v3
    move v9, v4
    move v8, v13
    :goto_7a
    if-ge v9, v0, :cond_b6
    .line 28
    aget v4, v16, v13
    const/4 v7, 0x0
    move-object/from16 v3, p0
    move v5, v9
    move/from16 v6, p2
    move v1, v8
    move-object/from16 v8, p5
    move/from16 v17, v9
    move-object v9, v11
    invoke-static/range {v3 .. v9}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->findGuardPattern(Lcom/dcloud/zxing2/common/BitMatrix;IIIZ[I[I)[I
    move-result-object v3
    if-eqz v3, :cond_ab
    .line 33
    aget v4, v16, v13
    aget v5, v3, v13
    sub-int/2addr v4, v5
    .line 34
    invoke-static {v4}, Ljava/lang/Math;->abs(I)I
    move-result v4
    const/4 v5, 0x5
    if-ge v4, v5, :cond_ab
    aget v4, v16, v14
    aget v6, v3, v14
    sub-int/2addr v4, v6
    .line 35
    invoke-static {v4}, Ljava/lang/Math;->abs(I)I
    move-result v4
    if-ge v4, v5, :cond_ab
    move-object/from16 v16, v3
    move v8, v13
    goto :goto_b2
    :cond_ab
    const/16 v3, 0x19
    if-le v1, v3, :cond_b0
    goto :goto_b9
    :cond_b0
    add-int/lit8 v8, v1, 0x1
    :goto_b2
    add-int/lit8 v9, v17, 0x1
    const/4 v1, 0x4
    goto :goto_7a
    :cond_b6
    move v1, v8
    move/from16 v17, v9
    :goto_b9
    add-int/lit8 v8, v1, 0x1
    sub-int v4, v17, v8
    .line 47
    new-instance v0, Lcom/dcloud/zxing2/ResultPoint;
    aget v1, v16, v13
    int-to-float v1, v1
    int-to-float v3, v4
    invoke-direct {v0, v1, v3}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
    aput-object v0, v2, v15
    .line 48
    new-instance v0, Lcom/dcloud/zxing2/ResultPoint;
    aget v1, v16, v14
    int-to-float v1, v1
    invoke-direct {v0, v1, v3}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
    const/4 v1, 0x3
    aput-object v0, v2, v1
    :cond_d3
    sub-int/2addr v4, v12
    const/16 v0, 0xa
    if-ge v4, v0, :cond_e1
    const/4 v0, 0x4
    :goto_d9
    if-ge v13, v0, :cond_e1
    const/4 v1, 0x0
    .line 52
    aput-object v1, v2, v13
    add-int/lit8 v13, v13, 0x1
    goto :goto_d9
    :cond_e1
    return-object v2
.end method
.method private static findVertices(Lcom/dcloud/zxing2/common/BitMatrix;II)[Lcom/dcloud/zxing2/ResultPoint;
    .registers 12
    .line 1
    invoke-virtual {p0}, Lcom/dcloud/zxing2/common/BitMatrix;->getHeight()I
    move-result v6
    .line 2
    invoke-virtual {p0}, Lcom/dcloud/zxing2/common/BitMatrix;->getWidth()I
    move-result v7
    const/16 v0, 0x8
    new-array v8, v0, [Lcom/dcloud/zxing2/ResultPoint;
    .line 5
    sget-object v5, Lcom/dcloud/zxing2/pdf417/detector/Detector;->START_PATTERN:[I
    move-object v0, p0
    move v1, v6
    move v2, v7
    move v3, p1
    move v4, p2
    invoke-static/range {v0 .. v5}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->findRowsWithPattern(Lcom/dcloud/zxing2/common/BitMatrix;IIII[I)[Lcom/dcloud/zxing2/ResultPoint;
    move-result-object v0
    sget-object v1, Lcom/dcloud/zxing2/pdf417/detector/Detector;->INDEXES_START_PATTERN:[I
    invoke-static {v8, v0, v1}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->copyToResult([Lcom/dcloud/zxing2/ResultPoint;[Lcom/dcloud/zxing2/ResultPoint;[I)V
    const/4 v0, 0x4
    .line 8
    aget-object v1, v8, v0
    if-eqz v1, :cond_2f
    .line 9
    aget-object p1, v8, v0
    invoke-virtual {p1}, Lcom/dcloud/zxing2/ResultPoint;->getX()F
    move-result p1
    float-to-int p2, p1
    .line 10
    aget-object p1, v8, v0
    invoke-virtual {p1}, Lcom/dcloud/zxing2/ResultPoint;->getY()F
    move-result p1
    float-to-int p1, p1
    :cond_2f
    move v3, p1
    move v4, p2
    .line 12
    sget-object v5, Lcom/dcloud/zxing2/pdf417/detector/Detector;->STOP_PATTERN:[I
    move-object v0, p0
    move v1, v6
    move v2, v7
    invoke-static/range {v0 .. v5}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->findRowsWithPattern(Lcom/dcloud/zxing2/common/BitMatrix;IIII[I)[Lcom/dcloud/zxing2/ResultPoint;
    move-result-object p0
    sget-object p1, Lcom/dcloud/zxing2/pdf417/detector/Detector;->INDEXES_STOP_PATTERN:[I
    invoke-static {v8, p0, p1}, Lcom/dcloud/zxing2/pdf417/detector/Detector;->copyToResult([Lcom/dcloud/zxing2/ResultPoint;[Lcom/dcloud/zxing2/ResultPoint;[I)V
    return-object v8
.end method
.method private static patternMatchVariance([I[IF)F
    .registers 12
    .line 1
    array-length v0, p0
    const/4 v1, 0x0
    move v2, v1
    move v3, v2
    move v4, v3
    :goto_5
    if-ge v2, v0, :cond_10
    .line 5
    aget v5, p0, v2
    add-int/2addr v3, v5
    .line 6
    aget v5, p1, v2
    add-int/2addr v4, v5
    add-int/lit8 v2, v2, 0x1
    goto :goto_5
    :cond_10
    const/high16 v2, 0x7f800000    # Float.POSITIVE_INFINITY
    if-ge v3, v4, :cond_15
    return v2
    :cond_15
    int-to-float v3, v3
    int-to-float v4, v4
    div-float v4, v3, v4
    mul-float/2addr p2, v4
    const/4 v5, 0x0
    :goto_1b
    if-ge v1, v0, :cond_35
    .line 21
    aget v6, p0, v1
    .line 22
    aget v7, p1, v1
    int-to-float v7, v7
    mul-float/2addr v7, v4
    int-to-float v6, v6
    cmpl-float v8, v6, v7
    if-lez v8, :cond_2a
    sub-float/2addr v6, v7
    goto :goto_2c
    :cond_2a
    sub-float v6, v7, v6
    :goto_2c
    cmpl-float v7, v6, p2
    if-lez v7, :cond_31
    return v2
    :cond_31
    add-float/2addr v5, v6
    add-int/lit8 v1, v1, 0x1
    goto :goto_1b
    :cond_35
    div-float/2addr v5, v3
    return v5
.end method