/* [[file:~/qp2/src/utils/qsort.org::*Generated%20C%20file][Generated C file:1]] */ #include #include struct int16_t_comp { int16_t x; int32_t i; }; int compare_int16_t( const void * l, const void * r ) { const struct int16_t_comp * restrict _l= l; const struct int16_t_comp * restrict _r= r; if( _l->x > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_int16_t(int16_t* A_in, int32_t* iorder, int32_t isize) { struct int16_t_comp* A = malloc(isize * sizeof(struct int16_t_comp)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_int16_t_big(int16_t* A_in, int64_t* iorder, int64_t isize) { struct int16_t_comp_big* A = malloc(isize * sizeof(struct int16_t_comp_big)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_int32_t(int32_t* A_in, int32_t* iorder, int32_t isize) { struct int32_t_comp* A = malloc(isize * sizeof(struct int32_t_comp)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_int32_t_big(int32_t* A_in, int64_t* iorder, int64_t isize) { struct int32_t_comp_big* A = malloc(isize * sizeof(struct int32_t_comp_big)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_int64_t(int64_t* A_in, int32_t* iorder, int32_t isize) { struct int64_t_comp* A = malloc(isize * sizeof(struct int64_t_comp)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_int64_t_big(int64_t* A_in, int64_t* iorder, int64_t isize) { struct int64_t_comp_big* A = malloc(isize * sizeof(struct int64_t_comp_big)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_double(double* A_in, int32_t* iorder, int32_t isize) { struct double_comp* A = malloc(isize * sizeof(struct double_comp)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_double_big(double* A_in, int64_t* iorder, int64_t isize) { struct double_comp_big* A = malloc(isize * sizeof(struct double_comp_big)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_float(float* A_in, int32_t* iorder, int32_t isize) { struct float_comp* A = malloc(isize * sizeof(struct float_comp)); if (A == NULL) return; for (int i=0 ; ix > _r->x ) return 1; if( _l->x < _r->x ) return -1; return 0; } void qsort_float_big(float* A_in, int64_t* iorder, int64_t isize) { struct float_comp_big* A = malloc(isize * sizeof(struct float_comp_big)); if (A == NULL) return; for (int i=0 ; i