/*
* (c) 2008- RANDI2 Core Development Team
*
* This file is part of RANDI2.
*
* RANDI2 is free software: you can redistribute it and/or modify it under the
* terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later
* version.
*
* RANDI2 is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
* A PARTICULAR PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with
* RANDI2. If not, see <http://www.gnu.org/licenses/>.
*/
package de.randi2.model.randomization;
import static de.randi2.utility.IntegerIterator.upto;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.Set;
import javax.persistence.Entity;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import lombok.Data;
import lombok.EqualsAndHashCode;
import de.randi2.model.AbstractDomainObject;
import de.randi2.model.TreatmentArm;
/**
* @author Natalie Waskowzow
*
*/
@Entity
@Data
@EqualsAndHashCode(callSuper=true)
public class ResponseAdaptiveUrn extends AbstractDomainObject {
private static final long serialVersionUID = -2472302592410115052L;
@ManyToMany
@JoinTable(name = "ResponseAdaptiveUrn_Treatmentarm",
joinColumns = { @JoinColumn(name = "ResponseAdaptiveUrn_id") },
inverseJoinColumns = { @JoinColumn(name = "Treatmentarm_id") })
private List<TreatmentArm> responseAdaptiveUrn = new ArrayList<TreatmentArm>();
public static ResponseAdaptiveUrn generate(ResponseAdaptiveRConfig config){
ResponseAdaptiveUrn responseAdaptiveUrn = new ResponseAdaptiveUrn();
Set<TreatmentArm> arms = config.getTrial().getTreatmentArms();
int initializeCount = config.getInitializeCountBallsResponseAdaptiveR();
if (initializeCount != 0) {
for (int i : upto(initializeCount)) {
for (TreatmentArm arm : arms) {
responseAdaptiveUrn.add(arm);
}
}
}
return responseAdaptiveUrn;
}
public void add(TreatmentArm arm){
responseAdaptiveUrn.add(arm);
}
public TreatmentArm drawFromUrn(ResponseAdaptiveRConfig config, Random rand) {
if (responseAdaptiveUrn.size() != 0) {
return responseAdaptiveUrn.get(rand.nextInt(responseAdaptiveUrn
.size()));
} else {
TreatmentArm drawnArm = new TreatmentArm();
double randomNumber = rand.nextDouble();
Set<TreatmentArm> arms = config.getTrial().getTreatmentArms();
int i=0;
for(TreatmentArm arm: arms){
i++;
if((randomNumber<(i/arms.size())) && (randomNumber>=(i-1)/arms.size())){
drawnArm=arm;
break;
}
}
return drawnArm;
}
}
}