python improvements

metadata
Wenzel Jakob 2011-08-21 00:30:49 -04:00
parent 482ca30bfc
commit e92e71b9ec
5 changed files with 135 additions and 31 deletions

View File

@ -33,7 +33,14 @@ MTS_NAMESPACE_BEGIN
/** /**
* \brief Abstract work unit -- represents a small amount of information * \brief Abstract work unit -- represents a small amount of information
* that encodes part of a larger processing task. * that encodes part of a larger processing task.
*
* Instead of the usual serialization function and unserialization
* constructor, implementations of this class supply \ref load()
* and \ref save() methods that can be used for essentially the
* same purpose, but without requiring any memory allocations.
*
* \sa WorkProcessor
* \ingroup libcore * \ingroup libcore
* \ingroup libpython * \ingroup libpython
*/ */
@ -59,7 +66,14 @@ protected:
/** /**
* \brief Abstract work result -- represents the result of a * \brief Abstract work result -- represents the result of a
* processed <tt>\ref WorkUnit</tt> instance. * processed \ref WorkUnit instance.
*
* Instead of the usual serialization function and unserialization
* constructor, implementations of this class supply \ref load()
* and \ref save() methods that can be used for essentially the
* same purpose, but without requiring any memory allocations.
*
* \sa WorkProcessor
* \ingroup libcore * \ingroup libcore
* \ingroup libpython * \ingroup libpython
*/ */
@ -82,15 +96,22 @@ protected:
/** /**
* \brief Abstract work processor -- takes work units and turns them into * \brief Abstract work processor -- takes work units and turns them into
* <tt>WorkResult</tt> instances. *\ref WorkResult instances.
* *
* When executing a parallel task using Mitsuba's scheduling system, the
* actual work is done in an implementation of this interface.
*
* The class is serializable so that it can be sent over the network if * The class is serializable so that it can be sent over the network if
* required. It is possible to keep local state in <tt>WorkProcessor</tt> * required. It is possible to keep local state in \ref WorkProcessor
* instances (e.g. scratch space for computations), though anything not * instances (e.g. scratch space for computations), though anything not
* returned in the form of <tt>WorkResult</tt>s will eventually be lost. * returned in the form of a \ref WorkResult will eventually be lost.
* Each worker (both locally and remotely) has its own <tt>WorkProcessor</tt>, * Each \ref Worker (both locally and remotely) has its own \ref WorkProcessor,
* and therefore no form of locking is required within instances of this class. * and therefore no form of locking is required within instances of this class.
* *
* \sa WorkUnit
* \sa WorkResult
* \sa ParallelProcess
* \sa Scheduler
* \ingroup libcore * \ingroup libcore
* \ingroup libpython * \ingroup libpython
*/ */
@ -105,10 +126,11 @@ public:
/** /**
* \brief Create a copy of this work processor instance. * \brief Create a copy of this work processor instance.
* *
* Note: Before the cloned work processor is used, its * \remark In practice, before the cloned work processor
* prepare() method will be called - therefore, state * is actually used, its \ref prepare() method will be called.
* that is initialized there does not have to be copied. * Therefore, any state that is initialized in \ref prepeare()
* does not have to be copied.
*/ */
virtual ref<WorkProcessor> clone() const = 0; virtual ref<WorkProcessor> clone() const = 0;
@ -157,14 +179,15 @@ protected:
/** /**
* \brief Abstract parallelizable task. * \brief Abstract parallelizable task.
* *
* Models a larger piece of work that can be split into independent * Instances of this class model a larger piece of work that can be split
* `units' and subsequently farmed out over a cluster or processed locally. * into independent `units' and subsequently farmed out over a cluster or
* After the work units have been completed, the results are pieced back * processed locally. After the work units have been completed, the results
* together to a solution of the original large-scale problem. This class * are pieced back together to a solution of the original large-scale problem.
* implements the core logic running on the central scheduling server, *
* i.e. the part that is responsible for generating work units and * This class implements the core logic running on the central scheduling
* server, i.e. the part that is responsible for generating work units and
* accepting their results. The module that performs the actual computation * accepting their results. The module that performs the actual computation
* is an instance of <tt>WorkProcessor</tt>, which is also specified here. * is an instance of \ref WorkProcessor, which is also specified here.
* Finally, the this class references `resources', which denote * Finally, the this class references `resources', which denote
* chunks of globally shared read-only data required during execution. * chunks of globally shared read-only data required during execution.
* *
@ -188,18 +211,18 @@ public:
/** /**
* \brief Generate a piece of work. * \brief Generate a piece of work.
* *
* Takes a pre-allocated <tt>\ref WorkUnit</tt> instance of * Takes a pre-allocated \ref WorkUnit instance of
* the appropriate sub-type and size (as specified by * the appropriate sub-type and size (as specified by
* <tt>\ref ParallelProcess::getWorkUnitName()</tt>) and * \ref ParallelProcess::getWorkUnitName()) and
* fills it with the appropriate content. Returns ESuccess * fills it with the appropriate content. Returns ESuccess
* on success and EFailure or EPause when no more work is * on success and EFailure or EPause when no more work is
* left -- in that case, the work unit will be ignored and * left -- in that case, the work unit will be ignored and
* the process completed (\ref EFailure) or temporarily * the process completed (\ref EFailure) or temporarily
* paused (\ref EPause). When \ref EPause was used, * paused (\ref EPause). When \ref EPause was used,
* resubmission via <tt>\ref Scheduler::schedule()</tt> will * resubmission via \ref Scheduler::schedule() will
* be required once more work is available. In some cases, it * be required once more work is available. In some cases, it
* is useful to distribute 'nearby' pieces of work to the same * is useful to distribute 'nearby' pieces of work to the same
* processor -- the <tt>worker</tt> parameter can be used to * processor -- the \c worker parameter can be used to
* implement this. * implement this.
* This function should run as quickly as possible, since it * This function should run as quickly as possible, since it
* will be executed while the scheduler mutex is held. A * will be executed while the scheduler mutex is held. A
@ -220,7 +243,7 @@ public:
* in \ref generateWork(). * in \ref generateWork().
* *
* When a work unit is only partially completed due to * When a work unit is only partially completed due to
* a call to <tt>Scheduler::cancel</tt>, the second * a call to \ref Scheduler::cancel(), the second
* parameter is set to true. * parameter is set to true.
* A thrown exception will lead to the termination of * A thrown exception will lead to the termination of
* the parallel process. * the parallel process.
@ -243,7 +266,7 @@ public:
* \brief Query the return status of a process after its * \brief Query the return status of a process after its
* execution has finished. * execution has finished.
* *
* Returns one of <tt>\ref Success, \ref Failure or \ref Unknown</tt> * Returns one of \ref Success, \ref Failure or \ref Unknown.
* (\ref EUnknown means that the process is either still running * (\ref EUnknown means that the process is either still running
* or has never been scheduled). * or has never been scheduled).
*/ */
@ -318,7 +341,7 @@ class Worker;
* *
* Accepts parallelizable jobs and distributes their computational load * Accepts parallelizable jobs and distributes their computational load
* both locally and remotely. This is done by associating different types * both locally and remotely. This is done by associating different types
* of <tt>\ref Worker</tt>s with the scheduler. These try to acquire work * of \ref Worker instances with the scheduler. These try to acquire work
* units from the scheduler, which are then executed on the current machine * units from the scheduler, which are then executed on the current machine
* or sent to remote nodes over a network connection. * or sent to remote nodes over a network connection.
* *
@ -343,7 +366,7 @@ public:
* or canceled prematurely. * or canceled prematurely.
* *
* Returns false if the process does not exist or has already * Returns false if the process does not exist or has already
* finished by the time <tt>\ref wait()</tt> is invoked. * finished by the time \ref wait() is invoked.
*/ */
bool wait(const ParallelProcess *process); bool wait(const ParallelProcess *process);
@ -374,8 +397,8 @@ public:
* \a Manifold means that in comparison to the previous method, a separate * \a Manifold means that in comparison to the previous method, a separate
* instance is provided for every core. An example where this is useful * instance is provided for every core. An example where this is useful
* is to distribute random generator state when performing parallel * is to distribute random generator state when performing parallel
* Monte Carlo simulations. <tt>resources</tt> must be a vector whose * Monte Carlo simulations. \c resources must be a vector whose
* length is equal to <tt>\ref getCoreCount()</tt>. * length is equal to \ref getCoreCount().
*/ */
int registerManifoldResource(std::vector<SerializableObject *> &resources); int registerManifoldResource(std::vector<SerializableObject *> &resources);
@ -427,7 +450,7 @@ public:
* running workers. * running workers.
* *
* Any currently scheduled work units are still completed. * Any currently scheduled work units are still completed.
* Processing can be resumed via <tt>\ref start()</tt>. * Processing can be resumed via \ref start().
*/ */
void pause(); void pause();
@ -469,7 +492,7 @@ public:
int inflight; int inflight;
/* Is the parallel process still generating work */ /* Is the parallel process still generating work */
bool morework; bool morework;
/* Was the process cancelled using <tt>cancel()</tt>?*/ /* Was the process cancelled using \c cancel()?*/
bool cancelled; bool cancelled;
/* Is the process currently in the queue? */ /* Is the process currently in the queue? */
bool active; bool active;

View File

@ -28,7 +28,7 @@ MTS_NAMESPACE_BEGIN
*/ */
class MTS_EXPORT_HW GPUGeometry : public Object { class MTS_EXPORT_HW GPUGeometry : public Object {
public: public:
/// Create an empty program /// Create an empty geometry object
GPUGeometry(const TriMesh *mesh); GPUGeometry(const TriMesh *mesh);
/// Return the name of this geometry object /// Return the name of this geometry object

View File

@ -11,6 +11,7 @@
#include <mitsuba/core/bitmap.h> #include <mitsuba/core/bitmap.h>
#include <mitsuba/core/random.h> #include <mitsuba/core/random.h>
#include <mitsuba/core/aabb.h> #include <mitsuba/core/aabb.h>
#include <mitsuba/core/sched_remote.h>
using namespace mitsuba; using namespace mitsuba;
@ -507,6 +508,81 @@ void export_core() {
.def("getInstance", &PluginManager::getInstance, BP_RETURN_VALUE) .def("getInstance", &PluginManager::getInstance, BP_RETURN_VALUE)
.staticmethod("getInstance"); .staticmethod("getInstance");
BP_CLASS(WorkUnit, Object, bp::no_init)
.def("set", &WorkUnit::set)
.def("load", &WorkUnit::load)
.def("save", &WorkUnit::save);
BP_CLASS(WorkResult, Object, bp::no_init)
.def("load", &WorkResult::load)
.def("save", &WorkResult::save);
BP_CLASS(WorkProcessor, SerializableObject, bp::no_init)
.def("createWorkUnit", &WorkProcessor::createWorkUnit, BP_RETURN_VALUE)
.def("createWorkResult", &WorkProcessor::createWorkResult, BP_RETURN_VALUE)
.def("clone", &WorkProcessor::clone, BP_RETURN_VALUE)
.def("prepare", &WorkProcessor::prepare)
.def("process", &WorkProcessor::process);
BP_CLASS(ParallelProcess, Object, bp::no_init)
.def("generateWork", &ParallelProcess::generateWork)
.def("processResult", &ParallelProcess::processResult)
.def("handleCancellation", &ParallelProcess::handleCancellation)
.def("getReturnStatus", &ParallelProcess::getReturnStatus)
.def("createWorkProcessor", &ParallelProcess::createWorkProcessor)
.def("bindResource", &ParallelProcess::bindResource)
.def("isLocal", &ParallelProcess::isLocal)
.def("getLogLevel", &ParallelProcess::getLogLevel)
.def("getRequiredPlugins", &ParallelProcess::getRequiredPlugins, BP_RETURN_VALUE);
BP_SETSCOPE(ParallelProcess_class);
bp::enum_<ParallelProcess::EStatus>("EStatus")
.value("EUnknown", ParallelProcess::EUnknown)
.value("EPause", ParallelProcess::EPause)
.value("ESuccess", ParallelProcess::ESuccess)
.value("EFailure", ParallelProcess::EFailure)
.export_values();
BP_SETSCOPE(coreModule);
BP_CLASS(Worker, Thread, bp::no_init)
.def("getCoreCount", &Worker::getCoreCount)
.def("isRemoteWorker", &Worker::isRemoteWorker);
BP_CLASS(LocalWorker, Worker, bp::init<const std::string>())
.def(bp::init<const std::string, Thread::EThreadPriority>());
BP_CLASS(RemoteWorker, Worker, (bp::init<const std::string, Stream *>()))
.def("getNodeName", &RemoteWorker::getNodeName, BP_RETURN_VALUE);
bp::class_<SerializableObjectVector>("SerializableObjectVector")
.def(bp::vector_indexing_suite<SerializableObjectVector>());
bool (Scheduler::*scheduler_cancel)(ParallelProcess *)= &Scheduler::cancel;
BP_CLASS(Scheduler, Object, bp::no_init)
.def("schedule", &Scheduler::schedule)
.def("wait", &Scheduler::wait)
.def("cancel", scheduler_cancel)
.def("registerResource", &Scheduler::registerResource)
.def("registerManifoldResource", &Scheduler::registerManifoldResource)
.def("retainResource", &Scheduler::retainResource)
.def("unregisterResource", &Scheduler::unregisterResource)
.def("getResourceID", &Scheduler::getResourceID)
.def("registerWorker", &Scheduler::registerWorker)
.def("unregisterWorker", &Scheduler::unregisterWorker)
.def("getWorkerCount", &Scheduler::getWorkerCount)
.def("getLocalWorkerCount", &Scheduler::getLocalWorkerCount)
.def("getWorker", &Scheduler::getWorker, BP_RETURN_VALUE)
.def("start", &Scheduler::start)
.def("pause", &Scheduler::pause)
.def("stop", &Scheduler::stop)
.def("getCoreCount", &Scheduler::getCoreCount)
.def("hasLocalWorkers", &Scheduler::hasLocalWorkers)
.def("hasRemoteWorkers", &Scheduler::hasRemoteWorkers)
.def("getInstance", &Scheduler::getInstance, BP_RETURN_VALUE)
.def("isRunning", &Scheduler::isRunning)
.def("isBusy", &Scheduler::isBusy)
.staticmethod("getInstance");
BP_STRUCT(Spectrum, bp::init<>()) BP_STRUCT(Spectrum, bp::init<>())
.def("__init__", bp::make_constructor(spectrum_array_constructor)) .def("__init__", bp::make_constructor(spectrum_array_constructor))
.def(bp::init<Float>()) .def(bp::init<Float>())

View File

@ -143,7 +143,12 @@ public:
} }
}; };
namespace mitsuba {
class SerializableObject;
};
typedef std::vector<std::string> StringVector; typedef std::vector<std::string> StringVector;
typedef std::vector<mitsuba::SerializableObject *> SerializableObjectVector;
typedef std::map<std::string, std::string> StringMap; typedef std::map<std::string, std::string> StringMap;
#endif /* __MTSPY_H */ #endif /* __MTSPY_H */

View File

@ -50,8 +50,8 @@ if hasQt:
qtEnv.Prepend(LIBS=env['COLLADALIB']) qtEnv.Prepend(LIBS=env['COLLADALIB'])
if sys.platform == 'darwin': if sys.platform == 'darwin':
qtEnv_osx = qtEnv.Clone()
mainEnv_osx = mainEnv.Clone() mainEnv_osx = mainEnv.Clone()
qtEnv_osx = qtEnv.Clone()
mainEnv_osx.ConfigureForObjectiveCPP() mainEnv_osx.ConfigureForObjectiveCPP()
qtEnv_osx.ConfigureForObjectiveCPP() qtEnv_osx.ConfigureForObjectiveCPP()
mainEnv_osx.Program('symlinks_install', ['symlinks_install.c']) mainEnv_osx.Program('symlinks_install', ['symlinks_install.c'])