src/raytracer.cc
branchpyrit
changeset 51 89fec8668768
parent 50 14a727b70d07
child 52 a6413a3d741d
--- a/src/raytracer.cc	Fri Mar 28 17:13:21 2008 +0100
+++ b/src/raytracer.cc	Fri Mar 28 21:47:32 2008 +0100
@@ -404,43 +404,33 @@
 	Ray ray;
 	for (;;)
 	{
-		cout<<"#worker "<<pthread_self()<<" locking queue"<<endl;
 		pthread_mutex_lock(&rt->sample_queue_mutex);
 		pthread_cond_signal(&rt->worker_ready_cond);
 
-		// if queue is empty, wait for samples
 		while (rt->sample_queue.empty()) {
 			if (rt->sample_queue_end)
 			{
-				cout<<"#worker "<<pthread_self()<<" end of queue, unlocking queue and exiting..."<<endl;
 				pthread_mutex_unlock(&rt->sample_queue_mutex);
 				pthread_exit(NULL);
 			}
-			cout<<"#worker "<<pthread_self()<<" waiting for cond"<<endl;
 			pthread_cond_wait(&rt->sample_queue_cond, &rt->sample_queue_mutex);
 		}
 
-
 		sample = rt->sample_queue.front();
 		rt->sample_queue.pop();
-		cout<<"#worker "<<pthread_self()<<" unlocking queue"<<endl;
+
 		pthread_mutex_unlock(&rt->sample_queue_mutex);
 
 		// do the work
-		cout<<"#worker "<<pthread_self()<<" locking sampler (camera)"<<endl;
 		pthread_mutex_lock(&rt->sampler_mutex);
 		ray = rt->camera->makeRay(sample);
-		cout<<"#worker "<<pthread_self()<<" unlocking sampler (camera)"<<endl;
 		pthread_mutex_unlock(&rt->sampler_mutex);
 
-		cout<<"#worker "<<pthread_self()<<" ray tracing..."<<endl;
 		col = rt->raytrace(ray, 0, NULL);
-		
+
 		// save the result
-		cout<<"#worker "<<pthread_self()<<" locking sampler"<<endl;
 		pthread_mutex_lock(&rt->sampler_mutex);
 		rt->sampler->saveSample(sample, col);
-		cout<<"#worker "<<pthread_self()<<" unlocking sampler"<<endl;
 		pthread_mutex_unlock(&rt->sampler_mutex);
 
 		delete sample;
@@ -455,7 +445,7 @@
 	sample_queue_end = false;
 
 	// create workers
-	dbgmsg(1, "* using %d threads\n", num_threads);
+	dbgmsg(1, "* running %d threads\n", num_threads);
 	pthread_t threads[num_threads];
 	for (int t = 0; t < num_threads; t++)
 	{
@@ -466,70 +456,62 @@
 		}
 	}
 
+	dbgmsg(1, "* raytracing...\n");
+	dbgmsg(2, "-  0%% done");
+
 	sampler->init();
-	int sampnum = 0;
-	cout<<"locking sampler"<<endl;
+	int sampnum = 0, sampdone;
+	Sample *sample;
+
 	pthread_mutex_lock(&sampler_mutex);
 	while ( (sampnum = sampler->initSampleSet()) > 0 )
 	{
-		Sample *sample;
+		sampdone = 0;
 		while ( (sample = sampler->nextSample()) != NULL )
 		{
-			cout<<"unlocking sampler and locking queue"<<endl;
 			pthread_mutex_unlock(&sampler_mutex);
 			pthread_mutex_lock(&sample_queue_mutex);
 			sample_queue.push(sample);
 
+			// wait for workers if there is enough samples ready on queue
 			if (sample_queue.size() > 1000)
 			{
-			    while (sample_queue.size() > 100)
-			    {
-				pthread_cond_signal(&sample_queue_cond);
-				pthread_cond_wait(&worker_ready_cond, &sample_queue_mutex);
-			    }
+				while (sample_queue.size() > 100)
+				{
+					pthread_cond_signal(&sample_queue_cond);
+					pthread_cond_wait(&worker_ready_cond, &sample_queue_mutex);
+				}
 			}
 
-			cout<<"sending signal and unlocking queue"<<endl;
+			sampdone++;
+			if ((sampdone & 0xfff) == 0)
+				dbgmsg(2, "\b\b\b\b\b\b\b\b%2d%% done", (sampdone - sample_queue.size())*100/sampnum);
+
 			pthread_cond_signal(&sample_queue_cond);
 			pthread_mutex_unlock(&sample_queue_mutex);
-
-			sampnum--;
-			if ((sampnum % 1000) == 0)
-				dbgmsg(2, "\b\b\b\b\b\b\b\b%8d", sampnum);
-
-
-			cout<<"locking sampler"<<endl;
 			pthread_mutex_lock(&sampler_mutex);
 		}
-		dbgmsg(2, "\n");
+		dbgmsg(2, "\b\b\b\b\b\b\b\b100%% done\n");
 	}
-	cout<<"unlocking sampler"<<endl;
 	pthread_mutex_unlock(&sampler_mutex);
 
 	// wait for workers
 	dbgmsg(2, "- waiting for threads to finish\n");
 
-	cout<<"locking queue"<<endl;
 	pthread_mutex_lock(&sample_queue_mutex);
 	sample_queue_end = true;
 	while (!sample_queue.empty())
 	{
-		cout<<"broadcasting signal and unlocking queue"<<endl;
 		pthread_cond_broadcast(&sample_queue_cond);
 		pthread_mutex_unlock(&sample_queue_mutex);
-		cout<<"locking queue"<<endl;
 		pthread_mutex_lock(&sample_queue_mutex);
 	}
-	cout<<"broadcasting signal and unlocking queue"<<endl;
 	pthread_cond_broadcast(&sample_queue_cond);
 	pthread_mutex_unlock(&sample_queue_mutex);
 
-	cout<<"joining threads"<<endl;
 	for (int t = 0; t < num_threads; t++)
 		pthread_join(threads[t], NULL);
 
-	cout<<"done!"<<endl;
-
 #if 0
 
 	RenderrowData *d;