summaryrefslogtreecommitdiff
path: root/lib/core/c++/particle/porosity.hpp
blob: 39d96529113a1ca181b024807b1f851ea7c3a6c5 (plain)
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
#pragma once

#include "particle.hpp"
#include "../math/n_closest.hpp"

namespace kel {
namespace lbm {
template<typename T, uint64_t D, typename Coll>
class particle_porosity {
public:

	
	saw::data<sch::Scalar<T>> calculate(const saw::data<sch::ParticleGroup<T,D,Coll>>& part_group, uint64_t p_i, const saw::data<sch::Vector<T,D>>& lbm_pos){
		auto& mask = part_group.template get<"mask">();

		auto& particles = part_group.template get<"particles">();
		auto& part_i = particles.at({p_i});

		auto& part_i_rb = part_i.template get<"rigid_body">();
		auto& pirb = part_i_rb.template get<"position">();

		auto dist = lbm_pos - pirb;

		// index 0 is at 

		return {};
	}
};


template<typename T, uint64_t D, typename saw::native_data_type<T>::type radius, typename saw::native_data_type<T>::type eps>
class particle_porosity<T, D, coll::ParticleCollisionSpheroid<T,radius, eps>> final {
public:
	saw::data<sch::Scalar<T>> calculate(const saw::data<sch::ParticleGroup<T,D,sch::ParticleCollisionSpheroid<T,radius,eps> > >& part_group, uint64_t i, const saw::data<sch::Vector<T,D>>& lbm_pos){
		saw::data<sch::Scalar<T>> por;
		por.at({});

		auto& parts = part_group.template get<"particles">();
		auto& pi = parts.at({i});
		auto& pi_rb = pi.template get<"rigid_body">();

		auto& pi_rb_pos = pi_rb.template get<"position">();

		// Basically the queried position minus the center of the particle
		auto dist = lbm_pos - pi_rb_pos;

		saw::data<sch::Scalar<T>> dist_len;
		for(uint64_t i{0u}; i < D; ++i){
			auto& d_i = dist.at({{i}});
			dist_len.at({}) = d_i * d_i;
		}
		dist_len.at({}).set(std::sqrt(dist_len.at({}).get());

		saw::data<sch::Scalar<T>> rad_d{radius};
		saw::data<sch::Scalar<T>> eps_half{eps *0.5};
		
		saw::data<sch::Scalar<T>> rad_d_eps_p = rad_d + eps_half;
		saw::data<sch::Scalar<T>> rad_d_eps_n = rad_d - eps_half;

		// saw::data<sch::Scalar<T>> rad_d_eps_p_2 = rad_d_eps_p * rad_d_eps_p;
		// saw::data<sch::Scalar<T>> rad_d_eps_n_2 = rad_d_eps_n * rad_d_eps_n;
		// saw::data<sch::Scalar<T>> rad_2;
		// rad_2 = rad_d * rad_d;

		saw::data<sch::Scalar<T>> inside;
		if(dist_len.at({}) <= rad_d_eps_n.at({})){
			inside.at({}).set(1);
			return inside;
		}
		if(dist_len.at({}) > rad_d_eps_p.at({})){
			inside.at({}).set(0);
			return inside
		}

		/*
		 * cos^2 ( ||x-X(t)||_2 - (R-eps/2) )
		 */
		{
			typename saw::native_data_type<T>::type inner = (std::pi / ( 2.0 * eps )) * (dist_len - rad_d_eps_n).at({}).get();
			auto cos_inner = std::cos(inner);
			auto cos_i_2 = cos_inner * cos_inner;
			inside.at({}).set(cos_i_2);
		}
		return inside;
	}
};

}
}