/*
* Copyright (c) 2012 Patrick Meyer
*
* This program 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.
*
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.itemanalysis.jmetrik.graph.nicc;
import com.itemanalysis.jmetrik.commandbuilder.*;
public class NonparametricCurveCommand extends AbstractCommand {
public NonparametricCurveCommand()throws IllegalArgumentException{
super("nicc", "Nonparamedtric item characteristic curves");
FreeOptionList selectedVariables = new FreeOptionList("variables", "List of selected variables", true, OptionValueType.STRING);
this.addFreeOptionList(selectedVariables);
FreeOption regressorVariable = new FreeOption("xvar", "Regressor variable", true, OptionValueType.STRING);
this.addFreeOption(regressorVariable);
FreeOption groupVariable = new FreeOption("groupvar", "DIF group variable", false, OptionValueType.STRING);
this.addFreeOption(groupVariable);
PairedOptionList dataInfo = new PairedOptionList("data", "Data information", true);
dataInfo.add("db", OptionValueType.STRING);
dataInfo.add("table", OptionValueType.STRING);
this.addPairedOptionList(dataInfo);
SelectOneOption curves = new SelectOneOption("curves", "Type of curves", false);
curves.addArgument("all", "Show curves for all response options");
curves.addArgument("expected", "Show curve for correct answer (expected item score)");
this.addSelectOneOption(curves);
SelectOneOption kernel = new SelectOneOption("kernel", "Kernel type", false);
kernel.addArgument("epanechnikov", "Epanechnikov kernel");
kernel.addArgument("uniform", "Uniform kernel");
kernel.addArgument("triangle", "Triangle kernel");
kernel.addArgument("biweight", "Biweight kernel");
kernel.addArgument("triweight", "Triweight kernel");
kernel.addArgument("cosine", "Cosine kernel");
kernel.addArgument("gaussian", "Gaussian kernel");
this.addSelectOneOption(kernel);
FreeOption adjust = new FreeOption("adjust", "Bandwidth adjustment factor", false, OptionValueType.DOUBLE);
adjust.add(1.0);
this.addFreeOption(adjust);
FreeOption grid = new FreeOption("gridpoints", "Number of grid points for kernel estimator", false, OptionValueType.INTEGER);
grid.add(51);
this.addFreeOption(grid);
SelectAllOption options = new SelectAllOption("options", "General options", false);
options.addArgument("noprint", "Do not display results file", false);
this.addSelectAllOption(options);
PairedOptionList groupCodes = new PairedOptionList("codes", "Focal and references group codes", false);
groupCodes.add("focal", OptionValueType.STRING);
groupCodes.add("reference", OptionValueType.STRING);
this.addPairedOptionList(groupCodes);
FreeOption output = new FreeOption("output", "Output directory", false, OptionValueType.STRING);
this.addFreeOption(output);
}
public String getDataString()throws IllegalArgumentException{
String s = "";
try{
s = this.getPairedOptionList("data").getStringAt("db") + "." +
this.getPairedOptionList("data").getStringAt("table");
}catch(IllegalArgumentException ex){
throw new IllegalArgumentException(ex);
}
return s;
}
}