From 3f0510629e422e979b57d3f93791937912a4183a Mon Sep 17 00:00:00 2001 From: Ian Jauslin Date: Tue, 14 Jun 2022 09:26:07 +0200 Subject: Update to v1.5. The update to version 1.5 is rather substantial, and introduces some minor backward-incompatibilities: * The header "#!symbols" has been replaced by "#!virtual_fields" * Multiplying polynomials using the '*' symbol is no longer supported (or, rather, the symbolic capabilities of meankondo were enhanced, and the syntax has been changed). * 'meantools exp' has been removed (its functionality is now handled by other means) * 'meantoolds derive' has been replaced by 'meantools differentiate' * The symbolic capabilities were enhanced: polynomials can now be multiplied, added, exponentiated, and their logarithms can be taken directly in the configuration file. * The flow equation can now be processed after being computed using the various "#!postprocess_*" entries. * Deprecated kondo_preprocess. * Compute the mean using an LU decomposition if possible. * More detailed checks for syntax errors in configuration file. * Check that different '#!group' entries are indeed uncorrelated. * New flags in meankondo: '-p' and '-A'. * New tool: meantools expand. * Improve conversion to LaTeX using meantools-convert * Assign terms randomly to different threads. * Created vim files to implement syntax highlighting for configuration files. * Multiple bug fixes --- src/determinant.c | 93 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 93 insertions(+) create mode 100644 src/determinant.c (limited to 'src/determinant.c') diff --git a/src/determinant.c b/src/determinant.c new file mode 100644 index 0000000..906c75f --- /dev/null +++ b/src/determinant.c @@ -0,0 +1,93 @@ +#include "determinant.h" + +#include "number.h" +#include "rational.h" +#include "definitions.cpp" + +// determinant of a matrix +// replaces the matrix by its LU decomposition +int determinant_inplace(Number_Matrix M, Number* out){ + int i; + int sign_correction; + + LU_dcmp_inplace(M, &sign_correction); + + if(sign_correction==0){ + *out=number_zero(); + return(0); + } + + *out=number_one(); + if(sign_correction==-1){ + number_Qprod_chain(quot(-1,1), out); + } + + for(i=0;i=M.length){ + *sign_correction=0; + return(0); + } + // pivot if needed + if(pivot!=j){ + for(k=0;k