
#include "bench_harness.h"
#include "bench_utils.h"
#include <stddef.h>
#include <stdint.h>
void kernel_run(int n, const float *x, uint8_t *packed) {
  if (n < 1)
    n = 1;
  size_t bytesN = ((size_t)n + 7u) >> 3;

  for (size_t byte_i = 0; byte_i < bytesN; ++byte_i) {
    uint8_t byte_val = 0;
    for (int b = 0; b < 8; ++b) {
      size_t idx = (byte_i << 3) + (size_t)b;
      if (idx < (size_t)n) {
        float v = x[idx];
        if (v >= 0.0f) {
          byte_val |= (uint8_t)(1u << b);
        }
      }
    }
    packed[byte_i] = byte_val;
  }
}
BENCH_MAIN_ARRAY3_BYTES(
    T003_Code_060, OP90, 4096, 16384, 65536,
    float *x = (float *)malloc((size_t)n * sizeof(float));
    uint8_t *packed = (uint8_t *)malloc((size_t)((n + 7) >> 3) *
                                        sizeof(uint8_t));
    double dummy_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        x[i] = (float)bench_rng_double_signed(&rng) * 4.0f;
      }
      size_t bytesN = (size_t)((n + 7) >> 3);
      for (size_t k = 0; k < bytesN; k++) {
        packed[k] = 0;
      }
    },
    kernel_run(n, x, packed), packed, (size_t)((n + 7) >> 3), free(x);
    free(packed);)
