include/common.h
author Radek Brich <radek.brich@devl.cz>
Sun, 27 Apr 2008 19:56:23 +0200 (2008-04-27)
branchpyrit
changeset 86 ce6abe0aeeae
parent 83 e3a2a5b26abb
child 91 9d66d323c354
permissions -rw-r--r--
BBox - RayPacket intersection clean up
/*
 * common.h: common functions and definitions
 *
 * This file is part of Pyrit Ray Tracer.
 *
 * Copyright 2006, 2007, 2008  Radek Brich
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */

#ifndef COMMON_H
#define COMMON_H

#include <stdio.h>
#include <stdarg.h>
#include <float.h>
#include <pthread.h>
#include <string>

// SSE intrinsics
#include <xmmintrin.h>

using namespace std;

#ifdef PYRIT_DOUBLE
# define Float double
# define Eps DBL_EPSILON
# define Inf DBL_MAX
#else
# define Float float
# define Eps 1e-6
# define Inf FLT_MAX
#endif

const __m128 mZero = _mm_set_ps1(0.);
const __m128 mOne = _mm_set_ps1(1.);
const __m128 mEps = _mm_set_ps1(Eps);
const __m128 mMEps = _mm_set_ps1(-Eps);
const __m128 mInf = _mm_set_ps1(Inf);
const __m128 mAllSet = _mm_cmplt_ps(mZero, mOne);

/* verbosity level:
0: only errors (E)
1: major status messages (*)
2: minor status, progress (-)
3: debug messages (D)
4: thread debug
default = 2
*/
extern int pyrit_verbosity;

inline void dbgmsg(const int vlevel, const char *format, ...)
{
	static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
	if (pyrit_verbosity >= vlevel)
	{
		if (pyrit_verbosity >= 4)
			pthread_mutex_lock(&mutex);

		va_list ap;
		va_start(ap, format);
		vprintf(format, ap);
		va_end(ap);
		fflush(stdout);

		if (pyrit_verbosity >= 4)
			pthread_mutex_unlock(&mutex);
	}
}

template<typename Type> const Type &min3(const Type &a, const Type &b, const Type &c)
{
	if (a <= b)
	{
		if (a <= c)
			return a;
		else
			return c;
	}
	else
	{
		if (b <= c)
			return b;
		else
			return c;
	}
}

template<typename Type> const Type &max3(const Type &a, const Type &b, const Type &c)
{
	if (a >= b)
	{
		if (a >= c)
			return a;
		else
			return c;
	}
	else
	{
		if (b >= c)
			return b;
		else
			return c;
	}
}

inline void trim(string& s)
{
	const char *ws = " \n";
	string::size_type pos = s.find_last_not_of(ws);
	if (pos != string::npos)
	{
		s.erase(pos + 1);
		pos = s.find_first_not_of(ws);
		if (pos != string::npos)
			s.erase(0, pos);
	}
	else
		s.erase(s.begin(), s.end());
}

#endif