FAQ
1. Precission Loss
message: Desired error not nescessarily achieved due to precision loss.
Check the jac value,
1.1 If all absulute value is small. it is acceptable beacuse of the precision.
1.2 If some absulte value is large. It is the bad parameters or problem in models.
1.3 Avoid negative weights
2. NaN value in fit
message: NaN result encountered.
2.1 Check the data.
There a script (scripts/check_nan.py) to check it.
2.1.1 No stange value in data, (nan, infs …).
2.1.2 The data order should be \(E, p_x, p_y,p_z\), \(E\) is the first.
2.1.3 The mass should be valid, \(E^2 - p_x^2 - p_y^2 - p_z^2 > 0\), and for any combinations of final particles, mab > ma + mb.
2.1.4 Avoid 0 in weights.
2.2 Check the model.
2.2.1 The resonaces mass should be valid, for example in the mass range (m1+m2, m0-m3), out of the threshold required special options.
3. NaN value when getting params error.
numpy.linalg.LinAlgError: Array must not contain infs or NaN.
3.1 Similar as sec 2.2.
3.2 Bad fit parameters: too wide width or two narrow width, reach the boundary and so on.
3.3 Bad gradients. No gradients or the gradients is not corret for fit paramters.
4. Singular Matrix when getting params error
numpy.linalg.LinAlgError: Singular matrix
4.1 Free paramters are not used in model.
4.2 Used numpy for calculation of variable. The calculation have to be done in get_amp with TensorFlow.
... def init_params(self): self.a = self.add_var("a") def get_amp(self, data, *args, **kwargs): # avoid use numpy for varible as a = np.sin(self.a()) # use tensorflow instead a = tf.sin(self.a())
5. Out of memory (OOM)
5.1 GPU
tensorflow.python.framework.errors_impl.ResourceExhaustedError: OOM when allocating tensor with shape ... device:GPU:0 by allocator GPU_0_bfc [Op:...]
5.1.1 Reduce batch size at config.fit(batch=65000)
and config.get_params_error(batch=13000)
in fit.py.
5.1.2 Use option for large data size, such as lazy call
# config.yml data: lazy_call: True
5.1.3 Try to use small data sample, or simple cases (less final particles).
5.1.4 Some speical model required large memory (such as interpolation model), try other model.
5.2 CPU
killed
5.2.1 Try to allocate more memory. There should be some options for job.
5.2.2 Similar as sec 5.1
6. Bad config.yml
6.1 yaml parse error
yaml.parser.ParserError: while parsing ..
Check the yaml file (see https://yaml.org): the indent, speical chars ,:}]
, unicode and so on.
6.2 Decay chain
AssertionError: not only one top particle
The decay chain should be complete. All the item in decay should decay from initial to finals.
6.3 Decay chain 2
RuntimeError: not decay chain aviable, check you config.yml
6.3.1 Similar as sec 6.2.
6.3.2 Check the information in remove decay chain, see the reson why those decays are not aviable.
ls not aviable means no possible LS combination allowed. Check the spin and parity. If allow parity voilate, add p_break: True
to decay.