jhainm@fas.harvard.edu
2005-Jul-28  13:52 UTC
[R] replace matrix values with names from a dataframe
Hi, I am looking for a way to replace matrix values with names from a dataframe. Let me do this by example: I have a dataframe:>datacity.name 1 munich 2 paris 3 tokio 4 london 5 boston each city name corresponds to only one index number (there is only one observation for each city). After doing some matching I end up with a matrix that looks something like this:> X[,1] [,2] [1,] 2 4 [2,] 5 1 [3,] 5 3 [4,] 12 217 [5,] 16 13 Here the numbers in the matrix are the index numbers from my original dataset, each row is a matched pair (so e.g. the first row tells me that obs. number 2 (i.e. Paris) was matched to obs number 4 (i.e. London)). Now I am looking for a quick way to transform the index numbers back to city names, so that at the end I have a matrix that looks something like this:> X.transformed[,1] [,2] [1,] paris london [2,] boston munich [3,] boston tokio [4,] 12 217 [5,] 16 13 etc. So instead of the index number, the matrix should contain the names that corresponds to it. In my real data, I have many many names and replacing each value by hand would take too long. Any help is highly appreciated. Thank you. Regards, Jens
Dimitris Rizopoulos
2005-Jul-28  14:06 UTC
[R] replace matrix values with names from a dataframe
maybe something like this could be helpful
city.name <- c("munich", "paris", "tokio",
"london", "boston")
X <- cbind(c(2, 5, 5), c(4, 1, 3))
####
matrix(city.name[X], ncol = 2)
I hope it helps.
Best,
Dimitris
----
Dimitris Rizopoulos
Ph.D. Student
Biostatistical Centre
School of Public Health
Catholic University of Leuven
Address: Kapucijnenvoer 35, Leuven, Belgium
Tel: +32/16/336899
Fax: +32/16/337015
Web: http://www.med.kuleuven.be/biostat/
     http://www.student.kuleuven.be/~m0390867/dimitris.htm
----- Original Message ----- 
From: <jhainm at fas.harvard.edu>
To: <r-help at stat.math.ethz.ch>
Sent: Thursday, July 28, 2005 3:52 PM
Subject: [R] replace matrix values with names from a dataframe
> Hi,
>
> I am looking for a way to replace matrix values with names from a 
> dataframe.
>
> Let me do this by example: I have a dataframe:
>
>>data
>  city.name
> 1    munich
> 2     paris
> 3     tokio
> 4    london
> 5    boston
>
> each city name corresponds to only one index number (there is only 
> one
> observation for each city). After doing some matching I end up with 
> a matrix
> that looks something like this:
>
>> X
>       [,1] [,2]
>  [1,]    2    4
>  [2,]    5    1
>  [3,]    5    3
>  [4,]   12  217
>  [5,]   16   13
>
> Here the numbers in the matrix are the index numbers from my 
> original dataset,
> each row is a matched pair (so e.g. the first row tells me that obs. 
> number 2
> (i.e. Paris) was matched to obs number 4 (i.e. London)).
>
> Now I am looking for a quick way to transform the index numbers back 
> to city
> names, so that at the end I have a matrix that looks something like 
> this:
>
>> X.transformed
>         [,1]     [,2]
>  [1,]  paris   london
>  [2,] boston   munich
>  [3,] boston    tokio
>  [4,]     12      217
>  [5,]     16       13
>
> etc. So instead of the index number, the matrix should contain the 
> names that
> corresponds to it. In my real data, I have many many names and 
> replacing each
> value by hand would take too long. Any help is highly appreciated.
>
> Thank you.
>
> Regards,
> Jens
>
> ______________________________________________
> R-help at stat.math.ethz.ch mailing list
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide! 
> http://www.R-project.org/posting-guide.html
>
Spencer Graves
2005-Jul-29  16:03 UTC
[R] replace matrix values with names from a dataframe
Does the following help:
 > set.seed(1)
 > Lvls <- factor(letters[1:4])
 > A <- array(sample(4, 6, replace=TRUE), dim=c(2,3))
 > A[] <- levels(Lvls)[A]
 > A
      [,1] [,2] [,3]
[1,] "b"  "c"  "a"
[2,] "b"  "d"  "d"
 >
	  If not, PLEASE do read the posting guide! 
"http://www.R-project.org/posting-guide.html" and submit another 
question (if the process of working the posting guide does not itself 
provide enlightenment).
	  spencer graves
jhainm at fas.harvard.edu wrote:
> Hi,
> 
> I am looking for a way to replace matrix values with names from a
dataframe.
> 
> Let me do this by example: I have a dataframe:
> 
> 
>>data
> 
>   city.name
> 1    munich
> 2     paris
> 3     tokio
> 4    london
> 5    boston
> 
> each city name corresponds to only one index number (there is only one
> observation for each city). After doing some matching I end up with a
matrix
> that looks something like this:
> 
> 
>>X
> 
>        [,1] [,2]
>   [1,]    2    4
>   [2,]    5    1
>   [3,]    5    3
>   [4,]   12  217
>   [5,]   16   13
> 
> Here the numbers in the matrix are the index numbers from my original
dataset,
> each row is a matched pair (so e.g. the first row tells me that obs. number
2
> (i.e. Paris) was matched to obs number 4 (i.e. London)).
> 
> Now I am looking for a quick way to transform the index numbers back to
city
> names, so that at the end I have a matrix that looks something like this:
> 
> 
>>X.transformed
> 
>          [,1]     [,2]
>   [1,]  paris   london
>   [2,] boston   munich
>   [3,] boston    tokio
>   [4,]     12      217
>   [5,]     16       13
> 
> etc. So instead of the index number, the matrix should contain the names
that
> corresponds to it. In my real data, I have many many names and replacing
each
> value by hand would take too long. Any help is highly appreciated.
> 
> Thank you.
> 
> Regards,
> Jens
> 
> ______________________________________________
> R-help at stat.math.ethz.ch mailing list
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide!
http://www.R-project.org/posting-guide.html
-- 
Spencer Graves, PhD
Senior Development Engineer
PDF Solutions, Inc.
333 West San Carlos Street Suite 700
San Jose, CA 95110, USA
spencer.graves at pdf.com
www.pdf.com <http://www.pdf.com>
Tel:  408-938-4420
Fax: 408-280-7915