[Rd] Is this a bug in `[`?
Rui Barradas
ruipb@rr@d@@ @ending from @@po@pt
Sun Aug 5 10:45:39 CEST 2018
Thanks,
This is what I needed.
I had read the R Inferno a long time ago and apparently forgot this one.
Rui Barradas
Às 08:46 de 05/08/2018, Patrick Burns escreveu:
> This is Circle 8..1.13 of the R Inferno.
>
>
> On 05/08/2018 06:57, Rui Barradas wrote:
>> Thanks.
>> This is exactly the doubt I had.
>>
>> Rui Barradas
>>
>> Às 05:26 de 05/08/2018, Kenny Bell escreveu:
>>> This should more clearly illustrate the issue:
>>>
>>> c(1, 2, 3, 4)[-seq_len(4)]
>>> #> numeric(0)
>>> c(1, 2, 3, 4)[-seq_len(3)]
>>> #> [1] 4
>>> c(1, 2, 3, 4)[-seq_len(2)]
>>> #> [1] 3 4
>>> c(1, 2, 3, 4)[-seq_len(1)]
>>> #> [1] 2 3 4
>>> c(1, 2, 3, 4)[-seq_len(0)]
>>> #> numeric(0)
>>> Created on 2018-08-05 by the reprex package (v0.2.0.9000).
>>>
>>> On Sun, Aug 5, 2018 at 3:58 AM Rui Barradas <ruipbarradas using sapo.pt
>>> <mailto:ruipbarradas using sapo.pt>> wrote:
>>>
>>>
>>>
>>> Às 15:51 de 04/08/2018, Iñaki Úcar escreveu:
>>> > El sáb., 4 ago. 2018 a las 15:32, Rui Barradas
>>> > (<ruipbarradas using sapo.pt <mailto:ruipbarradas using sapo.pt>>) escribió:
>>> >>
>>> >> Hello,
>>> >>
>>> >> Maybe I am not understanding how negative indexing works but
>>> >>
>>> >> 1) This is right.
>>> >>
>>> >> (1:10)[-1]
>>> >> #[1] 2 3 4 5 6 7 8 9 10
>>> >>
>>> >> 2) Are these right? They are at least surprising to me.
>>> >>
>>> >> (1:10)[-0]
>>> >> #integer(0)
>>> >>
>>> >> (1:10)[-seq_len(0)]
>>> >> #integer(0)
>>> >>
>>> >>
>>> >> It was the last example that made me ask, seq_len(0) whould
>>> avoid an
>>> >> if/else or something similar.
>>> >
>>> > I think it's ok, because there is no negative zero integer, so -0
>>> is 0.
>>>
>>> Ok, this makes sense, I should have thought about that.
>>>
>>> >
>>> > 1.0/-0L # Inf
>>> > 1.0/-0.0 # - Inf
>>> >
>>> > And the same can be said for integer(0), which is the result of
>>> > seq_len(0): there is no negative empty integer.
>>>
>>> I'm not completely convinced about this one, though.
>>> I would expect -seq_len(n) to remove the first n elements from the
>>> vector, therefore, when n == 0, it would remove none.
>>>
>>> And integer(0) is not the same as 0.
>>>
>>> (1:10)[-0] == (1:10)[0] == integer(0) # empty
>>>
>>> (1:10)[-seq_len(0)] == (1:10)[-integer(0)]
>>>
>>>
>>> And I have just reminded myself to run
>>>
>>> identical(-integer(0), integer(0))
>>>
>>> It returns TRUE so my intuition is wrong, R is right.
>>> End of story.
>>>
>>> Thanks for the help,
>>>
>>> Rui Barradas
>>>
>>> >
>>> > Iñaki
>>> >
>>> >>
>>> >>
>>> >> Thanks in advance,
>>> >>
>>> >> Rui Barradas
>>> >>
>>> >> ______________________________________________
>>> >> R-devel using r-project.org <mailto:R-devel using r-project.org> mailing
>>> list
>>> >> https://stat.ethz.ch/mailman/listinfo/r-devel
>>>
>>> ______________________________________________
>>> R-devel using r-project.org <mailto:R-devel using r-project.org> mailing list
>>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>>
>>
>> ______________________________________________
>> R-devel using r-project.org mailing list
>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>
>
More information about the R-devel
mailing list