File: Medium.ih

package info (click to toggle)
ospray 3.2.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 10,048 kB
  • sloc: cpp: 80,569; ansic: 951; sh: 805; makefile: 170; python: 69
file content (42 lines) | stat: -rw-r--r-- 833 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// Copyright 2009 Intel Corporation
// SPDX-License-Identifier: Apache-2.0

#pragma once

#include "rkcommon/math/vec.ih"

#include "MediumShared.h"

OSPRAY_BEGIN_ISPC_NAMESPACE

inline Medium make_Medium(const vec3f attenuation, const float ior)
{
  Medium m;
  m.attenuation = attenuation;
  m.ior = ior;
  return m;
}

inline Medium make_Medium_vacuum()
{
  return make_Medium(make_vec3f(0.0f), 1.0f);
}

inline bool eq(const Medium &a, const Medium &b)
{
  return (a.ior == b.ior) & eq(a.attenuation, b.attenuation);
}

#ifdef ISPC
inline bool eq(const Medium &a, const uniform Medium &b)
{
  return (a.ior == b.ior) & eq(a.attenuation, b.attenuation);
}

inline uniform bool eq(const uniform Medium &a, const uniform Medium &b)
{
  return (a.ior == b.ior) & eq(a.attenuation, b.attenuation);
}
#endif

OSPRAY_END_ISPC_NAMESPACE