.class public Landroidx/constraintlayout/motion/utils/MonotonicCurveFit; .super Landroidx/constraintlayout/motion/utils/CurveFit; .source "MonotonicCurveFit.java" # static fields .field public static final TAG:Ljava/lang/String; = "MonotonicCurveFit" # instance fields .field public mT:[D .field public mTangent:[[D .field public mY:[[D # direct methods .method public constructor ([D[[D)V .locals 22 move-object/from16 v0, p0 move-object/from16 v1, p1 move-object/from16 v2, p2 const-class v3, D invoke-direct/range {p0 .. p0}, Landroidx/constraintlayout/motion/utils/CurveFit;->()V array-length v4, v1 const/4 v5, 0x0 aget-object v6, v2, v5 array-length v6, v6 add-int/lit8 v7, v4, -0x1 const/4 v8, 0x2 new-array v9, v8, [I const/4 v10, 0x1 aput v6, v9, v10 aput v7, v9, v5 invoke-static {v3, v9}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object; move-result-object v9 check-cast v9, [[D new-array v11, v8, [I aput v6, v11, v10 aput v4, v11, v5 invoke-static {v3, v11}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object; move-result-object v3 check-cast v3, [[D const/4 v10, 0x0 :goto_0 if-ge v10, v6, :cond_2 const/4 v11, 0x0 :goto_1 if-ge v11, v7, :cond_1 add-int/lit8 v12, v11, 0x1 aget-wide v13, v1, v12 aget-wide v15, v1, v11 sub-double/2addr v13, v15 aget-object v15, v9, v11 aget-object v16, v2, v12 aget-wide v17, v16, v10 aget-object v16, v2, v11 aget-wide v19, v16, v10 sub-double v17, v17, v19 div-double v17, v17, v13 aput-wide v17, v15, v10 if-nez v11, :cond_0 aget-object v13, v3, v11 aget-object v11, v9, v11 aget-wide v14, v11, v10 aput-wide v14, v13, v10 goto :goto_2 :cond_0 aget-object v13, v3, v11 add-int/lit8 v14, v11, -0x1 aget-object v14, v9, v14 aget-wide v15, v14, v10 aget-object v11, v9, v11 aget-wide v17, v11, v10 add-double v15, v15, v17 const-wide/high16 v17, 0x3fe0000000000000L # 0.5 mul-double v15, v15, v17 aput-wide v15, v13, v10 :goto_2 move v11, v12 goto :goto_1 :cond_1 aget-object v11, v3, v7 add-int/lit8 v12, v4, -0x2 aget-object v12, v9, v12 aget-wide v13, v12, v10 aput-wide v13, v11, v10 add-int/lit8 v10, v10, 0x1 goto :goto_0 :cond_2 const/4 v4, 0x0 :goto_3 if-ge v4, v7, :cond_6 const/4 v8, 0x0 :goto_4 if-ge v8, v6, :cond_5 aget-object v10, v9, v4 aget-wide v11, v10, v8 const-wide/16 v13, 0x0 cmpl-double v10, v11, v13 if-nez v10, :cond_3 aget-object v10, v3, v4 aput-wide v13, v10, v8 add-int/lit8 v10, v4, 0x1 aget-object v10, v3, v10 aput-wide v13, v10, v8 goto :goto_5 :cond_3 aget-object v10, v3, v4 aget-wide v11, v10, v8 aget-object v10, v9, v4 aget-wide v13, v10, v8 div-double/2addr v11, v13 add-int/lit8 v10, v4, 0x1 aget-object v13, v3, v10 aget-wide v14, v13, v8 aget-object v13, v9, v4 aget-wide v16, v13, v8 div-double v14, v14, v16 invoke-static {v11, v12, v14, v15}, Ljava/lang/Math;->hypot(DD)D move-result-wide v16 const-wide/high16 v18, 0x4022000000000000L # 9.0 cmpl-double v13, v16, v18 if-lez v13, :cond_4 const-wide/high16 v18, 0x4008000000000000L # 3.0 div-double v18, v18, v16 aget-object v13, v3, v4 mul-double v11, v11, v18 aget-object v16, v9, v4 aget-wide v20, v16, v8 mul-double v11, v11, v20 aput-wide v11, v13, v8 aget-object v10, v3, v10 mul-double v18, v18, v14 aget-object v11, v9, v4 aget-wide v12, v11, v8 mul-double v18, v18, v12 aput-wide v18, v10, v8 :cond_4 :goto_5 add-int/lit8 v8, v8, 0x1 goto :goto_4 :cond_5 add-int/lit8 v4, v4, 0x1 goto :goto_3 :cond_6 iput-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D iput-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D iput-object v3, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mTangent:[[D return-void .end method .method public static diff(DDDDDD)D .locals 10 mul-double v0, p2, p2 const-wide/high16 v2, -0x3fe8000000000000L # -6.0 mul-double v2, v2, v0 mul-double v2, v2, p6 const-wide/high16 v4, 0x4018000000000000L # 6.0 mul-double v6, p2, v4 mul-double v8, v6, p6 add-double/2addr v8, v2 mul-double v4, v4, v0 mul-double v4, v4, p4 add-double/2addr v4, v8 mul-double v6, v6, p4 sub-double/2addr v4, v6 const-wide/high16 v2, 0x4008000000000000L # 3.0 mul-double v2, v2, p0 mul-double v6, v2, p10 mul-double v6, v6, v0 add-double/2addr v6, v4 mul-double v2, v2, p8 mul-double v2, v2, v0 add-double/2addr v2, v6 const-wide/high16 v0, 0x4000000000000000L # 2.0 mul-double v0, v0, p0 mul-double v0, v0, p10 mul-double v0, v0, p2 sub-double/2addr v2, v0 const-wide/high16 v0, 0x4010000000000000L # 4.0 mul-double v0, v0, p0 mul-double v0, v0, p8 mul-double v0, v0, p2 sub-double/2addr v2, v0 mul-double v0, p0, p8 add-double/2addr v0, v2 return-wide v0 .end method .method public static interpolate(DDDDDD)D .locals 12 mul-double v0, p2, p2 mul-double v2, v0, p2 const-wide/high16 v4, -0x4000000000000000L # -2.0 mul-double v4, v4, v2 mul-double v4, v4, p6 const-wide/high16 v6, 0x4008000000000000L # 3.0 mul-double v6, v6, v0 mul-double v8, v6, p6 add-double/2addr v8, v4 const-wide/high16 v4, 0x4000000000000000L # 2.0 mul-double v10, v2, v4 mul-double v10, v10, p4 add-double/2addr v10, v8 mul-double v6, v6, p4 sub-double/2addr v10, v6 add-double v10, v10, p4 mul-double v6, p0, p10 mul-double v8, v6, v2 add-double/2addr v8, v10 mul-double v10, p0, p8 mul-double v2, v2, v10 add-double/2addr v2, v8 mul-double v6, v6, v0 sub-double/2addr v2, v6 mul-double v4, v4, p0 mul-double v4, v4, p8 mul-double v4, v4, v0 sub-double/2addr v2, v4 mul-double v10, v10, p2 add-double/2addr v10, v2 return-wide v10 .end method # virtual methods .method public getPos(DI)D .locals 21 move-object/from16 v0, p0 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D array-length v2, v1 const/4 v3, 0x0 aget-wide v4, v1, v3 cmpg-double v6, p1, v4 if-gtz v6, :cond_0 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v1, v1, v3 aget-wide v2, v1, p3 return-wide v2 :cond_0 add-int/lit8 v2, v2, -0x1 aget-wide v4, v1, v2 cmpl-double v1, p1, v4 if-ltz v1, :cond_1 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v1, v1, v2 aget-wide v2, v1, p3 return-wide v2 :cond_1 :goto_0 if-ge v3, v2, :cond_4 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D aget-wide v4, v1, v3 cmpl-double v6, p1, v4 if-nez v6, :cond_2 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v1, v1, v3 aget-wide v2, v1, p3 return-wide v2 :cond_2 add-int/lit8 v4, v3, 0x1 aget-wide v5, v1, v4 cmpg-double v7, p1, v5 if-gez v7, :cond_3 aget-wide v5, v1, v4 aget-wide v7, v1, v3 sub-double v9, v5, v7 aget-wide v5, v1, v3 sub-double v1, p1, v5 div-double v11, v1, v9 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v2, v1, v3 aget-wide v13, v2, p3 aget-object v1, v1, v4 aget-wide v15, v1, p3 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mTangent:[[D aget-object v2, v1, v3 aget-wide v17, v2, p3 aget-object v1, v1, v4 aget-wide v19, v1, p3 invoke-static/range {v9 .. v20}, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->interpolate(DDDDDD)D move-result-wide v1 return-wide v1 :cond_3 move v3, v4 goto :goto_0 :cond_4 const-wide/16 v1, 0x0 return-wide v1 .end method .method public getPos(D[D)V .locals 23 move-object/from16 v0, p0 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D array-length v2, v1 iget-object v3, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D const/4 v4, 0x0 aget-object v3, v3, v4 array-length v3, v3 aget-wide v5, v1, v4 cmpg-double v7, p1, v5 if-gtz v7, :cond_1 const/4 v1, 0x0 :goto_0 if-ge v1, v3, :cond_0 iget-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v2, v2, v4 aget-wide v5, v2, v1 aput-wide v5, p3, v1 add-int/lit8 v1, v1, 0x1 goto :goto_0 :cond_0 return-void :cond_1 add-int/lit8 v2, v2, -0x1 aget-wide v5, v1, v2 cmpl-double v1, p1, v5 if-ltz v1, :cond_3 :goto_1 if-ge v4, v3, :cond_2 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v1, v1, v2 aget-wide v5, v1, v4 aput-wide v5, p3, v4 add-int/lit8 v4, v4, 0x1 goto :goto_1 :cond_2 return-void :cond_3 const/4 v1, 0x0 :goto_2 if-ge v1, v2, :cond_7 iget-object v5, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D aget-wide v6, v5, v1 cmpl-double v5, p1, v6 if-nez v5, :cond_4 const/4 v5, 0x0 :goto_3 if-ge v5, v3, :cond_4 iget-object v6, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v6, v6, v1 aget-wide v7, v6, v5 aput-wide v7, p3, v5 add-int/lit8 v5, v5, 0x1 goto :goto_3 :cond_4 iget-object v5, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D add-int/lit8 v6, v1, 0x1 aget-wide v7, v5, v6 cmpg-double v9, p1, v7 if-gez v9, :cond_6 aget-wide v7, v5, v6 aget-wide v9, v5, v1 sub-double/2addr v7, v9 aget-wide v9, v5, v1 sub-double v9, p1, v9 div-double/2addr v9, v7 :goto_4 if-ge v4, v3, :cond_5 iget-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v5, v2, v1 aget-wide v15, v5, v4 aget-object v2, v2, v6 aget-wide v17, v2, v4 iget-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mTangent:[[D aget-object v5, v2, v1 aget-wide v19, v5, v4 aget-object v2, v2, v6 aget-wide v21, v2, v4 move-wide v11, v7 move-wide v13, v9 invoke-static/range {v11 .. v22}, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->interpolate(DDDDDD)D move-result-wide v11 aput-wide v11, p3, v4 add-int/lit8 v4, v4, 0x1 goto :goto_4 :cond_5 return-void :cond_6 move v1, v6 goto :goto_2 :cond_7 return-void .end method .method public getPos(D[F)V .locals 23 move-object/from16 v0, p0 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D array-length v2, v1 iget-object v3, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D const/4 v4, 0x0 aget-object v3, v3, v4 array-length v3, v3 aget-wide v5, v1, v4 cmpg-double v7, p1, v5 if-gtz v7, :cond_1 const/4 v1, 0x0 :goto_0 if-ge v1, v3, :cond_0 iget-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v2, v2, v4 aget-wide v5, v2, v1 double-to-float v2, v5 aput v2, p3, v1 add-int/lit8 v1, v1, 0x1 goto :goto_0 :cond_0 return-void :cond_1 add-int/lit8 v2, v2, -0x1 aget-wide v5, v1, v2 cmpl-double v1, p1, v5 if-ltz v1, :cond_3 :goto_1 if-ge v4, v3, :cond_2 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v1, v1, v2 aget-wide v5, v1, v4 double-to-float v1, v5 aput v1, p3, v4 add-int/lit8 v4, v4, 0x1 goto :goto_1 :cond_2 return-void :cond_3 const/4 v1, 0x0 :goto_2 if-ge v1, v2, :cond_7 iget-object v5, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D aget-wide v6, v5, v1 cmpl-double v5, p1, v6 if-nez v5, :cond_4 const/4 v5, 0x0 :goto_3 if-ge v5, v3, :cond_4 iget-object v6, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v6, v6, v1 aget-wide v7, v6, v5 double-to-float v6, v7 aput v6, p3, v5 add-int/lit8 v5, v5, 0x1 goto :goto_3 :cond_4 iget-object v5, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D add-int/lit8 v6, v1, 0x1 aget-wide v7, v5, v6 cmpg-double v9, p1, v7 if-gez v9, :cond_6 aget-wide v7, v5, v6 aget-wide v9, v5, v1 sub-double/2addr v7, v9 aget-wide v9, v5, v1 sub-double v9, p1, v9 div-double/2addr v9, v7 :goto_4 if-ge v4, v3, :cond_5 iget-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v5, v2, v1 aget-wide v15, v5, v4 aget-object v2, v2, v6 aget-wide v17, v2, v4 iget-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mTangent:[[D aget-object v5, v2, v1 aget-wide v19, v5, v4 aget-object v2, v2, v6 aget-wide v21, v2, v4 move-wide v11, v7 move-wide v13, v9 invoke-static/range {v11 .. v22}, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->interpolate(DDDDDD)D move-result-wide v11 double-to-float v2, v11 aput v2, p3, v4 add-int/lit8 v4, v4, 0x1 goto :goto_4 :cond_5 return-void :cond_6 move v1, v6 goto :goto_2 :cond_7 return-void .end method .method public getSlope(DI)D .locals 23 move-object/from16 v0, p0 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D array-length v2, v1 const/4 v3, 0x0 aget-wide v4, v1, v3 cmpg-double v6, p1, v4 if-gez v6, :cond_0 aget-wide v4, v1, v3 goto :goto_0 :cond_0 add-int/lit8 v4, v2, -0x1 aget-wide v5, v1, v4 cmpl-double v7, p1, v5 if-ltz v7, :cond_1 aget-wide v4, v1, v4 goto :goto_0 :cond_1 move-wide/from16 v4, p1 :goto_0 add-int/lit8 v1, v2, -0x1 if-ge v3, v1, :cond_3 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D add-int/lit8 v6, v3, 0x1 aget-wide v7, v1, v6 cmpg-double v9, v4, v7 if-gtz v9, :cond_2 aget-wide v7, v1, v6 aget-wide v9, v1, v3 sub-double/2addr v7, v9 aget-wide v9, v1, v3 sub-double/2addr v4, v9 div-double v13, v4, v7 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v2, v1, v3 aget-wide v15, v2, p3 aget-object v1, v1, v6 aget-wide v17, v1, p3 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mTangent:[[D aget-object v2, v1, v3 aget-wide v19, v2, p3 aget-object v1, v1, v6 aget-wide v21, v1, p3 move-wide v11, v7 invoke-static/range {v11 .. v22}, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->diff(DDDDDD)D move-result-wide v1 div-double/2addr v1, v7 return-wide v1 :cond_2 move v3, v6 goto :goto_0 :cond_3 const-wide/16 v1, 0x0 return-wide v1 .end method .method public getSlope(D[D)V .locals 25 move-object/from16 v0, p0 iget-object v1, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D array-length v2, v1 iget-object v3, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D const/4 v4, 0x0 aget-object v3, v3, v4 array-length v3, v3 aget-wide v5, v1, v4 cmpg-double v7, p1, v5 if-gtz v7, :cond_0 aget-wide v5, v1, v4 goto :goto_0 :cond_0 add-int/lit8 v5, v2, -0x1 aget-wide v6, v1, v5 cmpl-double v8, p1, v6 if-ltz v8, :cond_1 aget-wide v5, v1, v5 goto :goto_0 :cond_1 move-wide/from16 v5, p1 :goto_0 const/4 v1, 0x0 :goto_1 add-int/lit8 v7, v2, -0x1 if-ge v1, v7, :cond_3 iget-object v7, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D add-int/lit8 v8, v1, 0x1 aget-wide v9, v7, v8 cmpg-double v11, v5, v9 if-gtz v11, :cond_2 aget-wide v9, v7, v8 aget-wide v11, v7, v1 sub-double/2addr v9, v11 aget-wide v11, v7, v1 sub-double/2addr v5, v11 div-double/2addr v5, v9 :goto_2 if-ge v4, v3, :cond_3 iget-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mY:[[D aget-object v7, v2, v1 aget-wide v17, v7, v4 aget-object v2, v2, v8 aget-wide v19, v2, v4 iget-object v2, v0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mTangent:[[D aget-object v7, v2, v1 aget-wide v21, v7, v4 aget-object v2, v2, v8 aget-wide v23, v2, v4 move-wide v13, v9 move-wide v15, v5 invoke-static/range {v13 .. v24}, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->diff(DDDDDD)D move-result-wide v11 div-double/2addr v11, v9 aput-wide v11, p3, v4 add-int/lit8 v4, v4, 0x1 goto :goto_2 :cond_2 move v1, v8 goto :goto_1 :cond_3 return-void .end method .method public getTimePoints()[D .locals 1 iget-object v0, p0, Landroidx/constraintlayout/motion/utils/MonotonicCurveFit;->mT:[D return-object v0 .end method