Can't you just do this with apply? Something like this:
f = (x, y, z) -> x + y + z^2
let x=3, y=4, z=5
apply(f, x, y, z)
end
On Sunday, February 2, 2014 5:47:36 PM UTC+2, Walking Sparrow wrote:
>
> Let me clarify a little bit. My question is actually the following:
>
> In R, one can do something like
>
> > f <- function(x1, x2, x3, x4, x5, x6) { some expressions that you like
> to use }
> > evaluate.at <- list(x1 = 2, x2 = 2.3, x3 = 2, x4 = 1.2, x5 = 3.4, x6 =
> 5.6)
> > do.call(f, evaluate.at) # get the value
>
> "do.call" can accept any valid function, and a list of variable values.
> There is no restriction to the function or the number of variables.
> Sometimes this is very useful.
>
> How do we do similar things in Julia? Does Julia have a function or macro
> similar to "do.call"?
>
> On Sunday, February 2, 2014 4:09:05 AM UTC-8, Mauro wrote:
>>
>> I don't quite comprehend your problem, so maybe this doesn't help. But
>> as far as I can tell, there is no need for macros:
>>
>> Just define your function as a normal function, which can be evaluated
>> for any (x,z):
>>
>> julia> f(x,z) = x + x*z + log(sin(x) + 2) * log(cos(z) + 2)
>> f (generic function with 1 method)
>> julia> x0 = 2.3; z0 = 1.4;
>> julia> f(x0,z0)
>> 6.302488546391614
>>
>> For the first step: use automatic differentiation on the function in
>> question. The package https://github.com/scidom/DualNumbers.jl can do
>> this:
>>
>> julia> using DualNumbers
>> julia> xdu = dual(x0,1)
>> 2.3 + 1.0du
>>
>> # this gives (f(x0,z0), \partial f / \partial x at (x0,z0)) :
>> julia> f(xdu,z)
>> 6.302488546391614 + 2.2120074784516013du
>>
>> julia> zdu = dual(z,1)
>> 1.4 + 1.0du
>> # this gives (f(x0,z0), \partial f / \partial z at (x0,z0)) :
>> julia> f(x,zdu)
>> 6.302488546391614 + 1.8413102782559223du
>>
>> (double check that the derivatives are right but I think that is how it
>> should work)
>>
>> On Sat, 2014-02-01 at 23:42, [email protected] wrote:
>> > You are right about that I have an R background. What I am trying to do
>> is
>> > to evaluate a function given by the user. For example,
>> >
>> > I want to write a function that can compute the marginal effects of a
>> > linear or logistic model. For simplicity, let's just use linear
>> regression.
>> > If the user did a linear regression using the following model (I am
>> using
>> > the formula syntax from R)
>> >
>> > y ~ x + z + sin(x) * sin(z) for the data set my_data, which has three
>> > columns x, y, and z
>> >
>> > Then the marginal effects at the mean are computed like this: First,
>> > compute the first derivative of 1+ x + z + sin(x) * sin(z). This can be
>> > done in R using the function "deriv" to get the expression of the first
>> > derivative. In the second step, I need to substitute the mean values of
>> x
>> > and z into the result of the first step. An example of this would be
>> the
>> > "margins" function in the R package "PivotalR"
>> > (http://cran.r-project.org/web/packages/PivotalR/ and
>> > https://github.com/gopivotal/PivotalR)
>> >
>> > Right now, I have no idea how to do the first step in Julia. But that
>> is
>> > OK, because I just started learning Julia.
>> >
>> > Now my question is in the second step. The user can use any complex
>> > expressions in the linear regression like y ~ x + x*z + log(sin(x) + 2)
>> *
>> > log(cos(z) + 2), and the data set my_data and formula can have any
>> number
>> > of variables like x1, x2, ...., x1000. So when you write the code for
>> the
>> > value substitution in the second step, you cannot know which function
>> and
>> > what variables you will have.
>> >
>> > So in Julia or R, I need a function or macro F(f, [....]) that does
>> this:
>> > given a function f, whose format is the input from the user, and a set
>> of
>> > variable values [...], whose number and names are also the input from
>> the
>> > user, F(f, [...]) returns the value of f evaluated at the values [...].
>> For
>> > example, the user inputs
>> >
>> > f = 1 + z + cos(x)*log(2+cos(z))/(2+sin(x))
>> >
>> > and [x = 2.3, z = 1.4],
>> >
>> > F should return the value of f evaluated at x = 2.3 and z = 1.4.
>> >
>> > This can be done in R, see "margins" function in PivotalR, which
>> actually
>> > does big data computation in-database. The problem is how to do the
>> same
>> > thing in Julia?
>> >
>> > Hope my explanation makes my question clearer.
>> >
>> > On Saturday, February 1, 2014 2:35:38 PM UTC-8, Jameson wrote:
>> >>
>> >> You need to provide more detail on what you are trying to do with
>> this.
>> >> You seem
>> >> to be confusing several concepts involving the usage of expressions,
>> >> macros, and functions. I can't tell if you are trying to write special
>> >> syntax, or are just unaware of anonymous functions:
>> >>
>> >> Mostly, why is :(sin(x) + cos(y) * sin(z)) an expression, and not a
>> >> function? It seems like you perhaps have an R background?
>> >>
>> >> f(x,y,z) = (sin(x) + cos(y) * sin(z))
>> >> f(1,2,3)
>> >>
>> >> On Sat, Feb 1, 2014 at 12:04 PM, Walking Sparrow
>> >> <[email protected]<javascript:>>
>>
>> >> wrote:
>> >> > So the real question is how to generate a code block like this
>> >> >
>> >> > quote
>> >> > x = 2
>> >> > y = 3
>> >> > .....
>> >> > x + y + ....
>> >> > end
>> >> >
>> >> > Need to embed a for loop inside the macro definition?
>> >> >
>> >> >
>> >> >
>> >> > On Saturday, February 1, 2014 8:52:30 AM UTC-8, Walking Sparrow
>> wrote:
>> >> >>
>> >> >> Please forgive me if this is a stupid question. Suppose I have an
>> >> >> expression
>> >> >>
>> >> >> :(sin(x) + cos(y) * sin(z))
>> >> >>
>> >> >> and the values of x, y, z.
>> >> >>
>> >> >> How can I write a macro that can substitute the values of x, y, z
>> into
>> >> the
>> >> >> above expression? The number of values that I want to substitute
>> >> depends on
>> >> >> the actual use cases and thus is unknown.
>> >> >>
>> >> >> I wrote a function that can do this
>> >> >>
>> >> >> function substitute(expr::Expr, vals::Array{Expr,1})
>> >> >> for i = 1:length(vals)
>> >> >> @eval $(vals[i])
>> >> >> end
>> >> >> @eval $expr
>> >> >> end
>> >> >>
>> >> >> x = 10
>> >> >> y = 23
>> >> >>
>> >> >> substitute(:(x+y), [:(x = 2), :(y = 3)])
>> >> >>
>> >> >> x
>> >> >> y
>> >> >>
>> >> >> But if you run the above code, you will see that the values of
>> global x
>> >> >> and y are changed, which is not what I intend to do. This is
>> because
>> >> "eval"
>> >> >> does the evaluation in the global scope. Besides, I think it is a
>> bad
>> >> coding
>> >> >> pattern to use eval and it is slow.
>> >> >>
>> >> >> It would be better if this can be done using macro. But I have no
>> idea
>> >> >> about how to do this.
>> >>
>>
>> --
>> Sent with my mu4e
>>
>>