[FFmpeg-devel] [PATCH 2/2] eval: Allow specifying the variable id.

Nicolas George nicolas.george at normalesup.org
Wed Feb 22 22:27:19 CET 2012


Le quartidi 4 ventôse, an CCXX, Michael Niedermayer a écrit :
> Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> ---
>  doc/eval.texi    |    5 +++--
>  libavutil/eval.c |   12 ++++++++----
>  2 files changed, 11 insertions(+), 6 deletions(-)
> 
> diff --git a/doc/eval.texi b/doc/eval.texi
> index b481bfe..c4a8ac5 100644
> --- a/doc/eval.texi
> +++ b/doc/eval.texi
> @@ -107,9 +107,10 @@ the evaluation of @var{y}, return 0 otherwise.
>  Evaluate @var{x}, and if the result is zero return the result of the
>  evaluation of @var{y}, return 0 otherwise.
>  
> - at item taylor(expr, x)
> + at item taylor(expr, x) taylor(expr, x, id)
>  Evaluate a taylor series at x.
> -expr represents the LD(0)-th derivates of f(x) at 0.
> +expr represents the LD(id)-th derivates of f(x) at 0. If id is not specified
> +then 0 is assumed.
>  note, when you have the derivatives at y instead of 0
>  taylor(expr, x-y) can be used
>  When the series does not converge the results are undefined.
> diff --git a/libavutil/eval.c b/libavutil/eval.c
> index d1d2cec..0061e22 100644
> --- a/libavutil/eval.c
> +++ b/libavutil/eval.c
> @@ -184,18 +184,19 @@ static double eval_expr(Parser *p, AVExpr *e)
>          case e_taylor: {
>              double t = 1, d = 0, v;
>              double x = eval_expr(p, e->param[1]);
> +            int id = e->param[2] ? eval_expr(p, e->param[2]) : 0;

av_clip(eval..., 0, VARS - 1)?

>              int i;
> -            double var0 = p->var[0];
> +            double var0 = p->var[id];
>              for(i=0; i<1000; i++) {
>                  double ld = d;
> -                p->var[0] = i;
> +                p->var[id] = i;
>                  v = eval_expr(p, e->param[0]);
>                  d += t*v;
>                  if(ld==d && v)
>                      break;
>                  t *= x / (i+1);
>              }
> -            p->var[0] = var0;
> +            p->var[id] = var0;
>              return d;
>          }
>          default: {
> @@ -523,6 +524,9 @@ static int verify_expr(AVExpr *e)
>          case e_not:
>          case e_random:
>              return verify_expr(e->param[0]);
> +        case e_taylor:
> +            if (e->param[2] && !verify_expr(e->param[2]))
> +                return 0;
>          default: return verify_expr(e->param[0]) && verify_expr(e->param[1]);
>      }
>  }
> @@ -722,7 +726,7 @@ int main(int argc, char **argv)
>          "ifnot(0, 23)",
>          "ifnot(1, NaN) + if(0, 1)",
>          "taylor(1, 1)",
> -        "taylor(eq(mod(ld(0),4),1)-eq(mod(ld(0),4),3), PI/2)",
> +        "taylor(eq(mod(ld(1),4),1)-eq(mod(ld(1),4),3), PI/2, 1)",
>          NULL
>      };

Apart from that, looks right. If you did not apply the original patch yet,
it could be reordered and squashed with it.

Thanks.

Regards,

-- 
  Nicolas George
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 198 bytes
Desc: Digital signature
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20120222/cea83103/attachment.asc>


More information about the ffmpeg-devel mailing list