org.labkey.remoteapi.assay.nab.NAbRunsResponse Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of labkey-client-api Show documentation
Show all versions of labkey-client-api Show documentation
The client-side library for Java developers is a separate JAR from the LabKey Server code base. It can be used by any Java program, including another Java web application.
/*
* Copyright (c) 2009-2015 LabKey Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.labkey.remoteapi.assay.nab;
import org.json.JSONObject;
import org.labkey.remoteapi.Command;
import org.labkey.remoteapi.CommandResponse;
import org.labkey.remoteapi.assay.nab.model.NAbRun;
import java.util.List;
import java.util.Map;
/**
* Response class for the {@link NAbRunsCommand}. This class
* provides helpful getter method to access particular bits of the parsed
* response data. Sample usage:
public static void main(String[] args) throws Exception
{
// expected parameters:
// args[0]: username
// args[1]: password
Connection conn = new Connection("http://myserver/labkey", args[0], args[1]);
double avg = getAverageNeutDilution(cn, "/home", "NAB", 50);
System.out.println("Average dilution where 50 percent neutralization occurs: " + avg);
}
public static double getAverageNeutDilution(Connection cn, String folderPath, String assayName, int neutPercent) throws CommandException, IOException
{
NAbRunsCommand nabCommand = new NAbRunsCommand();
nabCommand.setAssayName(assayName);
nabCommand.setCalculateNeut(true);
nabCommand.setIncludeFitParameters(false);
nabCommand.setIncludeStats(false);
nabCommand.setIncludeWells(false);
NAbRunsResponse runResponse = nabCommand.execute(cn, folderPath);
NAbRun[] runs = runResponse.getRuns();
int totalSamples = 0;
double totalDilution = 0;
for (NAbRun run : runs)
{
for (NAbSample sample : run.getSamples())
{
for (NAbNeutralizationResult neutResult : sample.getNeutralizationResults())
{
// only total non-infinite values (that is, results where we found a neutralizing dilution:
if (neutResult.getCutoff() == neutPercent && !Double.isInfinite(neutResult.getCurveBasedDilution()))
{
totalSamples++;
totalDilution += neutResult.getCurveBasedDilution();
}
}
}
}
return totalDilution/totalSamples;
}
*/
public class NAbRunsResponse extends CommandResponse
{
private NAbRun[] _runs;
/**
* Constructs a new CommandResponse, initialized with the provided
* response text and status code.
*
* @param text The response text
* @param statusCode The HTTP status code
* @param contentType The response content type
* @param json The parsed JSONObject (or null if JSON was not returned).
* @param sourceCommand A copy of the command that created this response
*/
public NAbRunsResponse(String text, int statusCode, String contentType, JSONObject json, Command extends NAbRunsResponse> sourceCommand)
{
super(text, statusCode, contentType, json, sourceCommand);
}
public NAbRun[] getRuns()
{
if (_runs == null)
{
List