This is a simple dynamic array tool, similar to C++'s std::vector
, implemented in C. It is coded using macros to simulate template-like
functions found in languages like C++. This allows users to work with arrays in C more easily, without the need to repeatedly declare the data type.
It's a single-header library. For most basic dynamic array functionality, you only need to include src/c_array.h
in your project. If you want to use extended features such as statistical calculations and the mt19937 random number generator
, you should also link either src/c_array.c
or src/c_array_mt.c
when compiling your code. (All the functions are declared in src/c_array.h
, so you can call any of them by including the header file src/c_array.h
in your source code.)
For example, if you have a program like main.c:
# include "c_array.h"
int main() {
c_array_int array;
mt19937_state state;
mt19937_init(&state, 1314);
// This funciton is implemented in c_array_mt.c
c_array_rand_range(&array, 10, mt19937_get_int32_range(&state, -5, 20));
// This funciton is implemented in c_array.c
int sum = c_array_sum(&array);
c_array_free(&array);
}
compile with gcc (remember to add -lm to link math.h in linux os)
gcc main.c c_array_mt.c c_array.c -lm -o main.out
Because of the typeof
and _Generic
features in the code, the project has been tested exclusively with the GCC compiler on both Windows (MinGW) and Ubuntu operating systems. (A minimum version of GCC 4.9 is required, as _Generic
support was introduced starting from version 4.9.)
Compiler | Windows | Ubuntu | Mac |
---|---|---|---|
GNU Compiler Collection (gcc) | - | ✅ | Not yet tested |
x86_64 mingw series (gcc) | ✅ | - | Not yet tested |
Visual Studio Build Tools | ❌ | ❌ | Not yet tested |
- c_array_sum
- c_array_mean
- c_array_std
- c_array_var
- c_array_max
- c_array_min
- c_array_argmax
- c_array_argmin
- c_array_qsort
- c_matrix_flatten
- c_matrix_reshape
- c_matrix_sum
- c_matrix_mean
- c_matrix_max
- c_matrix_min
- c_matrix_var
- c_matrix_std
- c_array_search
- mt19937_init
- mt19937_generate
- mt19937_get_int32_range
- mt19937_get_float
- mt19937_get_float_range
- mt19937_get_double
- mt19937_get_double_range
- random_normal
- c_array_randnormal
- c_array_rand_range
Here is an example in example.c
that demonstrates how to use this library. You can simply use the shell script example.sh (for Linux)
or the batch file example.bat
to compile and run the program. The example program prints out results to help users understand how it works.
# include <stdio.h>
# include "./src/c_array.h"
int main() {
printf("\nc_array Example\n\n");
// Initialize the array. If capacity > 0, then it will initialize with 0 val.
c_array_int array;
c_array_init(&array, 0);
// add element to the back (the idx of back is the current size of array)
c_array_push_back(&array, 10);
c_array_push_back(&array, 2222);
c_array_push_back(&array, -1024);
// print the array in this style -> arr = [1, 2, 3]
printf("After push back\n");
c_array_printf(array, "%d");
printf("Array size = %zu\n", array.size);
printf("Array capacity = %zu\n\n", array.capacity);
// assign value directly or via function.
// assign by function can help to check if the memory is allocated.
c_array_assign(&array, 0, 999);
printf("Use c_array_assign: \n");
c_array_print(array, "%d");
printf("Assign directly: \n");
array.data[0] = 111;
c_array_printf(array, "%d");
// pop the last element in array.
// That element will be reseted to 0, and - 1 to the array size.
c_array_pop_back(&array);
printf("\nAfter pop_back\n");
c_array_printf(array, "%d");
printf("Array size = %zu\n", array.size);
printf("Array capacity = %zu\n\n", array.capacity);
// insert the element at certain idx of the array
// c_array_insert(array, index, value)
c_array_insert(&array, 1, 90);
printf("\nAfter insert\n");
c_array_printf(array, "%d");
printf("Array size = %zu\n", array.size);
printf("Array capacity = %zu\n\n", array.capacity);
// remove the element at certain idx of the array
// c_array_remove(array, index)
c_array_remove(&array, 1);
printf("\nAfter remove\n");
c_array_printf(array, "%d");
printf("Array size = %zu\n", array.size);
printf("Array capacity = %zu\n\n", array.capacity);
// adjust the array capacity
// should be careful the value was not initialize
c_array_resize(&array, 20);
printf("\nAfter resize\n");
c_array_printf(array, "%d");
printf("Array size = %zu\n", array.size);
printf("Array capacity = %zu\n\n", array.capacity);
// adjust the array size
c_array_set_size(&array, 20);
printf("\nAfter set size\n");
c_array_printf(array, "%d");
printf("Array size = %zu\n", array.size);
printf("Array capacity = %zu\n\n", array.capacity);
// Remember to free the memory after you don't need it.
c_array_free(&array);
return 0;
}
- params:
T
: the data type of the array -> (int, long long, float, double etc..)
arr
: c_array structure -> (c_array)
c
: the capacity for init -> (size_t)
Create the array with given datatype by c_array(datatype) arr;
. You should initialize it before use. arr.size
is the logical size of the array and arr.capacity
is the whole space for the container. However it is better to use c_array_int
, c_array_float
, c_array_doulbe
which was defined by typdef
. You can also define your own type like typedef c_array_long c_array(long);
.
Initialize the array with the given size & capacity by c_array_init(&arr, size)
.
int main() {
c_array(int) arr; // You can use this method to declare array, but it can't be used in other function which need to declare the dtype.
c_array_int array; // This is the dtype of c_array(int). You can use this in any function which need to declare dtype like void foo(c_array_int array, int num);
c_array_init(&arr, 10); // arr[0] ~ arr[9] will be initialized with 0
c_array_free(&arr); // free memory
return 0;
}
- params:
T
: the data type of the array -> (int, long long, float, double etc..)
arr
: c_array structure -> (c_array)
c
: the capacity for init -> (size_t)
Allocate memory of the array with the given size & capacity (No initialize value).
int main() {
c_array(int) arr; // You can use this method to declare array, but it can't be used in other function which need to declare the dtype.
c_array_int array; // This is the dtype of c_array(int). You can use this in any function which need to declare dtype like void foo(c_array_int array, int num);
c_array_init(&arr, 10); // arr[0] ~ arr[9] will be initialized with 0
c_array_free(&arr); // free memory
return 0;
}
- params:
arr_old
: c_array structure you want to copy -> (c_array)
arr_new
: new c_array structure -> (c_array)
Copy an array to the target arry.
int main() {
c_array_int arr;
c_array_init(&arr, 0); // arr[0] ~ arr[9] will be initialized with 0
c_array_push_back(&arr, 7);
c_array_push_back(&arr, 8);
c_array_push_back(&arr, 9);
c_array_int arr_new; // declare arr_new without initialize.
c_array_copy(&arr, &arr_new); // copy the memory from arr to arr_new
c_array_print(arr_new, "%d"); // arr_new = [7, 8, 9], size and capacity are also equals to arr
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
Get array capacity and size.
int main() {
c_array_int arr;
c_array_init(&arr, 10);
// Get size and capacity by macro
int size = c_array_size(&arr); // equals to 10
int capacity = c_array_capacity(&arr); // equals to 10
// Get these attributes by struct
size = arr.size;
capacity = arr.capacity;
c_array_free(&arr);
return 0;
}
- params:
arr
: c_array structure -> (c_array)
idx
: index of the array -> (int)
val
: value -> (int, long long, float, double etc..)
Assign the value at given location. This funciton will help to check if the memory is allocated before assigning the value. If memory is not allocated, then the program will abort with error.
int main() {
c_array_int arr;
c_array_init(&arr, 10);
c_array_assign(&arr, 0, 150); // arr.data[0] now is 150
c_array_assign(&arr, 11, 150); // program abort due to the size of array is only 10.
// Assign value in struct directly
arr.data[0] = -150; // warning: this method didn't check if the memory is allocated.
c_array_free(&arr); // free memory
return 0;
}
This macro is for array to grow the capacity while the memory is not enough. User don't have to call it manually. If you want to adjust the size or the capacity, please refer to the c_array_resize
and c_array_set_size
. Features in c_array_tools will grow the capacity while the memory space is not enough. By default, each growing will double the current capacity.
- params:
arr
: c_array structure -> (c_array)
c
: capacity -> (size_t)
size
: size -> (size_t)
Resize the capacity to given value.
int main() {
c_array_int arr;
c_array_init(&arr, 0); // capacity and size are both 0 now
c_array_resize(&arr, 10); // capacity become 10 and size remain 0.
c_array_set_size(&arr, 8); // capacity is 10 and size is 8 (element will initialize with 0)
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
val
: value -> (int, long long, float, double etc..)
Push the element at the end of the array (depend on arr.size). If the capacity is not enough, this funciton will call c_array_grow
to enlarge the capacity automatically. Notice if you need to push_back frequently, please use c_array_resize
to set enough capacity to avoid the realloc of memory.
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1); // capacity and size is 1 now
c_array_push_back(&arr, 2); // capacity and size is 2 now
c_array_push_back(&arr, 3); // capacity is 4 and size is 3 now
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
Remove the last element of the array (depend on arr.size).
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3); // arr = [1, 2, 3]
c_array_pop_back(&arr); // arr = [1, 2]
c_array_free(&arr); // free memory
return 0;
}
These are the feature for c_array_insert and c_array_remove.
- params:
arr
: c_array structure -> (c_array)
idx
: index of the array -> (int)
val
: value -> (int, long long, float, double etc..)
Insert the element at given index.
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3); // arr = [1, 2, 3]
c_array_insert(&arr, 1, 99); // arr = [1, 99, 2, 3]
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
idx
: index of the array -> (int)
Remove the elemnt at given index.
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3); // arr = [1, 2, 3]
c_array_remove(&arr, 1); // arr = [1, 3]
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
format
: format specifier -> (char*)
Print the array with clean style.
int main() {
c_array_int arr_print_test;
c_array(&arr_print_test, 0);
c_array_push_back(&arr_print_test, 1);
c_array_push_back(&arr_print_test, 2);
c_array_push_back(&arr_print_test, 3);
c_array_printf(arr_print_test, "%d"); // Custom format to print the array
// Results shows: arr_print_test = [1, 2, 3]
c_array_print(arr_print_test); // Default format like %d %lld %f %lf. You can add more format in c_array_autoformat macro
// Results shows: arr_print_test = [1, 2, 3]
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array) - return: 0 or 1 -> (int)
Check if array is empty, if yes return 1 else 0
int main() {
c_array_int arr;
c_array(&arr, 0);
int e = c_array_empty(&arr); // e = 1
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
idx1
: index 1 -> (int)
idx2
: index 2 -> (int)
Swap the data in array
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3); // arr = [1, 2, 3]
c_array_swap(&arr, 0, 1); // arr = [2, 1, 3]
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
Reverse the array
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3); // arr = [1, 2, 3]
c_array_reverse(&arr); // arr = [3, 2, 1]
c_array_free(&arr); // free memory
return 0;
}
- params:
arr1
: c_array structure (result will concat at this array) -> (c_array)
arr2
: c_array structure -> (c_array)
Concat two arrays.
int main() {
c_array_int arr;
c_array_int arr2;
c_array(&arr, 0);
c_array(&arr2, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr2, 9);
c_array_push_back(&arr2, -45);
c_array_concat(&arr1, &arr2); // arr1 = [1, 2, 9, -45], arr2 = [9, -45]
c_array_free(&arr); // free memory
c_array_free(&arr2); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
Free the memory allocated from heap.
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_free(&arr);
return 0;
}
- params:
arr
: c_array structure -> (c_array)
Sort the array by the qsort function in <stdlib.h>, or sort the array by the 'merge sort'.
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 99);
c_array_push_back(&arr, -2);
c_array_push_back(&arr, 2); // arr = [99, -2, 2]
c_array_qsort(&arr); // arr = [-2, 2, 99]
c_array_push_back(&arr, -91);
c_array_push_back(&arr, 1); // arr = [-2, 2, 99, -91, 1]
c_array_msort(&arr); // arr = [-91, -2, 1, 2, 99]
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array) - return:
sum
-> (int, long long, float, double etc..)
Get the sum of an array.
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3);
int sum = c_array_sum(&arr); // sum = 6
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array) - return:
min or max
-> (int, long long, float, double etc..)
Get min or max value of an array
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3);
int max = c_array_max(&arr); // max = 3
int min = c_array_min(&arr); // min = 1
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array) - return:
pointer contain min and max (arr[0] = min, arr[1] = max)
-> (int, long long, float*, double* etc..**)
Get min or max value of an array
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3);
int* max_min = c_array_maxmin(&arr); // max_min[0] = 1, max_min[1] = 3
c_array_free(&arr); // free memory
free(max_min);
return 0;
}
- params:
arr
: c_array structure -> (c_array) - return:
pointer contain the index of max value in array
-> (int, long long, float*, double* etc..**)
Get index of max value of an array
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3);
c_array_push_back(&arr, 3);
int* max_indices = c_array_argmax(&arr); // max_indices[0] = 2, max_indices[1] = 3
c_array_free(&arr); // free memory
free(max_min); // You should free the max_indices manually.
return 0;
}
- params:
arr
: c_array structure -> (c_array) - return:
pointer contain the index of min value in array
-> (int, long long, float*, double* etc..**)
Get the index of min value of an array
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3);
c_array_push_back(&arr, 3);
int* min_indices = c_array_argmin(&arr); // min_indices[0] = 2, min_indices[1] = 3
c_array_free(&arr); // free memory
free(min_min); // You should free the min_indices manually.
return 0;
}
- params:
arr
: c_array structure -> (c_array) - return:
mean value
-> (mean_t)
Get mean value of an array
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3);
mean_t mean = c_arry_mean(&arr); // mean = 2
c_array_free(&arr); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array) - return:
standard deviation or variance
-> (std_t, var_t)
Get the standard deviation or the variance of an array
int main() {
c_array_int arr;
c_array(&arr, 0);
c_array_push_back(&arr, 1);
c_array_push_back(&arr, 2);
c_array_push_back(&arr, 3);
std_t std = c_array_std(&arr); // std = 0.8164
var_t var = c_array_var(&arr); // var = 0.6667
c_array_free(&arr); // free memory
return 0;
}
- params:
state
: state of random seed generator -> (mt19937_state*)
seed
: random seed number -> (unsigned int) - return:
void
-> (void)
Create the random seed generator with the given random seed.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
return 0;
}
- params:
state
: state of random seed generator -> (mt19937_state*) - return:
random value
-> (unsigned long)
Get the long or integer type random value between 0 ~ 4294967296.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
long num = mt19937_generate(&state);
return 0;
}
- params:
state
: state of random seed generator -> (mt19937_state*) - return:
random value
-> (float)
Get the float type random value between 0 ~ 1.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
float num = mt19937_get_float(&state);
return 0;
}
- params:
state
: state of random seed generator -> (mt19937_state*) - return:
random value
-> (double)
Get the double type random value between 0 ~ 1.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
double num = mt19937_get_double(&state);
return 0;
}
- params:
state
: state of random seed generator -> (mt19937_state*)
m
: min value -> (int)
n
: max value -> (int) - return:
random value
-> (int)
Get the random value between given min and max.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
int num = mt19937_get_int32_range(&state, -10, 20); // -10 <= num <= 20
return 0;
}
- params:
state
: state of random seed generator -> (mt19937_state*)
m
: min value -> (float)
n
: max value -> (float) - return:
random value
-> (float)
Get the random value between given min and max.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
float num = mt19937_get_float_range(&state, -5.65, 20.11); // -5.65 <= num < 20.11
return 0;
}
- params:
state
: state of random seed generator -> (mt19937_state*)
m
: min value -> (double)
n
: max value -> (double) - return:
random value
-> (double)
Get the random value between given min and max.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
double num = mt19937_get_double_range(&state, -5.65, 20.11); // -5.65 <= num < 20.11
return 0;
}
- params:
state
: state of random seed generator -> (mt19937_state*) - return:
random value
-> (double)
Draw the random value from standard normal distribution.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
double num = random_normal(&state);
return 0;
}
- params:
arr
: c_array structure -> (c_array)
c
: capacity and size for init -> (int)
rng_state
: state of random seed generator -> (mt19937_state*)
Initialize the c_array with the random value from standard normal distribution.
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
c_array_double array;
c_array_randnormal(&array, 10, &state);
c_array_free(&array); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
c
: capacity and size for init -> (int)
rng_function
: rng_function -> (rng_function)
Initialize the c_array with the random value from given random function
int main() {
mt19937_state state;
mt19937_init(&state, 12345);
c_array_double array;
double num = random_normal(&state);
c_array_rand_range(&arr, c, mt19937_get_int32_range(&state, -5, 20));
c_array_free(&array); // free memory
return 0;
}
- params:
arr
: c_array structure -> (c_array)
target
: target you want to search -> (int, long long, float, double etc..) - return:
Index of the target
-> (int)
Initialize the c_array with the random value from given random function
int main() {
c_array_int array;
c_array_init(&array, 0);
for (int i = 0; i < 5; i++) {
array.data[i] = i * 2;
}
int idx = c_array_search(&array, 8); // idx = 4
c_array_free(&array); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix)
rows
: number of rows -> (int)
cols
: number of cols -> (int)
Initialize c_matrix with given rows and cols.
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2); // matrix will init with value = 0
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat_old
: c_matrix structure to be copied -> (c_matrix)
mat_new
: The new clone of c_matrix structure -> (c_matrix)
Copy memory of mat_old to mat_new.
int main() {
c_matrix_int mat;
c_matrix_int mat_new;
c_matrix_init(&mat, 4, 5);
c_matrix_copy(&mat, &mat_new); // mat_new row = 4, mat_new col = 5
c_matrix_free(&mat); // free memory
c_matrix_free(&mat_new);
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix)
rows
: number of rows -> (int)
cols
: number of cols -> (int)
Allocate memory of the matrix with given rows and cols (No initialize value).
int main() {
c_matrix_int mat;
c_matrix_empty_init(&mat, 2, 2);
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix)
r
: number of rows -> (int)
c
: number of cols -> (int)
rng_state
: state of random seed generator -> (mt19937_state*)
Initialize c_matrix with random value draw from noraml distribution.
int main() {
c_matrix_double mat;
mt19937_state rng;
unsigned int seed = 12345;
mt19937_init(&rng, seed);
c_matrix_randnormal(&mat, 10, 10, &rng);
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix)
r
: number of rows -> (int)
c
: number of cols -> (int)
rng_state
: state of random seed generator -> (mt19937_state*)
Initialize the c_matrix with the random value from given random function.
int main() {
c_matrix_int mat;
mt19937_state rng;
unsigned int seed = 12345;
mt19937_init(&rng, seed);
c_matrix_rand_range(&mat, r, c, mt19937_get_int32_range(&state, -5, 20));
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix)
rows
: number of rows -> (int)
cols
: number of cols -> (int)
val
: value -> (int, long long, float, double etc..)
Assign given value at given row and col.
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2);
c_matrix_assign(&mat, 2, 2, 10);
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix)
format
: format specifier -> (char*)
Print matirx with clean style.
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2);
for (int i = 0; i < mat.rows; i++) {
for (int j = 0; j < mat.cols; j++) {
mat.data[i][j] = i + j;
}
}
c_matrix_print(mat);
c_matrix_printf(mat, "%d");
c_array_free(&arr); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix)
Free memory
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2);
for (int i = 0; i < mat.rows; i++) {
for (int j = 0; j < mat.cols; j++) {
mat.data[i][j] = i + j;
}
}
c_matrix_free(&mat); // free memory
return 0;
}
- params:
arr
: c_matrix structure -> (c_array)
n_row
: number of rows -> (int) - return:
c_matrix
-> (c_matrix)
Reshape array to matrix with given row numbers.
int main() {
c_array_int arr;
c_matrix_init(&mat, 20);
for (int i = 0; i < arr.size; i++) {
arr.data[i] = i;
}
c_matrix_int mat = c_array_matrix_form(&arr, 4); // mat.rows = 4, mat.cols = 5
c_array_free(&arr);
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix) - return:
c_array
-> (c_array)
Flatten c_matrix and return c_array
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2);
for (int i = 0; i < mat.rows; i++) {
for (int j = 0; j < mat.cols; j++) {
mat.data[i][j] = i + j;
}
}
c_array_int arr = c_matrix_flatten(&mat);
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix)
row
: row number -> (int)
col
: col number -> (int) - return:
c_matrix
-> (c_matrix)
Reshape c_matrix.
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2);
for (int i = 0; i < mat.rows; i++) {
for (int j = 0; j < mat.cols; j++) {
mat.data[i][j] = i + j;
}
}
c_array_int arr = c_matrix_reshape(&mat, 4, 1);
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix) - return:
sum
-> (int, long long, float, double etc..)
Calculate the sum of the matrix.
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2);
for (int i = 0; i < mat.rows; i++) {
for (int j = 0; j < mat.cols; j++) {
mat.data[i][j] = 5;
}
}
int sum_i = c_matrix_sum(&mat); // sum i = 20
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix) - return:
mean
-> (mean_t)
Calculate the mean value of the matrix.
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2);
for (int i = 0; i < mat.rows; i++) {
for (int j = 0; j < mat.cols; j++) {
mat.data[i][j] = 5;
}
}
mean_t mean = c_matrix_mean(&mat); // mean = 5
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix) - return:
max or min
-> (int, long long, float, double etc..)
Get the max or min of the matrix.
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 2, 2);
for (int i = 0; i < mat.rows; i++) {
for (int j = 0; j < mat.cols; j++) {
mat.data[i][j] = i + j;
}
}
int max = c_matrix_max(&mat); // mean = 2
int min = c_matrix_min(&mat); // min = 0
c_matrix_free(&mat); // free memory
return 0;
}
- params:
mat
: c_matrix structure -> (c_matrix) - return:
std or var
-> (std_t, var_t)
Calculate the variance or the standard deviation of the matrix.
int main() {
c_matrix_int mat;
c_matrix_init(&mat, 3, 3);
for (int i = 0; i < mat.rows; i++) {
for (int j = 0; j < mat.cols; j++) {
mat.data[i][j] = i + j;
}
}
var_t var = c_matrix_var(&mat); // var = 1.3333333
std_t std = c_matrix_std(&mat); // std = 1.154701
c_matrix_free(&mat); // free memory
return 0;
}