ftp.nice.ch/pub/next/unix/graphics/rayshade.4.0.s.tar.gz#/rayshade.4.0/rayshade/stats.c

This is stats.c in view mode; [Download] [Up]

/*
 * stats.c
 *
 * Copyright (C) 1989, 1991, Craig E. Kolb
 * All rights reserved.
 *
 * This software may be freely copied, modified, and redistributed
 * provided that this copyright notice is preserved on all copies.
 *
 * You may not distribute this software, in whole or in part, as part of
 * any commercial product without the express consent of the authors.
 *
 * There is no warranty or other guarantee of fitness of this software
 * for any purpose.  It is provided solely "as is".
 *
 * $Id$
 *
 * $Log$
 */
#include <ctype.h>
#include "rayshade.h"
#include "options.h"
#include "stats.h"

RSStats Stats;			/* Statistical information */
Object *ObjectRep = NULL;	/* Linked list of object representatives */

static void PrintObjectStats();

void
StatsPrint()
{
	extern void PrintMemoryStats();
	unsigned long TotalRays;

#ifndef LINDA
	get_cpu_time(&Stats.Utime, &Stats.Stime);
#endif
	ShadowStats(&Stats.ShadowRays, &Stats.ShadowHits,
		    &Stats.CacheHits, &Stats.CacheMisses);
	IntersectStats(&Stats.BVTests);
	
	TotalRays = Stats.EyeRays + Stats.ShadowRays + Stats.ReflectRays
			 + Stats.RefractRays;
	Stats.ShadowHits += Stats.CacheHits;
	Stats.HitRays += Stats.ShadowHits;
#ifdef LINDA
	fprintf(Stats.fstats,"Workers:\t\t\t%d\n",Options.workers);
#endif
	fprintf(Stats.fstats,"Eye rays:\t\t\t%lu\n", Stats.EyeRays);
	fprintf(Stats.fstats,"Shadow rays:\t\t\t%lu\n",Stats.ShadowRays);
	fprintf(Stats.fstats,"Reflected rays:\t\t\t%lu\n",Stats.ReflectRays);
	fprintf(Stats.fstats,"Refracted rays:\t\t\t%lu\n",Stats.RefractRays);
	fprintf(Stats.fstats,"Total rays:\t\t\t%lu\n", TotalRays);
	if (TotalRays != 0)
		fprintf(Stats.fstats,"Intersecting rays:\t\t%lu (%3.3f%%)\n",
			Stats.HitRays,
			100. * (float)Stats.HitRays / (float)TotalRays);
	if (Stats.ShadowRays != 0) {
		if (Options.cache)
			fprintf(Stats.fstats,
				"Shadow cache hits:\t\t%lu (%lu misses)\n",
				Stats.CacheHits, Stats.CacheMisses);
		fprintf(Stats.fstats,"Total shadow hits:\t\t%lu (%3.3f%%)\n",
			Stats.ShadowHits, 100.*(float)Stats.ShadowHits /
			(float)Stats.ShadowRays);
	}
	if (!Options.jittered)
		fprintf(Stats.fstats,"Supersampled pixels:\t\t%lu\n",
			Stats.SuperSampled);
	fprintf(Stats.fstats,"B.V. intersection tests:\t%lu\n",Stats.BVTests);
	PrintObjectStats();
#ifdef LINDA
	fprintf(Stats.fstats,"Average CPU time/processor:\t");
#else
	fprintf(Stats.fstats,"Total CPU time (sec):\t\t");
#endif
	fprintf(Stats.fstats,"%2.2f (%2.2fu + %2.2fs)\n",
		Stats.Utime+Stats.Stime, Stats.Utime, Stats.Stime);
	if (TotalRays != 0.)
		fprintf(Stats.fstats,"Seconds / ray:\t\t\t%4.4f\n",
			(Stats.Utime + Stats.Stime) / (Float)TotalRays);
	if (Stats.HitRays != 0.)
		fprintf(Stats.fstats,"Seconds / intersecting ray:\t%4.4f\n",
			(Stats.Utime + Stats.Stime)/(Float)Stats.HitRays);
	PrintMemoryStats(Stats.fstats);
}

static void
PrintObjectStats()
{
	Object *otmp;
	unsigned long tests, hits, totaltests, totalhits;
	char *name;
	extern void ObjectStats();

	totaltests = totalhits = 0;

	for (otmp = ObjectRep; otmp; otmp = otmp->next) {
		ObjectStats(otmp, &tests, &hits);
		if (tests <= 0)
			continue;
		name = ObjectName(otmp);
		fprintf(Stats.fstats,
			"%c%s intersection tests:\t%lu (%lu hit, %f%%)\n",
				toupper((int)name[0]), &name[1], tests, hits,
				100.*(float)hits/(float)tests);
		if (!IsAggregate(otmp)) {
			totaltests += tests;
			totalhits += hits;
		}
	}
	fprintf(Stats.fstats,"Total prim. intersection tests:\t%lu",
		totaltests);
	if (totaltests == 0)
		fprintf(Stats.fstats,"\n");
	else
		fprintf(Stats.fstats," (%lu hit, %f%%)\n", totalhits,
			100.*(float)totalhits/(float)totaltests);
}

void
StatsAddRep(obj)
Object *obj;
{
	Object *otmp;

	for (otmp = ObjectRep; otmp; otmp = otmp->next) {
		if (otmp->methods->stats == obj->methods->stats)
			return;
	}

	/*
	 * Stats method didn't match anything found so far.  Add
	 * a copy of obj to head of ObjectRep list.
	 */
	otmp = ObjectCopy(obj);
	otmp->next = ObjectRep;
	ObjectRep = otmp;
}

These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.