Nothing
con.Rrss<-function(X,Y,m,r=1,type="l",sets=FALSE,concomitant=FALSE,alpha){
if (is.vector(X)){
if (is.vector(Y)){
if (length(X)==length(Y)){
if ((alpha<0.5)&(alpha>=0)) {
data=matrix(ncol=2,nrow=length(X))
data.x=X
data.y=Y
sample.x=sample.y=numeric()
set.xy=data.frame(X,Y)
set.x=set.y=matrix(nrow=(m*r),ncol=m)
rss=sample.x=sample.y=numeric()
A<-matrix(0,nrow=(m*r),ncol=(m*2))
a=1
b=0
k=floor(m*alpha)
if (type=="l"){
if (k>0){
for (j in 1:r){
for (i in 1:k){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][k+1,1]
sample.y[a]=A[sort.list(A[,2]),][k+1,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
for (i in (k+1):(m-k)){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][i,1]
sample.y[a]=A[sort.list(A[,2]),][i,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
for (i in (m-k+1):m){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][(m-k),1]
sample.y[a]=A[sort.list(A[,2]),][(m-k),2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
b=b+m
}
}else {
for (j in 1:r){
for (i in 1:m){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][i,1]
sample.y[a]=A[sort.list(A[,2]),][i,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
b=b+m
}
}
}else if (type=="tb"){
if (k>0){
for (j in 1:r){
for (i in 1:k){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][1,1]
sample.y[a]=A[sort.list(A[,2]),][1,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
for (i in (k+1):(m-k)){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][i,1]
sample.y[a]=A[sort.list(A[,2]),][i,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
for (i in (m-k+1):m){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][m,1]
sample.y[a]=A[sort.list(A[,2]),][m,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
b=b+m
}
}else {
for (j in 1:r){
for (i in 1:(m)){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][i,1]
sample.y[a]=A[sort.list(A[,2]),][i,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
b=b+m
}
}
}else if (type=="re"){
if (m%%2==0){
for (j in 1:r){
for (i in 1:(m/2)){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][k+1,1]
sample.y[a]=A[sort.list(A[,2]),][k+1,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
for (i in ((m/2)+1):m){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][m-k,1]
sample.y[a]=A[sort.list(A[,2]),][m-k,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
b=b+m
}
}else {
for (j in 1:r){
for (i in 1:((m-1)/2)){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][k+1,1]
sample.y[a]=A[sort.list(A[,2]),][k+1,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][(m+1)/2,1]
sample.y[a]=A[sort.list(A[,2]),][(m+1)/2,2]
set.x[a,]=A[sort.list(A[,2]),]$X
set.y[a,]=A[sort.list(A[,2]),]$Y
a=a+1
for (i in ((m+3)/2):m){
A=set.xy[sample(nrow(set.xy),size=m,replace=TRUE),]
sample.x[a]=A[sort.list(A[,2]),][m-k,1]
sample.y[a]=A[sort.list(A[,2]),][m-k,2]
set.x[i+b,]=A[sort.list(A[,2]),]$X
set.y[i+b,]=A[sort.list(A[,2]),]$Y
a=a+1
}
b=b+m
}
}
}
sample.x=matrix(sample.x,ncol=m,nrow=r,byrow=T)
cn=rn=numeric()
for (i in 1:r){
rn[i]=paste("r","=",i)
}
for (i in 1:m){
cn[i]=paste("m","=",i)
}
rownames(sample.x)=rn
colnames(sample.x)=cn
sample.y=matrix(sample.y,ncol=m,nrow=r,byrow=T)
rownames(sample.y)=rn
colnames(sample.y)=cn
if (concomitant==T){
if (sets==T){
return(list(corr.coef=cor(X,Y),var.of.interest=set.x,concomitant.var.=set.y,sample.x=sample.x,sample.y=sample.y))
}else {
return(list(sample.x=sample.x,sample.y=sample.y))
}
}else {
if (sets==T){
return(list(corr.coef=cor(X,Y),var.of.interest=set.x,sample.x=sample.x))
}else {
return(list(sample.x=sample.x))
}
}
}else stop("alpha is out of bound",call.=F)
}else stop("X and Y must be in same length",call.=F)
}else stop("Y must be a vector!",call.=F)
}else stop("X must be a vector!",call.=F)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.