All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.terrier.structures.outputformat.WritableOutputFormat Maven / Gradle / Ivy

The newest version!
/*
 * Terrier - Terabyte Retriever 
 * Webpage: http://terrier.org 
 * Contact: terrier{a.}dcs.gla.ac.uk
 * University of Glasgow - School of Computing Science
 * http://www.gla.ac.uk/
 * 
 * The contents of this file are subject to the Mozilla Public License
 * Version 1.1 (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.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS"
 * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
 * the License for the specific language governing rights and limitations
 * under the License.
 *
 * The Original Code is WritableOutputFormat.java.
 *
 * The Original Code is Copyright (C) 2004-2020 the University of Glasgow.
 * All Rights Reserved.
 *
 * Contributor(s):
 *   Craig Macdonald 
 */

package org.terrier.structures.outputformat;

import java.io.DataOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintWriter;

import org.apache.hadoop.io.Writable;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.terrier.matching.FatResultSet;
import org.terrier.matching.FatResultsMatching;
import org.terrier.matching.ResultSet;
import org.terrier.querying.Request;
import org.terrier.querying.SearchRequest;
import org.terrier.structures.Index;

/** 
 * This class can be used for writing {@link FatResultSet}s to disk
 * for later use by {@link FatResultsMatching}
 * 
 * @author Craig Macdonald
 * @since 4.0
 */
public class WritableOutputFormat implements RawOutputFormat {

	static Logger logger = LoggerFactory.getLogger(WritableOutputFormat.class);
	
	/** Created a new NullOuputFormat */
	public WritableOutputFormat(Index i){} 
	
	@Override
	public void printResults(PrintWriter pw, SearchRequest q,
			String method, String iteration, int numberOfResults)
			throws IOException 
	{
		throw new UnsupportedOperationException();		
	}

	@Override
	public void writeResults(OutputStream os, SearchRequest q,
			String method, String iteration, int numberOfResults)
			throws IOException 
	{		
		final ResultSet rs = ((Request) q).getResultSet();
		DataOutputStream dos = new DataOutputStream(os);
		dos.writeUTF(q.getQueryID());
		((Writable)rs).write(dos);
		dos.flush();
		dos = null;
		logger.debug("Wrote " + rs.getResultSize() + " results for query " + q.getQueryID());
	}
	
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy