Arcane  v3.15.0.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
IRandomNumberGenerator.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2022 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7/*---------------------------------------------------------------------------*/
8/* IRandomNumberGenerator.h (C) 2000-2022 */
9/* */
10/* Interface pour générateur de nombres aléatoires. */
11/*---------------------------------------------------------------------------*/
12/*---------------------------------------------------------------------------*/
13
14#ifndef ARCANE_IRANDOMNUMBERGENERATOR_H
15#define ARCANE_IRANDOMNUMBERGENERATOR_H
16
17/*---------------------------------------------------------------------------*/
18/*---------------------------------------------------------------------------*/
19
20#include "arcane/utils/Array.h"
22
23/*---------------------------------------------------------------------------*/
24/*---------------------------------------------------------------------------*/
25
26namespace Arcane
27{
28
29/*---------------------------------------------------------------------------*/
30/*---------------------------------------------------------------------------*/
31
32/**
33 * @brief Classe permettant de manipuler facilement une graine.
34 *
35 * Une graine est représentée par un tableau de Byte.
36 * Cette classe utilise un ArrayView de ce tableau.
37 *
38 * Cette classe permet de définir une valeur dans le tableau et
39 * de récupérer cette valeur (autres autres choses).
40 *
41 * Cette classe ne stocke pas le tableau mais uniquement
42 * un ArrayView de ce tableau.
43 *
44 */
45class ARCANE_CORE_EXPORT RNGSeedHelper
46{
47 public:
48
49 /**
50 * @brief Constructeur de la classe.
51 *
52 * @param av Un ArrayView de tableau représentant une graine.
53 */
55 {
56 m_seed = av;
57 }
58
59 /**
60 * @brief Constructeur de classe.
61 *
62 * @tparam T Un type de base.
63 * @param var Un pointeur vers la graine
64 * (attention, ne fait pas une copie de la valeur !)
65 */
66 template <class T>
68 {
69 m_seed = ByteArrayView(sizeof(T), (Byte*)var);
70 }
71
72 virtual ~RNGSeedHelper() = default;
73
74 public:
75
76 /**
77 * @brief Méthode permettant de définir une valeur dans la graine.
78 *
79 * @tparam T Le type de valeur.
80 * @param value_in La futur valeur de la graine.
81 * @return true Si la valeur a pu être attribuée.
82 * @return false Si la valeur n'a pas pu être attribuée.
83 */
84 template <class T>
85 bool setValue(T value_in)
86 {
87 if (m_seed.empty()) {
88 return false;
89 }
90 memcpy(m_seed.data(), &value_in, std::min(m_seed.size(), (Integer)sizeof(T)));
91 for (Integer i = sizeof(T); i < m_seed.size(); i++) {
92 m_seed[i] = 0x00;
93 }
94 return true;
95 }
96
97 /**
98 * @brief Méthode permettant de récupérer la valeur de la graine.
99 *
100 * @tparam T Le type de la graine.
101 * @param value_out [OUT] La valeur de la graine.
102 * @param without_size_check Si le rognage de la valeur est autorisé.
103 * @return true Si la valeur a pu être récupérée.
104 * @return false Si la valeur n'a pas pu être récupérée ou si le tableau
105 * a une taille nulle.
106 */
107 template <class T>
108 bool value(T& value_out, bool without_size_check = true) const
109 {
110 if (m_seed.empty() || (!without_size_check && sizeof(T) != m_seed.size())) {
111 return false;
112 }
113 value_out = 0;
114 memcpy(&value_out, m_seed.data(), std::min(m_seed.size(), (Integer)sizeof(T)));
115 return true;
116 }
117
118 /**
119 * @brief Méthode permettant de récupérer la valeur de la graine.
120 *
121 * @tparam T Le type de la graine.
122 * @param value_out [OUT] La valeur de la graine.
123 * @param without_size_check Si le rognage de la valeur est autorisé.
124 * @return true Si la valeur a pu être récupérée.
125 * @return false Si la valeur n'a pas pu être récupérée ou si le tableau
126 * a une taille nulle.
127 */
128 template <class T>
129 bool value(T* value_out, bool without_size_check = true) const
130 {
131 if (m_seed.empty() || (sizeof(T) != m_seed.size() && !without_size_check)) {
132 return false;
133 }
134 *value_out = 0;
135 memcpy(value_out, m_seed.data(), std::min(m_seed.size(), (Integer)sizeof(T)));
136 return true;
137 }
138
139 /**
140 * @brief Méthode permettant de récupérer la taille de la graine.
141 *
142 * @return Integer La taille de la graine (en octet).
143 */
144 Integer sizeOfSeed() const
145 {
146 return m_seed.size();
147 }
148
149 /**
150 * @brief Méthode permettant de récupérer une vue constante.
151 *
152 * @return ByteConstArrayView La vue.
153 */
155 {
156 return m_seed.constView();
157 }
158
159 /**
160 * @brief Méthode permettant de récupérer une vue.
161 *
162 * @return ByteArrayView La vue.
163 */
165 {
166 return m_seed;
167 }
168
169 /**
170 * @brief Opérateur de copie depuis une valeur de graine.
171 *
172 * @tparam T Le type de la graine.
173 * @param value La valeur de la graine.
174 * @return RNGSeedHelper& La graine destination.
175 */
176 template <class T>
178 {
179 setValue(new_value);
180 return *this;
181 }
182
183 /**
184 * @brief Méthode permettant de récupérer une copie du
185 * tableau de Byte.
186 *
187 * @return ByteUniqueArray La copie du tableau de Byte.
188 */
190 {
191 return ByteUniqueArray(m_seed);
192 }
193
194 protected:
195 ByteArrayView m_seed;
196};
197
198/**
199 * @ingroup StandardService
200 * @brief Interface pour un générateur de nombre aléatoire.
201 */
202class ARCANE_CORE_EXPORT IRandomNumberGenerator
203{
204 public:
205 virtual ~IRandomNumberGenerator() = default;
206
207 public:
208 /**
209 * @brief Méthode permettant d'initialiser le service.
210 *
211 * Avec la graine en option (ou la graine par défaut si l'on est
212 * en mode singleton).
213 *
214 * @return true Si l'initialisation a bien eu lieu.
215 * @return false Si l'initialisation n'a pas eu lieu.
216 */
217 virtual bool initSeed() = 0;
218
219 /**
220 * @brief Méthode permettant d'initialiser le service.
221 *
222 * Si la graine n'a pas la bonne taille, false sera retourné.
223 *
224 * @param seed La graine d'origine.
225 * @return true Si l'initialisation a bien eu lieu.
226 * @return false Si l'initialisation n'a pas eu lieu.
227 */
228 virtual bool initSeed(ByteArrayView seed) = 0;
229
230 /**
231 * @brief Méthode permettant de récupérer une vue constante sur la
232 * graine actuelle.
233 *
234 * @return ByteArrayView La graine.
235 */
237
238 /**
239 * @brief Méthode permettant de récupérer une graine vide de bonne taille.
240 *
241 * @return ByteUniqueArray La graine vide.
242 */
244
245 /**
246 * @brief Méthode permettant de connaitre la taille de seed nécessaire
247 * pour l'implémentation.
248 *
249 * @return Integer La taille de seed nécessaire (en octet).
250 */
251 virtual Integer neededSizeOfSeed() = 0;
252
253 /**
254 * @brief Méthode permettant de savoir si les sauts sont permis sur le
255 * générateur de graines.
256 *
257 * @return true Si oui.
258 * @return false Si non.
259 */
260 virtual bool isLeapSeedSupported() = 0;
261
262 /**
263 * @brief Méthode permettant de générer une graine "enfant" à partir d'une
264 * graine "parent".
265 *
266 * @param leap Le saut à effectuer (0 = la graine n+1+0 / 1 = la graine n+1+1).
267 * @return ByteUniqueArray La nouvelle graine généré à partir de la graine en mémoire.
268 */
269 virtual ByteUniqueArray generateRandomSeed(Integer leap = 0) = 0;
270
271 /**
272 * @brief Méthode permettant de générer une graine "enfant" à partir d'une
273 * graine "parent".
274 *
275 * Cette méthode n'utilise pas la graine en mémoire mais la graine en paramètre.
276 * Si la graine en paramètre n'a pas la bonne taille, une erreur sera émise.
277 *
278 * @param parent_seed [IN/OUT] La graine "parent".
279 * @param leap Le saut à effectuer (0 = la graine n+1+0 / 1 = la graine n+1+1).
280 * @return ByteUniqueArray La nouvelle graine généré à partir de la graine "parent".
281 */
282 virtual ByteUniqueArray generateRandomSeed(ByteArrayView parent_seed, Integer leap = 0) = 0;
283
284 /**
285 * @brief Méthode permettant de savoir si les sauts sont permis sur le
286 * générateur de nombres.
287 *
288 * @return true Si oui.
289 * @return false Si non.
290 */
291 virtual bool isLeapNumberSupported() = 0;
292
293 /**
294 * @brief Méthode permettant de générer un nombre aléatoire avec
295 * la graine en mémoire.
296 *
297 * @param leap Le saut à effectuer (0 = le nombre n+1+0 / 1 = le nombre n+1+1).
298 * @return Real Le nombre généré (entre 0 et 1).
299 */
300 virtual Real generateRandomNumber(Integer leap = 0) = 0;
301
302 /**
303 * @brief Méthode permettant de générer un nombre aléatoire avec
304 * la graine transmise en paramètre.
305 *
306 * Cette méthode n'utilise pas la graine en mémoire mais la graine en paramètre.
307 * Si la graine en paramètre n'a pas la bonne taille, une erreur sera émise.
308 *
309 * @param seed [IN/OUT] La graine.
310 * @param leap Le saut à effectuer (0 = le nombre n+1+0 / 1 = le nombre n+1+1).
311 * @return Real Le nombre généré (entre 0 et 1).
312 */
313 virtual Real generateRandomNumber(ByteArrayView seed, Integer leap = 0) = 0;
314};
315
316/*---------------------------------------------------------------------------*/
317/*---------------------------------------------------------------------------*/
318
319} // End namespace Arcane
320
321/*---------------------------------------------------------------------------*/
322/*---------------------------------------------------------------------------*/
323
324#endif
Déclarations des types utilisés dans Arcane.
Interface pour un générateur de nombre aléatoire.
virtual ByteConstArrayView viewSeed()=0
Méthode permettant de récupérer une vue constante sur la graine actuelle.
virtual ByteUniqueArray emptySeed()=0
Méthode permettant de récupérer une graine vide de bonne taille.
virtual Real generateRandomNumber(ByteArrayView seed, Integer leap=0)=0
Méthode permettant de générer un nombre aléatoire avec la graine transmise en paramètre.
virtual ByteUniqueArray generateRandomSeed(Integer leap=0)=0
Méthode permettant de générer une graine "enfant" à partir d'une graine "parent".
virtual bool isLeapSeedSupported()=0
Méthode permettant de savoir si les sauts sont permis sur le générateur de graines.
virtual Real generateRandomNumber(Integer leap=0)=0
Méthode permettant de générer un nombre aléatoire avec la graine en mémoire.
virtual ByteUniqueArray generateRandomSeed(ByteArrayView parent_seed, Integer leap=0)=0
Méthode permettant de générer une graine "enfant" à partir d'une graine "parent".
virtual bool isLeapNumberSupported()=0
Méthode permettant de savoir si les sauts sont permis sur le générateur de nombres.
virtual bool initSeed(ByteArrayView seed)=0
Méthode permettant d'initialiser le service.
virtual Integer neededSizeOfSeed()=0
Méthode permettant de connaitre la taille de seed nécessaire pour l'implémentation.
virtual bool initSeed()=0
Méthode permettant d'initialiser le service.
Classe permettant de manipuler facilement une graine.
bool value(T &value_out, bool without_size_check=true) const
Méthode permettant de récupérer la valeur de la graine.
Integer sizeOfSeed() const
Méthode permettant de récupérer la taille de la graine.
bool setValue(T value_in)
Méthode permettant de définir une valeur dans la graine.
ByteConstArrayView constView() const
Méthode permettant de récupérer une vue constante.
ByteUniqueArray copy()
Méthode permettant de récupérer une copie du tableau de Byte.
bool value(T *value_out, bool without_size_check=true) const
Méthode permettant de récupérer la valeur de la graine.
ByteArrayView view()
Méthode permettant de récupérer une vue.
RNGSeedHelper(T *var)
Constructeur de classe.
RNGSeedHelper(ByteArrayView av)
Constructeur de la classe.
RNGSeedHelper & operator=(T new_value)
Opérateur de copie depuis une valeur de graine.
Vue modifiable d'un tableau d'un type T.
Vue constante d'un tableau de type T.
Vecteur 1D de données avec sémantique par valeur (style STL).
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
unsigned char Byte
Type d'un octet.
Definition UtilsTypes.h:148