Description Usage Arguments Details References See Also Examples
is.atomic
returns TRUE
if x
is of an atomic type
(or NULL
) and FALSE
otherwise.
is.recursive
returns TRUE
if x
has a recursive
(list-like) structure and FALSE
otherwise.
1 2 | is.atomic(x)
is.recursive(x)
|
x |
object to be tested. |
is.atomic
is true for the atomic types
("logical"
, "integer"
, "numeric"
,
"complex"
, "character"
and "raw"
) and NULL
.
Most types of objects are regarded as recursive. Exceptions are the atomic
types, NULL
, symbols (as given by as.name
),
S4
objects with slots, external pointers, and—rarely visible
from R—weak references and byte code, see typeof
.
It is common to call the atomic types ‘atomic vectors’, but
note that is.vector
imposes further restrictions: an
object can be atomic but not a vector (in that sense).
These are primitive functions.
Becker, R. A., Chambers, J. M. and Wilks, A. R. (1988) The New S Language. Wadsworth & Brooks/Cole.
is.list
,
is.language
, etc,
and the demo("is.things")
.
1 2 3 4 5 6 7 8 9 10 11 | require(stats)
is.a.r <- function(x) c(is.atomic(x), is.recursive(x))
is.a.r(c(a = 1, b = 3)) # TRUE FALSE
is.a.r(list()) # FALSE TRUE - a list is a list
is.a.r(list(2)) # FALSE TRUE
is.a.r(lm) # FALSE TRUE
is.a.r(y ~ x) # FALSE TRUE
is.a.r(expression(x+1)) # FALSE TRUE
is.a.r(quote(exp)) # FALSE FALSE
|
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.