RQ Query(3) Librecast Programmer's Manual RQ Query(3)

rq_query - RaptorQ Query Functions

#include <lcrq.h>
uint8_t rq_Al(const rq_t * const rq);
uint64_t rq_F(const rq_t * const rq);
uint16_t rq_K(const rq_t * const rq);
uint16_t rq_KP(const rq_t * const rq);
uint16_t rq_T(const rq_t * const rq);
uint16_t rq_N(const rq_t * const rq);
uint8_t rq_Z(const rq_t * const rq);

Compile and link with -llcrq.

The RaptorQ query functions return the value of their respective RaptorQ parameters.

F Transfer Length (F): 40-bit unsigned integer. A non-negative integer that is at most 946270874880. This is the transfer length of the object in units of octets.

T Symbol Size (T): 16-bit unsigned integer. A positive integer that is less than 2^^16. This is the size of a symbol in units of octets. This MUST be a multiple of Al.

Al A symbol alignment parameter (Al): 8-bit unsigned integer.

Z The number of source blocks (Z): 16-bit unsigned integer.

K The number of source symbols.

KP (K') The number of source and padding symbols.

The parameter rq must be a pointer to RaptorQ context initialized with rq_init(3)

These functions return the RQ parameters as unsigned integers.

These functions do not return errors.

/* params - example program to create RaptorQ context and print derived parameters */
#include <lcrq.h>
#include <stdio.h>
#include <stdlib.h>
int usage(const char *progname)
{
        fprintf(stderr, "usage: `%s F T`  (F = object size, T = symbol size)0, progname);
}
int main(int argc, char *argv[])
{
        rq_t *rq;
        uint64_t F;
        uint16_t T, K, KP, N, Z;
        uint8_t Al;
        if (argc != 3) return usage(argv[0]);
        F = atoll(argv[1]);
        T = atoll(argv[2]);
        /* initialize RaptorQ context */
        rq = rq_init(F, T);
        /* Query parameters */
        K = rq_K(rq);
        KP = rq_KP(rq);
        N = rq_N(rq);
        Z = rq_Z(rq);
        /* free RaptorQ context */
        rq_free(rq);
        printf("F  %12lusize of object to encode (40 bits)0, F);
        printf("T  %12usymbol (payload) size0, T);
        printf("K  %12unumber of original symbols0, K);
        printf("K' %12unumber of symbols, including padding symbols0, KP);
        printf("N  %12unumber of sub-blocks0, N);
        printf("Z  %12unumber of blocks0, Z);
        return 0;
}
rq_free(rq); /* free context when done */

rq_init(3), rq_free(3), rq_decode(3), rq_encode(3), rq_symbol(3), lcrq(7)

2022-07-07 LCRQ