The hardware and bandwidth for this mirror is donated by dogado GmbH, the Webhosting and Full Service-Cloud Provider. Check out our Wordpress Tutorial.
If you wish to report a bug, or if you are interested in having us mirror your free-software or open-source project, please feel free to contact us at mirror[@]dogado.de.
Package implementing additional infix operators for R.
Implemented operators work with 4 different value types: sets, intervals, regular expressions, and counts.
And provide 3 distinct functionalities: detection, subsetting, and replacement.
Install using the remotes
package:
remotes::install_github("moodymudskipper/inops")
All operators have the same form composed of two distinct parts: %<operation><type>%
.
[operation]
specifies the performed functionality and can be one of in
, out
, [in
, [out
.[type]
specifies the type of operation and can be one of {}
, []
, ()
, [)
, (]
, ~
, ~p
, ~f
, #
. %in{}%
%out{}%
Work with the same values as %in%
does but provide a more consistent behaviour for data.frames
and NA
values.
letters <- letters[1:10]
letters
#> [1] "a" "b" "c" "d" "e" "f" "g" "h" "i" "j"
# sets
letters %in{}% c("a", "b", "c", "e")
#> [1] TRUE TRUE TRUE FALSE TRUE FALSE FALSE FALSE FALSE FALSE
letters %out{}% c("a", "b", "c", "e")
#> [1] FALSE FALSE FALSE TRUE FALSE TRUE TRUE TRUE TRUE TRUE
%in()% %in[]% %in[)% %in(]%
%out()% %out[]% %out[)% %out(]%
1:10
#> [1] 1 2 3 4 5 6 7 8 9 10
# closed interval
1:10 %in()% c(3,6)
#> [1] FALSE FALSE FALSE TRUE TRUE FALSE FALSE FALSE FALSE FALSE
1:10 %out()% c(3,6)
#> [1] TRUE TRUE TRUE FALSE FALSE TRUE TRUE TRUE TRUE TRUE
# open interval
1:10 %in[]% c(3,6)
#> [1] FALSE FALSE TRUE TRUE TRUE TRUE FALSE FALSE FALSE FALSE
1:10 %out[]% c(3,6)
#> [1] TRUE TRUE FALSE FALSE FALSE FALSE TRUE TRUE TRUE TRUE
# open on the right
1:10 %in(]% c(3,6)
#> [1] FALSE FALSE FALSE TRUE TRUE TRUE FALSE FALSE FALSE FALSE
1:10 %out(]% c(3,6)
#> [1] TRUE TRUE TRUE FALSE FALSE FALSE TRUE TRUE TRUE TRUE
# open on the left
1:10 %in[)% c(3,6)
#> [1] FALSE FALSE TRUE TRUE TRUE FALSE FALSE FALSE FALSE FALSE
1:10 %out[)% c(3,6)
#> [1] TRUE TRUE FALSE FALSE FALSE TRUE TRUE TRUE TRUE TRUE
%in~% %in~f% %in~p%
%out~% %out~f% %out~p%
month.name
#> [1] "January" "February" "March" "April" "May"
#> [6] "June" "July" "August" "September" "October"
#> [11] "November" "December"
# regular expressions
month.name %in~% "^M.*"
#> [1] FALSE FALSE TRUE FALSE TRUE FALSE FALSE FALSE FALSE FALSE FALSE
#> [12] FALSE
month.name %out~% "^M.*"
#> [1] TRUE TRUE FALSE TRUE FALSE TRUE TRUE TRUE TRUE TRUE TRUE
#> [12] TRUE
# fixed string regular expressions
month.name %in~f% "^M.*"
#> [1] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
#> [12] FALSE
month.name %out~f% "^M.*"
#> [1] TRUE TRUE FALSE TRUE FALSE TRUE TRUE TRUE TRUE TRUE TRUE
#> [12] TRUE
# perl regular expressions
month.name %in~p% "^(?=.*r)(?!.*er)"
#> [1] TRUE TRUE TRUE TRUE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
#> [12] FALSE
month.name %out~p% "^(?=.*r)(?!.*er)"
#> [1] FALSE FALSE FALSE FALSE TRUE TRUE TRUE TRUE TRUE TRUE TRUE
#> [12] TRUE
%in#%
%out#%
Same form as examples shown above.
month.name
#> [1] "January" "February" "March" "April" "May"
#> [6] "June" "July" "August" "September" "October"
#> [11] "November" "December"
month.name %in~% c("^A", "^M")
#> [1] FALSE FALSE TRUE TRUE TRUE FALSE FALSE TRUE FALSE FALSE FALSE
#> [12] FALSE
Used for obtaining actual values.
Starts with [
.
month.name
#> [1] "January" "February" "March" "April" "May"
#> [6] "June" "July" "August" "September" "October"
#> [11] "November" "December"
month.name %[in~% c("^A", "^M")
#> [1] "March" "April" "May" "August"
Used for replacing the matched elements with new values.
Called with assignment <-
at the end.
month.name
#> [1] "January" "February" "March" "April" "May"
#> [6] "June" "July" "August" "September" "October"
#> [11] "November" "December"
month.name %in~% c("^A", "^M") <- "A or M"
month.name
#> [1] "January" "February" "A or M" "A or M" "A or M"
#> [6] "June" "July" "A or M" "September" "October"
#> [11] "November" "December"
The operators implemented here try to be consistent with the default comparison operators like ==
and <
.
Therefore in some scenarios their behaviour differs from %in%
.
For instance:
%in{}%
can be used on on data frames.df1 <- data.frame(a = 1:3, b = 2:4, c=letters[1:3])
df1 == 2
#> a b c
#> [1,] FALSE TRUE FALSE
#> [2,] TRUE FALSE FALSE
#> [3,] FALSE FALSE FALSE
df1 %in% 2
#> [1] FALSE FALSE FALSE
df1 %in{}% 2
#> a b c
#> [1,] FALSE TRUE FALSE
#> [2,] TRUE FALSE FALSE
#> [3,] FALSE FALSE FALSE
df1 %in{}% 2:3
#> a b c
#> [1,] FALSE TRUE FALSE
#> [2,] TRUE TRUE FALSE
#> [3,] TRUE FALSE FALSE
Simple examples for illustration.
Selecting flight records from the flights
dataset that:
library(nycflights13)
library(dplyr)
library(inops)
flights <- select(flights, origin, dest, tailnum, dep_time, arr_time, distance)
flights
#> # A tibble: 336,776 x 6
#> origin dest tailnum dep_time arr_time distance
#> <chr> <chr> <chr> <int> <int> <dbl>
#> 1 EWR IAH N14228 517 830 1400
#> 2 LGA IAH N24211 533 850 1416
#> 3 JFK MIA N619AA 542 923 1089
#> 4 JFK BQN N804JB 544 1004 1576
#> 5 LGA ATL N668DN 554 812 762
#> 6 EWR ORD N39463 554 740 719
#> 7 EWR FLL N516JB 555 913 1065
#> 8 LGA IAD N829AS 557 709 229
#> 9 JFK MCO N593JB 557 838 944
#> 10 LGA ORD N3ALAA 558 753 733
#> # ... with 336,766 more rows
filter(flights,
dep_time %in()% c(1200, 1700),
arr_time %in()% c(1200, 1700),
dest %out% c("LEX", "PSP", "HDN"),
distance %out[]% c(100, 3000),
tailnum %in~% c("^N1", "^N3")
)
#> # A tibble: 2 x 6
#> origin dest tailnum dep_time arr_time distance
#> <chr> <chr> <chr> <int> <int> <dbl>
#> 1 EWR PHL N14972 1240 1333 80
#> 2 JFK HNL N391HA 1214 1645 4983
Cleaning up planes
dataset in order to:
library(nycflights13)
library(inops)
table(planes$manufacturer %[in~% c("AIRBUS", "CANADAIR", "MCDONNELL"))
#>
#> AIRBUS AIRBUS INDUSTRIE
#> 336 400
#> CANADAIR CANADAIR LTD
#> 9 1
#> MCDONNELL DOUGLAS MCDONNELL DOUGLAS AIRCRAFT CO
#> 120 103
#> MCDONNELL DOUGLAS CORPORATION
#> 14
planes$manufacturer %in~% "AIRBUS" <- "AIRBUS"
planes$manufacturer %in~% "CANADAIR" <- "CANADAIR"
planes$manufacturer %in~% "MCDONNELL" <- "MCDONNELL"
table(planes$manufacturer %[in~% c("AIRBUS", "CANADAIR", "MCDONNELL"))
#>
#> AIRBUS CANADAIR MCDONNELL
#> 736 10 237
Combine engine models that in the dataset occur less than 6 times under the “Other” group.
library(nycflights13)
library(inops)
table(planes$engine)
#>
#> 4 Cycle Reciprocating Turbo-fan Turbo-jet Turbo-prop
#> 2 28 2750 535 2
#> Turbo-shaft
#> 5
planes$engine %in#% 1:5 <- "Other"
table(planes$engine)
#>
#> Other Reciprocating Turbo-fan Turbo-jet
#> 9 28 2750 535
Below is a full list of all the implemented operators along with their usage examples.
Form | Description | Call |
---|---|---|
%in{}% |
which elements are inside a set | x %in{}% set |
%in[]% |
which elements are inside a closed interval | x %in[]% interval |
%in()% |
which elements are inside an open interval | x %in()% interval |
%in[)% |
which elements are inside an interval open on the right | x %in[)% interval |
%in(]% |
which elements are inside an interval open on the left | x %in(]% interval |
%in~% |
which elements match a regular expression | x %in~% pattern |
%in~p% |
which elements match a regular perl expression | x %in~p% pattern |
%in~f% |
which elements match a regular fixed expression | x %in~f% pattern |
%in#% |
which elements occur a specified number of times | x %in#% count |
%out% |
which elements are outside a set (same as ! x %in% y) | x %out% set |
%out{}% |
which elements are outside a set | x %out{}% set |
%out[]% |
which elements are outside a closed interval | x %out[]% interval |
%out()% |
which elements are outside an open interval | x %out()% interval |
%out[)% |
which elements are outside an interval open on the right | x %out[)% interval |
%out(]% |
which elements are outside an interval open on the left | x %out(]% interval |
%out~% |
which elements do not match a regular expression | x %out~% pattern |
%out~p% |
which elements do not match a regular perl expression | x %out~p% pattern |
%out~f% |
which elements do not match a regular fixed expression | x %out~f% pattern |
%out#% |
which elements occur other than a specified number of times | x %out#% count |
Form | Description | Call |
---|---|---|
%[in% |
select elements inside a set | x %[in% set |
%[in{}% |
select elements inside a set | x %[in{}% set |
%[in[]% |
select elements inside a closed interval | x %[in[]% interval |
%[in()% |
select elements inside an open interval | x %[in()% interval |
%[in[)% |
select elements inside an interval open on the right | x %[in[)% interval |
%[in(]% |
select elements inside an interval open on the left | x %[in(]% interval |
%[in~% |
select elements matching a regular expression | x %[in~% pattern |
%[in~p% |
select elements matching a regular perl expression | x %[in~p% pattern |
%[in~f% |
select elements matching a regular fixed expression | x %[in~f% pattern |
%[in#% |
select elements that occur a specified number of times | x %[in#% count |
%[out% |
select elements outside a set | x %[out% set |
%[out{}% |
select elements outside a set | x %[out{}% set |
%[out[]% |
select elements outside a closed interval | x %[out[]% interval |
%[out()% |
select elements outside an open interval | x %[out()% interval |
%[out[)% |
select elements outside an interval open on the right | x %[out[)% interval |
%[out(]% |
select elements outside an interval open on the left | x %[out(]% interval |
%[out~% |
select elements not matching a regular expression | x %[out~% pattern |
%[out~p% |
select elements not matching a regular perl expression | x %[out~p% pattern |
%[out~f% |
select elements not matching a regular fixed expression | x %[out~f% pattern |
%[out#% |
select elements that occur other than specified number of times | x %[out% count |
Form | Description | Call |
---|---|---|
==<- |
change elements equal to the provided value | x == element <- value |
!=<- |
change elements not equal to the provided value | x != element <- value |
><- |
change elements greater than the provided value | x > number <- value |
<<- |
change elements lower than the provided value | x < number <- value |
>=<- |
change elements greater or equal to the provided value | x >= number <- value |
<=<- |
change elements lower or equal to the provided value | x <= number <- value |
%in%<- |
change elements inside a set | x %in% set <- value |
%in{}%<- |
change elements inside a set | x %in{}% set <- value |
%in[]%<- |
change elements inside a closed interval | x %in[]% interval <- value |
%in()%<- |
change elements inside an open interval | x %in()% interval <- value |
%in[)%<- |
change elements inside an interval open on the right | x %in[)% interval <- value |
%in(]%<- |
change elements inside an interval open on the left | x %in(]% interval <- value |
%in~%<- |
change elements matching a regular expression | x %in~% pattern <- value |
%in~p%<- |
change elements matching a regular perl expression | x %in~p% pattern <- value |
%in~f%<- |
change elements matching a regular fixed expression | x %in~f% pattern <- value |
%in#%<- |
change elements that occur specified number of times | x %in#% count <- value |
%out%<- |
change elements outside a set | x %out% set <- value |
%out{}%<- |
change elements outside a set | x %out{}% set <- value |
%out[]%<- |
change elements outside a closed interval | x %out[]% interval <- value |
%out()%<- |
change elements outside an open interval | x %out()% interval <- value |
%out[)%<- |
change elements outside an interval open on the right | x %out[)% interval <- value |
%out(]%<- |
change elements outside an interval open on the left | x %out(]% interval <- value |
%out~%<- |
change elements not matching a regular expression | x %out~% pattern <- value |
%out~p%<- |
change elements not matching a regular perl expression | x %out~p% pattern <- value |
%out~f%<- |
change elements not matching a regular fixed expression | x %out~f% pattern <- value |
%out#%<- |
change elements that occur other than specified number of times | x %out#% count <- value |
To give an assignment counterpart to <
we had to overload the <<-
operator, which explains the message when attaching the package. This doesn’t affect the behavior of the <<-
assignments.
These binaries (installable software) and packages are in development.
They may not be fully stable and should be used with caution. We make no claims about them.
Health stats visible at Monitor.