I don't think I understand you entirely, but here are a couple
things.
You need to shorten the loop so you don't run off the end.
You basically just write the code as you've stated it except that
"and" is && for single values and & for vectors
You don't say what should happen if the test is not true.
You can probably use "ifelse" instead of  a loop.
iseq <- 2:(length(x.dif) - 2)
test <- x.dif[iseq-1] <= 0 & x.dif[iseq] > 0 & x.dif[iseq + 2]
> 0
ifelse(test, iseq + 2, NA)
I suspect that the last term in test should be i+1 and not i+2 ?
You can see S Poetry for details.
Patrick Burns
Burns Statistics
patrick@burns-stat.com
+44 (0)20 8525 0696
http://www.burns-stat.com
(home of S Poetry and "A Guide for the Unwilling S User")
ebashi wrote:
>I'll appreciate if some one can help me with the
>following loop. This is the logic of the loop,
>if we have the following data;
>  
>
>>x.df
>>    
>>
>    x.dif
> .    .
> .    .
>102  0.00
>103  0.42
>104  0.08
>105  0.00
>106  0.00
>107  0.00
>108 -0.16
>109 -0.34
>110  0.00
>111 -0.17
>112 -0.33
>113  0.00
>114  0.00
>115  0.00
>116  0.33
>117  0.17
>118  0.00 
> .    .
> .    .
>I'm trying to find i's where 
>  for (i in 2:length(x.dif))
>  if (x.dif[i-1]<=0 and x.dif[i]>0 and x.dif[i+2]>0)
>  it would return i+2 to me,
>How can I turn this to a right format as a loop.(I
>can't figure out the syntax)
>
>Cheers,
>
>Sean
>
>_______________________________________________
>R-sig-finance@stat.math.ethz.ch mailing list
>https://stat.ethz.ch/mailman/listinfo/r-sig-finance
>
>
>  
>