Thanks rui..That was all i wanted... Elisa > Date: Fri, 24 May 2013 17:02:56 +0100 > From: ruipbarra...@sapo.pt > To: eliza_bo...@hotmail.com > CC: b...@xs4all.nl; r-help@r-project.org > Subject: Re: [R] Continuous columns of matrix > > Hello, > > No problem. Just change <0 to >= and Inf to -Inf: > > fun2 <- function(x){ > n <- length(x) > imx <- which.max(x) > if(imx == 1){ > x[2] <- x[n] <- -Inf > }else if(imx == n){ > x[1] <- x[n - 1] <- -Inf > }else{ > x[imx - 1] <- -Inf > x[imx + 1] <- -Inf > } > index <- which(x >= 0.8*x[imx]) > values <- x[index] > list(index = index, values = values) > } > > apply(mat, 2, fun2) > > > Rui Barradas > > Em 24-05-2013 16:23, eliza botto escreveu: > > Dear Rui, > > > > I infact wanted to have something like the following.. > > suppose the columns are > > > > structure(c(0.706461987893674, 0.998391468394261, 0.72402995269242, > > 1.70874688194537, 1.93906363083693, 0.89540353128442, 0.328327645695443, > > 0.427434603701202, 0.591932250254601, 0.444627635494183, 1.44407704434405, > > 1.79150336746345, 2.06195904001605, 1.41493262330451, 1.35748791897328, > > 1.19490680241894, 0.702488756183322, 0.338258418490199, 0.123398398622741, > > 0.138548982660226, 0.16170889185798, 0.414543218677095, 1.84629295875002, > > 2.24547399004563), .Dim = c(12L, 2L)) > > > > For col 1 > > [[1]] > > $Index > > 5 12 > > $value > > 1.939 1.79 > > Although value 1.708 of index 4 also has value which is above 80% of the > > maximum value but as it is in the neighbor of maxmimum value so we wont > > consider it. > > similarly for the column 2 > > [[1]] > > $Index > > 12 > > $value > > 2.245 > > Although values 1.846 of index 11 and 2.0619 of index 1 also have values > > which are above 80% of the maximum value but as they are in the neighbor of > > maxmimum value so we wont consider them. > > i am sorry if the manner in which i asked my question was not conclusive. > > i hope you wont mind... > > Elisa > >> Date: Fri, 24 May 2013 15:59:50 +0100 > >> From: ruipbarra...@sapo.pt > >> To: eliza_bo...@hotmail.com > >> CC: b...@xs4all.nl; r-help@r-project.org > >> Subject: Re: [R] Continuous columns of matrix > >> > >> Hello, > >> > >> Something like this? > >> > >> > >> fun2 <- function(x){ > >> n <- length(x) > >> imx <- which.max(x) > >> if(imx == 1){ > >> x[2] <- x[n] <- Inf > >> }else if(imx == n){ > >> x[1] <- x[n - 1] <- Inf > >> }else{ > >> x[imx - 1] <- Inf > >> x[imx + 1] <- Inf > >> } > >> index <- which(x <= 0.8*x[imx]) > >> values <- x[index] > >> list(index = index, values = values) > >> } > >> > >> apply(mat, 2, fun2) > >> > >> > >> Rui Barradas > >> > >> Em 24-05-2013 13:40, eliza botto escreveu: > >>> Dear Rui,Thankyou very much for your help. just for my own knowledge what > >>> if want the values and index, which are less than or equal to 80% of the > >>> maximum value other than those in the neighbors?? like if maximum is in > >>> row number 5 of any column then the second maximum can be in any row > >>> other than 4 and 6. similarly if maximum is in row number 12 than the > >>> second maximum can be in any row other than 1 and 11...thankyou very much > >>> for your help > >>> elisa > >>> > >>>> Date: Fri, 24 May 2013 12:37:37 +0100 > >>>> From: ruipbarra...@sapo.pt > >>>> To: eliza_bo...@hotmail.com > >>>> CC: b...@xs4all.nl; r-help@r-project.org > >>>> Subject: Re: [R] Continuous columns of matrix > >>>> > >>>> Hello, > >>>> > >>>> Berend is right, it's at least confusing. To get just the index of the > >>>> maximum value in each column, > >>>> > >>>> apply(mat, 2, which.max) > >>>> > >>>> > >>>> To get that index and the two neighbours (before and after, wraping > >>>> around) if they are greater than or equal to 80% of the maximum, try > >>>> > >>>> fun <- function(x){ > >>>> n <- length(x) > >>>> imx <- which.max(x) > >>>> sec <- numeric(2) > >>>> if(imx == 1){ > >>>> if(x[n] >= 0.8*x[imx]) sec[1] <- n > >>>> if(x[2] >= 0.8*x[imx]) sec[2] <- 2 > >>>> }else if(imx == n){ > >>>> if(x[n - 1] >= 0.8*x[imx]) sec[1] <- n - 1 > >>>> if(x[1] >= 0.8*x[imx]) sec[2] <- 1 > >>>> }else{ > >>>> if(x[imx - 1] >= 0.8*x[imx]) sec[1] <- imx - 1 > >>>> if(x[imx + 1] >= 0.8*x[imx]) sec[2] <- imx + 1 > >>>> } > >>>> sec <- sec[sec != 0] > >>>> c(imx, sec) > >>>> } > >>>> > >>>> apply(mat, 2, fun) > >>>> > >>>> > >>>> Note that the result comes with the maximum first and the others follow. > >>>> > >>>> Hope this helps, > >>>> > >>>> Rui Barradas > >>>> > >>>> > >>>> Em 24-05-2013 11:41, eliza botto escreveu: > >>>>> There you go!!! > >>>>> > >>>>> structure(c(0.706461987893674, 0.998391468394261, 0.72402995269242, > >>>>> 1.70874688194537, 1.93906363083693, 0.89540353128442, > >>>>> 0.328327645695443, 0.427434603701202, 0.591932250254601, > >>>>> 0.444627635494183, 1.44407704434405, 1.79150336746345, > >>>>> 0.94525563730664, 1.1025988539757, 0.944726401770203, > >>>>> 0.941068515436361, 1.50874009152312, 0.590015480056925, > >>>>> 0.311905493999476, 0.596771673581893, 1.01502499067153, > >>>>> 0.803273181849135, 1.6704085033648, 1.57021117646422, > >>>>> 0.492096635764151, 0.433332688044914, 0.521585941816778, > >>>>> 1.66472272302545, 2.61878329527404, 2.19154489521664, > >>>>> 0.493876245329722, 0.4915787202584, 0.889477365620806, > >>>>> 0.609135860199222, 0.739201878930367, 0.854663750519518, > >>>>> 0.948228727226247, 1.38569091844218, 0.910510759802679, > >>>>> 1.25991218521949, 0.993123416952421, 0.553640392997634, > >>>>> 0.357487763503204, 0.368328033777003, 0.344255688489322, > >>>>> 0.423679560916755, 1.32093576037521, 3.13420679229785, > >>>>> 2.06195904001605, 1.41493262330451, 1.35748791897328, 1.19490680241894, > >>>>> 0.702488! 75618332! > >>>>> 2, 0.338258418490199, 0.123398398622741, 0.138548982660226, > >>>>> 0.16170889185798, 0.414543218677095, 1.84629295875002, > >>>>> 2.24547399004563, 0.0849732189580101, 0.070591276171845, > >>>>> 0.0926010253161898, 0.362209761457517, 1.45769283057202, > >>>>> 3.16165004659667, 2.74903557756267, 1.94633472878995, 1.19319875840883, > >>>>> 0.533232612926756, 0.225531074123974, 0.122949089115578), .Dim = c(12L, > >>>>> 6L)) > >>>>> > >>>>> Thanks once again.. > >>>>> Elisa > >>>>> > >>>>> > >>>>>> Subject: Re: [R] Continuous columns of matrix > >>>>>> From: b...@xs4all.nl > >>>>>> Date: Fri, 24 May 2013 12:36:47 +0200 > >>>>>> CC: r-help@r-project.org > >>>>>> To: eliza_bo...@hotmail.com > >>>>>> > >>>>>> > >>>>>> On 24-05-2013, at 12:24, eliza botto <eliza_bo...@hotmail.com> wrote: > >>>>>> > >>>>>>> Dear useRs,If i have a matrix, say, 12 rows and 6 columns. The > >>>>>>> columns are continuous. I want to find the index of maximum values > >>>>>>> and the actual maximum values. The maximum values in each column are > >>>>>>> the highest values and the values greater than or equal to 80% of the > >>>>>>> maximum value. Moreover, if a column has more than one maximum values > >>>>>>> than these values should come immediately next to each other. For > >>>>>>> example, if you column 1 has a highest value in 6th row then the > >>>>>>> second maximum values cant be in row 5 or 7. And as the columns are > >>>>>>> continuous therefore, if maximum value is in row 12th, then the > >>>>>>> second maximum cant be in row 11 and 1.Thankyou very much indeed in > >>>>>>> advance > >>>>>> > >>>>>> > >>>>>> Incomprehensible. > >>>>>> What is a continuous column? > >>>>>> > >>>>>> Please give an example input matrix and and the result you want. > >>>>>> > >>>>>> Berend > >>>>>> > >>>>>>> Elisa > >>>>>>> [[alternative HTML version deleted]] > >>>>>>> > >>>>>> > >>>>>> Please post in plain text. > >>>>>> > >>>>> > >>>>> [[alternative HTML version deleted]] > >>>>> > >>>>> ______________________________________________ > >>>>> R-help@r-project.org mailing list > >>>>> https://stat.ethz.ch/mailman/listinfo/r-help > >>>>> PLEASE do read the posting guide > >>>>> http://www.R-project.org/posting-guide.html > >>>>> and provide commented, minimal, self-contained, reproducible code. > >>>>> > >>> > >>> > > > > [[alternative HTML version deleted]]
______________________________________________ R-help@r-project.org mailing list https://stat.ethz.ch/mailman/listinfo/r-help PLEASE do read the posting guide http://www.R-project.org/posting-guide.html and provide commented, minimal, self-contained, reproducible code.