
com.signalcollect.factory.worker.Akka.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of signal-collect_2.11 Show documentation
Show all versions of signal-collect_2.11 Show documentation
A framework for parallel and distributed graph processing.
The newest version!
/*
* @author Philip Stutz
*
* Copyright 2012 University of Zurich
*
* 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 com.signalcollect.factory.worker
import scala.reflect.ClassTag
import com.signalcollect.configuration.GraphConfiguration
import com.signalcollect.interfaces.WorkerFactory
import com.signalcollect.worker.AkkaWorker
import com.signalcollect.interfaces.MessageBusFactory
import com.signalcollect.interfaces.MapperFactory
import com.signalcollect.interfaces.StorageFactory
import com.signalcollect.interfaces.SchedulerFactory
import com.signalcollect.interfaces.ExistingVertexHandlerFactory
import com.signalcollect.interfaces.UndeliverableSignalHandlerFactory
import com.signalcollect.interfaces.EdgeAddedToNonExistentVertexHandlerFactory
/**
* The default Akka worker implementation.
*/
class AkkaWorkerFactory[Id: ClassTag, Signal: ClassTag] extends WorkerFactory[Id, Signal] {
def createInstance(
workerId: Int,
numberOfWorkers: Int,
numberOfNodes: Int,
messageBusFactory: MessageBusFactory[Id, Signal],
mapperFactory: MapperFactory[Id],
storageFactory: StorageFactory[Id, Signal],
schedulerFactory: SchedulerFactory[Id, Signal],
existingVertexHandlerFactory: ExistingVertexHandlerFactory[Id, Signal],
undeliverableSignalHandlerFactory: UndeliverableSignalHandlerFactory[Id, Signal],
edgeAddedToNonExistentVertexHandlerFactory: EdgeAddedToNonExistentVertexHandlerFactory[Id, Signal],
statsReportingIntervalInMilliseconds: Int,
eagerIdleDetection: Boolean,
throttlingEnabled: Boolean,
throttlingDuringLoadingEnabled: Boolean,
supportBlockingGraphModificationsInVertex: Boolean): AkkaWorker[Id, Signal] = {
new AkkaWorker[Id, Signal](
workerId,
numberOfWorkers,
numberOfNodes,
messageBusFactory,
mapperFactory,
storageFactory,
schedulerFactory,
existingVertexHandlerFactory,
undeliverableSignalHandlerFactory,
edgeAddedToNonExistentVertexHandlerFactory,
statsReportingIntervalInMilliseconds,
eagerIdleDetection,
throttlingEnabled,
throttlingDuringLoadingEnabled,
supportBlockingGraphModificationsInVertex)
}
override def toString: String = "AkkaWorkerFactory"
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy