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

org.apache.sysml.runtime.matrix.sort.IndexSortStitchupMapper Maven / Gradle / Ivy

There is a newer version: 1.2.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.apache.sysml.runtime.matrix.sort;

import java.io.IOException;
import java.util.StringTokenizer;

import org.apache.hadoop.mapred.JobConf;
import org.apache.hadoop.mapred.MapReduceBase;
import org.apache.hadoop.mapred.Mapper;
import org.apache.hadoop.mapred.OutputCollector;
import org.apache.hadoop.mapred.Reporter;

import org.apache.sysml.runtime.matrix.SortMR;
import org.apache.sysml.runtime.matrix.data.MatrixBlock;
import org.apache.sysml.runtime.matrix.data.MatrixIndexes;
import org.apache.sysml.runtime.matrix.mapred.MRJobConfiguration;

public class IndexSortStitchupMapper extends MapReduceBase 
 	  implements Mapper
{
	
  	private long[] _offsets = null;
  	private long _rlen = -1;
  	private long _brlen = -1;
  	
  	private MatrixBlock _tmpBlk = null;
  	private MatrixIndexes _tmpIx = null;
  	
	@Override
	public void map(MatrixIndexes key, MatrixBlock value, OutputCollector out, Reporter reporter) 
		throws IOException 
	{
		//compute starting cell offset
		int id = (int)key.getColumnIndex();
		long offset = _offsets[id];
		offset += (key.getRowIndex()-1)*_brlen;
		
		//SPECIAL CASE: block aligned
		int blksize = computeOutputBlocksize(_rlen, _brlen, offset);
		if( offset%_brlen==0 && value.getNumRows()==blksize ) 
		{ 
			_tmpIx.setIndexes(offset/_brlen+1, 1);
			out.collect(_tmpIx, value);
		}
		//GENERAL CASE: not block aligned
		else 
		{
			int loffset = (int) (offset%_brlen);
			//multiple output blocks
			if( value.getNumRows()+loffset>_brlen ) 
			{
				long tmpnnz = 0;
				//output first part
				_tmpBlk.reset( (int)_brlen, 1 );
				for( int i=0; i<_brlen-loffset; i++ )
					_tmpBlk.quickSetValue(loffset+i, 0, value.quickGetValue(i, 0));
				tmpnnz += _tmpBlk.getNonZeros();
				_tmpIx.setIndexes(offset/_brlen+1, 1);
				out.collect(_tmpIx, _tmpBlk);		
			
				//output second block
				blksize = computeOutputBlocksize(_rlen, _brlen, offset+(_brlen-loffset));
				_tmpBlk.reset( blksize, 1 );
				for( int i=(int)_brlen-loffset; i




© 2015 - 2024 Weber Informatics LLC | Privacy Policy