Swarm-NG
1.1
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
Swarm-NG
Overview
Text Formats
Getting Started with Swarm-NG
Advanced Options for Building Swarm
Configuration Files
Release notes
swarm-query.py command-line interface
Swarm command-line interface
How to Test Swarm
Using Swarm
Examining records from the log file.
Plotting results from a log file
Tutorial on using the Ensemble data structure.
Advanced tutorial for using GPU integrators
Tutorial for implementing an Integrator
Tutorial for making a monitor (stopper/logger)
Tutorial for Making a Propagator
Beginner Python Tutorial
Testing for ejection of planets
Tutorial for generating ensembles
Advanced Python Integration Tutorial
Resume an integration
Extracting statistical information from data files
Beginner tutorial for using the API
Todo List
Deprecated List
Modules
Namespaces
Classes
Files
File List
swarm
py
src
integrators
monitors
plugins
propagators
python
swarm
gpu
bppt.hpp
device_settings.cpp
device_settings.hpp
generic_gpu_bppt_integrator.hpp
gravitation_acc.hpp
gravitation_accjerk.hpp
gravitation_common.hpp
gravitation_gr_acc.hpp
gravitation_largen.hpp
gravitation_mediumn.hpp
helpers.hpp
pair_calculation.hpp
utilities.cu
utilities.hpp
log
peyton
types
bdb_query.cpp
bdb_query.hpp
common.hpp
ensemble_alloc.hpp
integrator.cpp
integrator.hpp
kepler.h
plugin.cpp
plugin.hpp
query.cpp
query.hpp
runtime_error.hpp
snapshot.cpp
snapshot.hpp
stopwatch.h
swarm.cpp
swarm.h
swarmplugin.h
utils.cpp
utils.hpp
tutorials
utils
File Members
gravitation_common.hpp
Go to the documentation of this file.
1
/*************************************************************************
2
* Copyright (C) 2010 by Saleh Dindar and the Swarm-NG Development Team *
3
* *
4
* This program is free software; you can redistribute it and/or modify *
5
* it under the terms of the GNU General Public License as published by *
6
* the Free Software Foundation; either version 3 of the License. *
7
* *
8
* This program is distributed in the hope that it will be useful, *
9
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
10
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
11
* GNU General Public License for more details. *
12
* *
13
* You should have received a copy of the GNU General Public License *
14
* along with this program; if not, write to the *
15
* Free Software Foundation, Inc., *
16
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
17
************************************************************************/
18
24
#pragma once
25
26
// For using CoalescedStructArray in the gravitation implementations
27
#include "../types/coalescedstructarray.hpp"
28
29
#include "
bppt.hpp
"
30
31
namespace
swarm {
namespace
gpu {
namespace
bppt {
32
43
template
<
int
W>
44
struct
GravitationAccScalars
{
45
static
const
int
CHUNK_SIZE = W;
46
typedef
double
scalar_t;
47
48
double
_acc[CHUNK_SIZE];
49
50
// Accessors
51
GENERIC
double
& acc() {
return
_acc[0]; }
52
};
53
54
65
template
<
int
W>
66
struct
GravitationAccJerkScalars
{
67
static
const
int
CHUNK_SIZE = W;
68
typedef
double
scalar_t;
69
70
double
_acc[CHUNK_SIZE];
71
double
_jerk[CHUNK_SIZE];
72
73
// Accessors
74
GENERIC
double
& acc() {
return
_acc[0]; }
75
GENERIC
double
& jerk() {
return
_jerk[0]; }
76
};
77
78
82
GENERIC
double
inner_product
(
const
double
a[3],
const
double
b[3]){
83
return
a[0]*b[0]+a[1]*b[1]+a[2]*b[2];
84
}
85
86
#include "pair_calculation.hpp"
87
88
89
} } }
// end of namespace bppt :: gpu :: swarm
90
swarm
src
swarm
gpu
gravitation_common.hpp
Generated on Sun Jul 21 2013 11:11:54 for Swarm-NG by
1.8.4