Below is my full implementation (tried to make it simple as for demonstration)
Lapply_me = function(X = X, FUN = FUN, Apply_MC = FALSE, ...) {
if (Apply_MC) {
return(mclapply(X, FUN, ...))
} else {
if (any(names(list(...)) == 'mc.cores')) {
myList = list(...)[!names(list(...)) %in% 'mc.cores']
}
return(lapply(X, FUN, myList))
}
}
Lapply_me(as.list(1:4), function(xx) {
if (xx == 1) return('a')
if (xx == 2) return('b')
if (xx == 3) return('c')
if (xx == 4) return('d')
}, Apply_MC = FALSE, mc.cores = 2)
Error message :
Error in FUN(X[[i]], ...) : unused argument (list())
Kindly note that, with Apply_MC = TRUE, it is working perfectly.
On Sun, Mar 4, 2018 at 10:45 PM, Eric Berger <ericjberger at gmail.com>
wrote:> That's fine. The issue is how you called Lapply_me(). What did you pass
as
> the argument to FUN?
> And if you did not pass anything that how is FUN declared?
> You have not shown that in your email.
>
>
>
>
> On Sun, Mar 4, 2018 at 7:11 PM, Christofer Bogaso
> <bogaso.christofer at gmail.com> wrote:
>>
>> My modified function looks below :
>>
>> Lapply_me = function(X = X, FUN = FUN, Apply_MC = FALSE, ...) {
>> if (Apply_MC) {
>> return(mclapply(X, FUN, ...))
>> } else {
>> if (any(names(list(...)) == 'mc.cores')) {
>> myList = list(...)[!names(list(...)) %in% 'mc.cores']
>> }
>> return(lapply(X, FUN, myList))
>> }
>> }
>>
>> Here, I am not passing ... anymore rather passing myList
>>
>> On Sun, Mar 4, 2018 at 10:37 PM, Eric Berger <ericjberger at
gmail.com>
>> wrote:
>> > Hi Christofer,
>> > Before you made the change that I suggested, your program was
stopping
>> > at
>> > the statement: list(...) = list(..) .etc
>> > This means that it never tried to execute the statement:
>> > return(lapply(X,FUN,...))
>> > Now that you have made the change, it gets past the first
statement and
>> > tries to execute the statement: return(lapply(X,FUN,...)).
>> > That attempt is generating the error message because whatever you
are
>> > passing in as the FUN argument is not expecting extra arguments.
>> >
>> > HTH,
>> > Eric
>> >
>> >
>> > On Sun, Mar 4, 2018 at 6:52 PM, Christofer Bogaso
>> > <bogaso.christofer at gmail.com> wrote:
>> >>
>> >> @Eric - with this approach I am getting below error :
>> >>
>> >> Error in FUN(X[[i]], ...) : unused argument (list())
>> >>
>> >> On Sun, Mar 4, 2018 at 10:18 PM, Eric Berger <ericjberger
at gmail.com>
>> >> wrote:
>> >> > Hi Christofer,
>> >> > You cannot assign to list(...). You can do the following
>> >> >
>> >> > myList <- list(...)[!names(list(...)) %in%
'mc.cores']
>> >> >
>> >> > HTH,
>> >> > Eric
>> >> >
>> >> > On Sun, Mar 4, 2018 at 6:38 PM, Christofer Bogaso
>> >> > <bogaso.christofer at gmail.com> wrote:
>> >> >>
>> >> >> Hi,
>> >> >>
>> >> >> As an example, I want to create below kind of custom
Function which
>> >> >> either be mclapply pr lapply
>> >> >>
>> >> >> Lapply_me = function(X = X, FUN = FUN, ..., Apply_MC
= FALSE) {
>> >> >> if (Apply_MC) {
>> >> >> return(mclapply(X, FUN, ...))
>> >> >> } else {
>> >> >> if (any(names(list(...)) == 'mc.cores')) {
>> >> >> list(...) = list(...)[!names(list(...)) %in%
'mc.cores']
>> >> >> }
>> >> >> return(lapply(X, FUN, ...))
>> >> >> }
>> >> >> }
>> >> >>
>> >> >> However when Apply_MC = FALSE it generates below
error saying :
>> >> >>
>> >> >> '...' used in an incorrect context
>> >> >>
>> >> >>
>> >> >> Appreciate if you can help me with the correct
approach. Thanks,
>> >> >>
>> >> >>
>> >> >> On Sun, Mar 4, 2018 at 9:34 PM, Duncan Murdoch
>> >> >> <murdoch.duncan at gmail.com>
>> >> >> wrote:
>> >> >> > On 04/03/2018 10:39 AM, Christofer Bogaso wrote:
>> >> >> >>
>> >> >> >> Hi again,
>> >> >> >>
>> >> >> >> I am looking for some way to alternately use
2 related functions,
>> >> >> >> based on some ifelse() condition.
>> >> >> >>
>> >> >> >> For example, I have 2 functions mclapply()
and lapply()
>> >> >> >>
>> >> >> >> However, mclapply() function has one extra
parameter 'mc.cores'
>> >> >> >> which
>> >> >> >> lapply doesnt not have.
>> >> >> >>
>> >> >> >> I know when mc.cores = 1, these 2 functions
are essentially same,
>> >> >> >> however I am looking for more general way to
control them within
>> >> >> >> ifelse() constion
>> >> >> >>
>> >> >> >> Can someone please help me how can I use
them within ifelse()
>> >> >> >> condition.
>> >> >> >
>> >> >> >
>> >> >> > Don't. ifelse() usually evaluates *both*
the true and false
>> >> >> > values,
>> >> >> > and
>> >> >> > then selects entries from each. Just use an if
statement.
>> >> >> >
>> >> >> > Duncan Murdoch
>> >> >>
>> >> >> ______________________________________________
>> >> >> R-help at r-project.org mailing list -- To
UNSUBSCRIBE and more, see
>> >> >> https://stat.ethz.ch/mailman/listinfo/r-help
>> >> >> PLEASE do read the posting guide
>> >> >> http://www.R-project.org/posting-guide.html
>> >> >> and provide commented, minimal, self-contained,
reproducible code.
>> >> >
>> >> >
>> >
>> >
>
>
The reason that it works for Apply_MC=TRUE is that in that case you call
mclapply(X,FUN,...) and
the mclapply() function strips off the mc.cores argument from the
"..."
list before calling FUN, so FUN is being called with zero arguments,
exactly as it is declared.
A quick workaround is to change the line
Lapply_me(as.list(1:4), function(xx) {
to
Lapply_me(as.list(1:4), function(xx,dummyList) {
HTH,
Eric
On Sun, Mar 4, 2018 at 7:21 PM, Christofer Bogaso <
bogaso.christofer at gmail.com> wrote:
> Below is my full implementation (tried to make it simple as for
> demonstration)
>
> Lapply_me = function(X = X, FUN = FUN, Apply_MC = FALSE, ...) {
> if (Apply_MC) {
> return(mclapply(X, FUN, ...))
> } else {
> if (any(names(list(...)) == 'mc.cores')) {
> myList = list(...)[!names(list(...)) %in% 'mc.cores']
> }
> return(lapply(X, FUN, myList))
> }
> }
>
>
> Lapply_me(as.list(1:4), function(xx) {
> if (xx == 1) return('a')
> if (xx == 2) return('b')
> if (xx == 3) return('c')
> if (xx == 4) return('d')
> }, Apply_MC = FALSE, mc.cores = 2)
>
> Error message :
>
> Error in FUN(X[[i]], ...) : unused argument (list())
>
> Kindly note that, with Apply_MC = TRUE, it is working perfectly.
>
> On Sun, Mar 4, 2018 at 10:45 PM, Eric Berger <ericjberger at
gmail.com>
> wrote:
> > That's fine. The issue is how you called Lapply_me(). What did you
pass
> as
> > the argument to FUN?
> > And if you did not pass anything that how is FUN declared?
> > You have not shown that in your email.
> >
> >
> >
> >
> > On Sun, Mar 4, 2018 at 7:11 PM, Christofer Bogaso
> > <bogaso.christofer at gmail.com> wrote:
> >>
> >> My modified function looks below :
> >>
> >> Lapply_me = function(X = X, FUN = FUN, Apply_MC = FALSE, ...) {
> >> if (Apply_MC) {
> >> return(mclapply(X, FUN, ...))
> >> } else {
> >> if (any(names(list(...)) == 'mc.cores')) {
> >> myList = list(...)[!names(list(...)) %in% 'mc.cores']
> >> }
> >> return(lapply(X, FUN, myList))
> >> }
> >> }
> >>
> >> Here, I am not passing ... anymore rather passing myList
> >>
> >> On Sun, Mar 4, 2018 at 10:37 PM, Eric Berger <ericjberger at
gmail.com>
> >> wrote:
> >> > Hi Christofer,
> >> > Before you made the change that I suggested, your program was
stopping
> >> > at
> >> > the statement: list(...) = list(..) .etc
> >> > This means that it never tried to execute the statement:
> >> > return(lapply(X,FUN,...))
> >> > Now that you have made the change, it gets past the first
statement
> and
> >> > tries to execute the statement: return(lapply(X,FUN,...)).
> >> > That attempt is generating the error message because whatever
you are
> >> > passing in as the FUN argument is not expecting extra
arguments.
> >> >
> >> > HTH,
> >> > Eric
> >> >
> >> >
> >> > On Sun, Mar 4, 2018 at 6:52 PM, Christofer Bogaso
> >> > <bogaso.christofer at gmail.com> wrote:
> >> >>
> >> >> @Eric - with this approach I am getting below error :
> >> >>
> >> >> Error in FUN(X[[i]], ...) : unused argument (list())
> >> >>
> >> >> On Sun, Mar 4, 2018 at 10:18 PM, Eric Berger
<ericjberger at gmail.com>
> >> >> wrote:
> >> >> > Hi Christofer,
> >> >> > You cannot assign to list(...). You can do the
following
> >> >> >
> >> >> > myList <- list(...)[!names(list(...)) %in%
'mc.cores']
> >> >> >
> >> >> > HTH,
> >> >> > Eric
> >> >> >
> >> >> > On Sun, Mar 4, 2018 at 6:38 PM, Christofer Bogaso
> >> >> > <bogaso.christofer at gmail.com> wrote:
> >> >> >>
> >> >> >> Hi,
> >> >> >>
> >> >> >> As an example, I want to create below kind of
custom Function
> which
> >> >> >> either be mclapply pr lapply
> >> >> >>
> >> >> >> Lapply_me = function(X = X, FUN = FUN, ...,
Apply_MC = FALSE) {
> >> >> >> if (Apply_MC) {
> >> >> >> return(mclapply(X, FUN, ...))
> >> >> >> } else {
> >> >> >> if (any(names(list(...)) == 'mc.cores'))
{
> >> >> >> list(...) = list(...)[!names(list(...)) %in%
'mc.cores']
> >> >> >> }
> >> >> >> return(lapply(X, FUN, ...))
> >> >> >> }
> >> >> >> }
> >> >> >>
> >> >> >> However when Apply_MC = FALSE it generates below
error saying :
> >> >> >>
> >> >> >> '...' used in an incorrect context
> >> >> >>
> >> >> >>
> >> >> >> Appreciate if you can help me with the correct
approach. Thanks,
> >> >> >>
> >> >> >>
> >> >> >> On Sun, Mar 4, 2018 at 9:34 PM, Duncan Murdoch
> >> >> >> <murdoch.duncan at gmail.com>
> >> >> >> wrote:
> >> >> >> > On 04/03/2018 10:39 AM, Christofer Bogaso
wrote:
> >> >> >> >>
> >> >> >> >> Hi again,
> >> >> >> >>
> >> >> >> >> I am looking for some way to
alternately use 2 related
> functions,
> >> >> >> >> based on some ifelse() condition.
> >> >> >> >>
> >> >> >> >> For example, I have 2 functions
mclapply() and lapply()
> >> >> >> >>
> >> >> >> >> However, mclapply() function has one
extra parameter 'mc.cores'
> >> >> >> >> which
> >> >> >> >> lapply doesnt not have.
> >> >> >> >>
> >> >> >> >> I know when mc.cores = 1, these 2
functions are essentially
> same,
> >> >> >> >> however I am looking for more general
way to control them
> within
> >> >> >> >> ifelse() constion
> >> >> >> >>
> >> >> >> >> Can someone please help me how can I
use them within ifelse()
> >> >> >> >> condition.
> >> >> >> >
> >> >> >> >
> >> >> >> > Don't. ifelse() usually evaluates
*both* the true and false
> >> >> >> > values,
> >> >> >> > and
> >> >> >> > then selects entries from each. Just use
an if statement.
> >> >> >> >
> >> >> >> > Duncan Murdoch
> >> >> >>
> >> >> >> ______________________________________________
> >> >> >> R-help at r-project.org mailing list -- To
UNSUBSCRIBE and more, see
> >> >> >> https://stat.ethz.ch/mailman/listinfo/r-help
> >> >> >> PLEASE do read the posting guide
> >> >> >> http://www.R-project.org/posting-guide.html
> >> >> >> and provide commented, minimal, self-contained,
reproducible code.
> >> >> >
> >> >> >
> >> >
> >> >
> >
> >
>
[[alternative HTML version deleted]]
Thanks Eric, this is working. On Sun, Mar 4, 2018 at 11:28 PM, Eric Berger <ericjberger at gmail.com> wrote:> The reason that it works for Apply_MC=TRUE is that in that case you call > mclapply(X,FUN,...) and > the mclapply() function strips off the mc.cores argument from the "..." list > before calling FUN, so FUN is being called with zero arguments, exactly as > it is declared. > > A quick workaround is to change the line > > Lapply_me(as.list(1:4), function(xx) { > > to > > Lapply_me(as.list(1:4), function(xx,dummyList) { > > HTH, > Eric > > > On Sun, Mar 4, 2018 at 7:21 PM, Christofer Bogaso > <bogaso.christofer at gmail.com> wrote: >> >> Below is my full implementation (tried to make it simple as for >> demonstration) >> >> Lapply_me = function(X = X, FUN = FUN, Apply_MC = FALSE, ...) { >> if (Apply_MC) { >> return(mclapply(X, FUN, ...)) >> } else { >> if (any(names(list(...)) == 'mc.cores')) { >> myList = list(...)[!names(list(...)) %in% 'mc.cores'] >> } >> return(lapply(X, FUN, myList)) >> } >> } >> >> >> Lapply_me(as.list(1:4), function(xx) { >> if (xx == 1) return('a') >> if (xx == 2) return('b') >> if (xx == 3) return('c') >> if (xx == 4) return('d') >> }, Apply_MC = FALSE, mc.cores = 2) >> >> Error message : >> >> Error in FUN(X[[i]], ...) : unused argument (list()) >> >> Kindly note that, with Apply_MC = TRUE, it is working perfectly. >> >> On Sun, Mar 4, 2018 at 10:45 PM, Eric Berger <ericjberger at gmail.com> >> wrote: >> > That's fine. The issue is how you called Lapply_me(). What did you pass >> > as >> > the argument to FUN? >> > And if you did not pass anything that how is FUN declared? >> > You have not shown that in your email. >> > >> > >> > >> > >> > On Sun, Mar 4, 2018 at 7:11 PM, Christofer Bogaso >> > <bogaso.christofer at gmail.com> wrote: >> >> >> >> My modified function looks below : >> >> >> >> Lapply_me = function(X = X, FUN = FUN, Apply_MC = FALSE, ...) { >> >> if (Apply_MC) { >> >> return(mclapply(X, FUN, ...)) >> >> } else { >> >> if (any(names(list(...)) == 'mc.cores')) { >> >> myList = list(...)[!names(list(...)) %in% 'mc.cores'] >> >> } >> >> return(lapply(X, FUN, myList)) >> >> } >> >> } >> >> >> >> Here, I am not passing ... anymore rather passing myList >> >> >> >> On Sun, Mar 4, 2018 at 10:37 PM, Eric Berger <ericjberger at gmail.com> >> >> wrote: >> >> > Hi Christofer, >> >> > Before you made the change that I suggested, your program was >> >> > stopping >> >> > at >> >> > the statement: list(...) = list(..) .etc >> >> > This means that it never tried to execute the statement: >> >> > return(lapply(X,FUN,...)) >> >> > Now that you have made the change, it gets past the first statement >> >> > and >> >> > tries to execute the statement: return(lapply(X,FUN,...)). >> >> > That attempt is generating the error message because whatever you are >> >> > passing in as the FUN argument is not expecting extra arguments. >> >> > >> >> > HTH, >> >> > Eric >> >> > >> >> > >> >> > On Sun, Mar 4, 2018 at 6:52 PM, Christofer Bogaso >> >> > <bogaso.christofer at gmail.com> wrote: >> >> >> >> >> >> @Eric - with this approach I am getting below error : >> >> >> >> >> >> Error in FUN(X[[i]], ...) : unused argument (list()) >> >> >> >> >> >> On Sun, Mar 4, 2018 at 10:18 PM, Eric Berger <ericjberger at gmail.com> >> >> >> wrote: >> >> >> > Hi Christofer, >> >> >> > You cannot assign to list(...). You can do the following >> >> >> > >> >> >> > myList <- list(...)[!names(list(...)) %in% 'mc.cores'] >> >> >> > >> >> >> > HTH, >> >> >> > Eric >> >> >> > >> >> >> > On Sun, Mar 4, 2018 at 6:38 PM, Christofer Bogaso >> >> >> > <bogaso.christofer at gmail.com> wrote: >> >> >> >> >> >> >> >> Hi, >> >> >> >> >> >> >> >> As an example, I want to create below kind of custom Function >> >> >> >> which >> >> >> >> either be mclapply pr lapply >> >> >> >> >> >> >> >> Lapply_me = function(X = X, FUN = FUN, ..., Apply_MC = FALSE) { >> >> >> >> if (Apply_MC) { >> >> >> >> return(mclapply(X, FUN, ...)) >> >> >> >> } else { >> >> >> >> if (any(names(list(...)) == 'mc.cores')) { >> >> >> >> list(...) = list(...)[!names(list(...)) %in% 'mc.cores'] >> >> >> >> } >> >> >> >> return(lapply(X, FUN, ...)) >> >> >> >> } >> >> >> >> } >> >> >> >> >> >> >> >> However when Apply_MC = FALSE it generates below error saying : >> >> >> >> >> >> >> >> '...' used in an incorrect context >> >> >> >> >> >> >> >> >> >> >> >> Appreciate if you can help me with the correct approach. Thanks, >> >> >> >> >> >> >> >> >> >> >> >> On Sun, Mar 4, 2018 at 9:34 PM, Duncan Murdoch >> >> >> >> <murdoch.duncan at gmail.com> >> >> >> >> wrote: >> >> >> >> > On 04/03/2018 10:39 AM, Christofer Bogaso wrote: >> >> >> >> >> >> >> >> >> >> Hi again, >> >> >> >> >> >> >> >> >> >> I am looking for some way to alternately use 2 related >> >> >> >> >> functions, >> >> >> >> >> based on some ifelse() condition. >> >> >> >> >> >> >> >> >> >> For example, I have 2 functions mclapply() and lapply() >> >> >> >> >> >> >> >> >> >> However, mclapply() function has one extra parameter >> >> >> >> >> 'mc.cores' >> >> >> >> >> which >> >> >> >> >> lapply doesnt not have. >> >> >> >> >> >> >> >> >> >> I know when mc.cores = 1, these 2 functions are essentially >> >> >> >> >> same, >> >> >> >> >> however I am looking for more general way to control them >> >> >> >> >> within >> >> >> >> >> ifelse() constion >> >> >> >> >> >> >> >> >> >> Can someone please help me how can I use them within ifelse() >> >> >> >> >> condition. >> >> >> >> > >> >> >> >> > >> >> >> >> > Don't. ifelse() usually evaluates *both* the true and false >> >> >> >> > values, >> >> >> >> > and >> >> >> >> > then selects entries from each. Just use an if statement. >> >> >> >> > >> >> >> >> > Duncan Murdoch >> >> >> >> >> >> >> >> ______________________________________________ >> >> >> >> R-help at r-project.org mailing list -- To UNSUBSCRIBE and more, see >> >> >> >> https://stat.ethz.ch/mailman/listinfo/r-help >> >> >> >> PLEASE do read the posting guide >> >> >> >> http://www.R-project.org/posting-guide.html >> >> >> >> and provide commented, minimal, self-contained, reproducible >> >> >> >> code. >> >> >> > >> >> >> > >> >> > >> >> > >> > >> > > >
... and note also:> f <- function(...)list(...) <- list(...) ## you cannot have list(...) onLHS> f(x=1,y="a")Error in list(...) <- list(...) : '...' used in an incorrect context In addition to Eric's suggestions, maybe something like this construction is useful: Lapply_me = function(X = X, FUN = FUN, ..., Apply_MC = FALSE) { if (Apply_MC) { return(mclapply(X, FUN, ...)) } else { if (any(names(list(...)) == 'mc.cores')) { l = list(...)[!names(list(...)) %in% 'mc.cores'] } return(do.call(lapply,c(list(X,FUN),l))) } }> Lapply_me (X=1:5,FUN=sum,mc.cores=4)[[1]] [1] 1 [[2]] [1] 2 [[3]] [1] 3 [[4]] [1] 4 [[5]] [1] 5 Though the program logic needs fixing: if none of the names in list(...) are "mc.cores," l is undefined! Cheers, Bert Bert Gunter "The trouble with having an open mind is that people keep coming along and sticking things into it." -- Opus (aka Berkeley Breathed in his "Bloom County" comic strip ) On Sun, Mar 4, 2018 at 9:58 AM, Eric Berger <ericjberger at gmail.com> wrote:> The reason that it works for Apply_MC=TRUE is that in that case you call > mclapply(X,FUN,...) and > the mclapply() function strips off the mc.cores argument from the "..." > list before calling FUN, so FUN is being called with zero arguments, > exactly as it is declared. > > A quick workaround is to change the line > > Lapply_me(as.list(1:4), function(xx) { > > to > > Lapply_me(as.list(1:4), function(xx,dummyList) { > > HTH, > Eric > > > On Sun, Mar 4, 2018 at 7:21 PM, Christofer Bogaso < > bogaso.christofer at gmail.com> wrote: > > > Below is my full implementation (tried to make it simple as for > > demonstration) > > > > Lapply_me = function(X = X, FUN = FUN, Apply_MC = FALSE, ...) { > > if (Apply_MC) { > > return(mclapply(X, FUN, ...)) > > } else { > > if (any(names(list(...)) == 'mc.cores')) { > > myList = list(...)[!names(list(...)) %in% 'mc.cores'] > > } > > return(lapply(X, FUN, myList)) > > } > > } > > > > > > Lapply_me(as.list(1:4), function(xx) { > > if (xx == 1) return('a') > > if (xx == 2) return('b') > > if (xx == 3) return('c') > > if (xx == 4) return('d') > > }, Apply_MC = FALSE, mc.cores = 2) > > > > Error message : > > > > Error in FUN(X[[i]], ...) : unused argument (list()) > > > > Kindly note that, with Apply_MC = TRUE, it is working perfectly. > > > > On Sun, Mar 4, 2018 at 10:45 PM, Eric Berger <ericjberger at gmail.com> > > wrote: > > > That's fine. The issue is how you called Lapply_me(). What did you pass > > as > > > the argument to FUN? > > > And if you did not pass anything that how is FUN declared? > > > You have not shown that in your email. > > > > > > > > > > > > > > > On Sun, Mar 4, 2018 at 7:11 PM, Christofer Bogaso > > > <bogaso.christofer at gmail.com> wrote: > > >> > > >> My modified function looks below : > > >> > > >> Lapply_me = function(X = X, FUN = FUN, Apply_MC = FALSE, ...) { > > >> if (Apply_MC) { > > >> return(mclapply(X, FUN, ...)) > > >> } else { > > >> if (any(names(list(...)) == 'mc.cores')) { > > >> myList = list(...)[!names(list(...)) %in% 'mc.cores'] > > >> } > > >> return(lapply(X, FUN, myList)) > > >> } > > >> } > > >> > > >> Here, I am not passing ... anymore rather passing myList > > >> > > >> On Sun, Mar 4, 2018 at 10:37 PM, Eric Berger <ericjberger at gmail.com> > > >> wrote: > > >> > Hi Christofer, > > >> > Before you made the change that I suggested, your program was > stopping > > >> > at > > >> > the statement: list(...) = list(..) .etc > > >> > This means that it never tried to execute the statement: > > >> > return(lapply(X,FUN,...)) > > >> > Now that you have made the change, it gets past the first statement > > and > > >> > tries to execute the statement: return(lapply(X,FUN,...)). > > >> > That attempt is generating the error message because whatever you > are > > >> > passing in as the FUN argument is not expecting extra arguments. > > >> > > > >> > HTH, > > >> > Eric > > >> > > > >> > > > >> > On Sun, Mar 4, 2018 at 6:52 PM, Christofer Bogaso > > >> > <bogaso.christofer at gmail.com> wrote: > > >> >> > > >> >> @Eric - with this approach I am getting below error : > > >> >> > > >> >> Error in FUN(X[[i]], ...) : unused argument (list()) > > >> >> > > >> >> On Sun, Mar 4, 2018 at 10:18 PM, Eric Berger < > ericjberger at gmail.com> > > >> >> wrote: > > >> >> > Hi Christofer, > > >> >> > You cannot assign to list(...). You can do the following > > >> >> > > > >> >> > myList <- list(...)[!names(list(...)) %in% 'mc.cores'] > > >> >> > > > >> >> > HTH, > > >> >> > Eric > > >> >> > > > >> >> > On Sun, Mar 4, 2018 at 6:38 PM, Christofer Bogaso > > >> >> > <bogaso.christofer at gmail.com> wrote: > > >> >> >> > > >> >> >> Hi, > > >> >> >> > > >> >> >> As an example, I want to create below kind of custom Function > > which > > >> >> >> either be mclapply pr lapply > > >> >> >> > > >> >> >> Lapply_me = function(X = X, FUN = FUN, ..., Apply_MC = FALSE) { > > >> >> >> if (Apply_MC) { > > >> >> >> return(mclapply(X, FUN, ...)) > > >> >> >> } else { > > >> >> >> if (any(names(list(...)) == 'mc.cores')) { > > >> >> >> list(...) = list(...)[!names(list(...)) %in% 'mc.cores'] > > >> >> >> } > > >> >> >> return(lapply(X, FUN, ...)) > > >> >> >> } > > >> >> >> } > > >> >> >> > > >> >> >> However when Apply_MC = FALSE it generates below error saying : > > >> >> >> > > >> >> >> '...' used in an incorrect context > > >> >> >> > > >> >> >> > > >> >> >> Appreciate if you can help me with the correct approach. Thanks, > > >> >> >> > > >> >> >> > > >> >> >> On Sun, Mar 4, 2018 at 9:34 PM, Duncan Murdoch > > >> >> >> <murdoch.duncan at gmail.com> > > >> >> >> wrote: > > >> >> >> > On 04/03/2018 10:39 AM, Christofer Bogaso wrote: > > >> >> >> >> > > >> >> >> >> Hi again, > > >> >> >> >> > > >> >> >> >> I am looking for some way to alternately use 2 related > > functions, > > >> >> >> >> based on some ifelse() condition. > > >> >> >> >> > > >> >> >> >> For example, I have 2 functions mclapply() and lapply() > > >> >> >> >> > > >> >> >> >> However, mclapply() function has one extra parameter > 'mc.cores' > > >> >> >> >> which > > >> >> >> >> lapply doesnt not have. > > >> >> >> >> > > >> >> >> >> I know when mc.cores = 1, these 2 functions are essentially > > same, > > >> >> >> >> however I am looking for more general way to control them > > within > > >> >> >> >> ifelse() constion > > >> >> >> >> > > >> >> >> >> Can someone please help me how can I use them within ifelse() > > >> >> >> >> condition. > > >> >> >> > > > >> >> >> > > > >> >> >> > Don't. ifelse() usually evaluates *both* the true and false > > >> >> >> > values, > > >> >> >> > and > > >> >> >> > then selects entries from each. Just use an if statement. > > >> >> >> > > > >> >> >> > Duncan Murdoch > > >> >> >> > > >> >> >> ______________________________________________ > > >> >> >> R-help at r-project.org mailing list -- To UNSUBSCRIBE and more, > see > > >> >> >> https://stat.ethz.ch/mailman/listinfo/r-help > > >> >> >> PLEASE do read the posting guide > > >> >> >> http://www.R-project.org/posting-guide.html > > >> >> >> and provide commented, minimal, self-contained, reproducible > code. > > >> >> > > > >> >> > > > >> > > > >> > > > > > > > > > > > [[alternative HTML version deleted]] > > ______________________________________________ > R-help at r-project.org mailing list -- To UNSUBSCRIBE and more, see > https://stat.ethz.ch/mailman/listinfo/r-help > PLEASE do read the posting guide http://www.R-project.org/ > posting-guide.html > and provide commented, minimal, self-contained, reproducible code. >[[alternative HTML version deleted]]