-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathAMRCellSampler.h
91 lines (71 loc) · 2.74 KB
/
AMRCellSampler.h
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
// ======================================================================== //
// Copyright 2022-2022 Stefan Zellmann //
// //
// Licensed under the Apache License, Version 2.0 (the "License"); //
// you may not use this file except in compliance with the License. //
// You may obtain a copy of the License at //
// //
// http://www.apache.org/licenses/LICENSE-2.0 //
// //
// Unless required by applicable law or agreed to in writing, software //
// distributed under the License is distributed on an "AS IS" BASIS, //
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. //
// See the License for the specific language governing permissions and //
// limitations under the License. //
// ======================================================================== //
#pragma once
#include "model/AMRCellModel.h"
#include "Sampler.h"
namespace exa {
struct AMRCellGeom {
AMRCell *amrCellBuffer;
float *scalarBuffer;
};
class AMRCellSampler : public Sampler {
public:
typedef std::shared_ptr<AMRCellSampler> SP;
// Launch params associated with sampler
struct LP {
OptixTraversableHandle sampleBVH;
#ifdef EXA_STITCH_MIRROR_EXAJET
affine3f mirrorInvTransform;
#endif
};
bool build(OWLContext owl, Model::SP model);
void computeMaxOpacities(OWLContext owl, OWLBuffer colorMap, range1f xfRange);
std::vector<OWLVarDecl> getLPVariables();
void setLPs(OWLParams lp);
std::string className() { return "AMRCellSampler"; }
AMRCellModel::SP model = nullptr;
private:
// owl
OWLModule module;
OWLGeomType geomType;
OWLGroup blas;
OWLGroup tlas;
public: // for grid
OWLBuffer cellBuffer;
OWLBuffer scalarBuffer;
private:
};
#ifdef __CUDA_ARCH__
inline __device__
Sample sample(const AMRCellSampler::LP &lp,
const SpatialDomain &domain,
const vec3f pos)
{
BasisPRD prd{0.f,0.f};
SamplingRay ray(pos,vec3f(1.f),0.f,0.f);
owl::traceRay(lp.sampleBVH,ray,prd,
OPTIX_RAY_FLAG_DISABLE_ANYHIT);
int primID = -1;
float value = 0.f;
if (prd.sumWeights > 0.f) {
primID = 0; // non-negative dummy value
value = prd.sumWeightedValues/prd.sumWeights;
}
return {primID,-1/*TODO:cellID*/,value};
}
#endif
} // ::exa
// vim: sw=2:expandtab:softtabstop=2:ts=2:cino=\:0g0t0