Compare commits
6 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 06cc1749a3 | |||
| 3bb2b7d2f5 | |||
| 31135b023f | |||
| 604902b398 | |||
| 3a100080c2 | |||
| 7626f99e32 |
+18
-1
@@ -1,4 +1,21 @@
|
||||
build
|
||||
.vscode
|
||||
*.bmp
|
||||
!images/*
|
||||
!images/*
|
||||
*.cache
|
||||
.deps
|
||||
Makefile
|
||||
*.log
|
||||
*.o
|
||||
.dirstamp
|
||||
aclocal.m4
|
||||
compile
|
||||
install-sh
|
||||
missing
|
||||
depcomp
|
||||
Makefile.in
|
||||
configure~
|
||||
config.status
|
||||
margen
|
||||
*.tar.gz
|
||||
configure
|
||||
@@ -0,0 +1,4 @@
|
||||
AUTOMAKE_OPTIONS = foreign subdir-objects -Wall
|
||||
bin_PROGRAMS = margen
|
||||
margen_SOURCES = src/main.c src/args.c src/bmp.c src/generator.c src/rand.c
|
||||
include_HEADERS = src/main.h src/args.h src/bmp.h src/generator.h src/rand.h src/config.h src/types.h
|
||||
+7
-10
@@ -24,15 +24,12 @@ valgrind: build
|
||||
valgrind --leak-check=full -s ./build/$(TARGET) $(TEST_ARGS)
|
||||
|
||||
.PHONY: release
|
||||
release: clean build time
|
||||
@echo -n "Version (x.y.z): "
|
||||
@read VERSION; \
|
||||
sed -i "s/#define VERSION.*/#define VERSION \"v$$VERSION\"/g" ./src/const.h; \
|
||||
git add ./src/const.h; \
|
||||
git diff origin/master; \
|
||||
git commit -m "$(TARGET) v$$VERSION"; \
|
||||
git tag v$$VERSION -m "$(TARGET) v$$VERSION"
|
||||
@echo updated ./src/const.h and tagged version
|
||||
release:
|
||||
aclocal
|
||||
autoconf
|
||||
automake --add-missing
|
||||
./configure
|
||||
make distcheck
|
||||
|
||||
.PHONY: gif
|
||||
gif: build
|
||||
@@ -41,4 +38,4 @@ gif: build
|
||||
./build/margen -w=1920 -h=720 --seed=$$i$$i -o=tmp/image$$i.bmp ; \
|
||||
done
|
||||
ffmpeg -y -f image2 -framerate 1 -i tmp/image%d.bmp -vf scale=960x360 images/sample.gif
|
||||
rm -rf tmp
|
||||
rm -rf tmp
|
||||
@@ -10,13 +10,29 @@ Written in pure C without librairies.
|
||||
|
||||
## Install
|
||||
|
||||
You only need **gcc** and **make**.
|
||||
### From release
|
||||
|
||||
See [Releases](https://github.com/klemek/margen/releases)
|
||||
|
||||
```bash
|
||||
tar xvzf margen-x.y.z.tar.gz
|
||||
cd margen-x.y.z
|
||||
./configure
|
||||
make
|
||||
make install
|
||||
```
|
||||
|
||||
### From repository (dev version)
|
||||
|
||||
```bash
|
||||
git clone https://github.com/klemek/margen
|
||||
cd margen
|
||||
make clean build install
|
||||
# margen is now installed in ~/.local/bin
|
||||
aclocal
|
||||
autoconf
|
||||
automake --add-missing
|
||||
./configure
|
||||
make
|
||||
make install
|
||||
```
|
||||
|
||||
## CLI arguments
|
||||
@@ -41,7 +57,3 @@ options:
|
||||
-r, --rotation start corner rotation [0-3] (default: random)
|
||||
-m, --monochrome grayscale generation
|
||||
```
|
||||
|
||||
## TODO
|
||||
|
||||
- configure, make, make install
|
||||
@@ -0,0 +1,10 @@
|
||||
AC_INIT([margen], [1.2.1], [klemek.dev@proton.me])
|
||||
AM_INIT_AUTOMAKE
|
||||
AC_PROG_CC
|
||||
AC_CHECK_HEADERS([stdio.h])
|
||||
AC_CHECK_HEADERS([stdlib.h])
|
||||
AC_CHECK_HEADERS([stdbool.h])
|
||||
AC_CHECK_HEADERS([string.h])
|
||||
AC_CHECK_HEADERS([time.h])
|
||||
AC_CONFIG_FILES([Makefile])
|
||||
AC_OUTPUT
|
||||
+8
-8
@@ -1,5 +1,5 @@
|
||||
#include "args.h"
|
||||
#include "const.h"
|
||||
#include "config.h"
|
||||
#include "rand.h"
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
@@ -7,9 +7,9 @@
|
||||
#include <time.h>
|
||||
|
||||
void print_help(int status_code) {
|
||||
puts(NAME
|
||||
puts(PACKAGE
|
||||
" " VERSION "\n\n"
|
||||
"usage: " NAME " "
|
||||
"usage: " PACKAGE " "
|
||||
"[--help] "
|
||||
"[-v] "
|
||||
"[-q] "
|
||||
@@ -23,7 +23,7 @@ void print_help(int status_code) {
|
||||
"[-va=R,G,B] "
|
||||
"[-vr=VAR_RANGE] "
|
||||
"[-r=ROTATION] "
|
||||
// "[-m]"
|
||||
"[-m]"
|
||||
"\n\n"
|
||||
"generate a marble-like pattern bitmap image, blazing fast.\n\n"
|
||||
"options:\n"
|
||||
@@ -145,7 +145,7 @@ parameters parse_args(int argc, char **argv) {
|
||||
} else if (is_arg(arg, "-q") || is_arg(arg, "--quiet")) {
|
||||
params.quiet = true;
|
||||
} else if (is_arg(arg, "-v") || is_arg(arg, "--version")) {
|
||||
puts(NAME " " VERSION);
|
||||
puts(PACKAGE " " VERSION);
|
||||
exit(0);
|
||||
} else if (is_arg(arg, "-w") || is_arg(arg, "--width")) {
|
||||
params.width = parse_ushort(arg, value);
|
||||
@@ -216,9 +216,9 @@ parameters parse_args(int argc, char **argv) {
|
||||
}
|
||||
|
||||
if (!var_set) {
|
||||
params.var[0] = rand_uchar(var_range);
|
||||
params.var[1] = rand_uchar(var_range);
|
||||
params.var[2] = rand_uchar(var_range);
|
||||
params.var[0] = rand_uchar(var_range + 1);
|
||||
params.var[1] = rand_uchar(var_range + 1);
|
||||
params.var[2] = rand_uchar(var_range + 1);
|
||||
}
|
||||
|
||||
if (!rot_set) {
|
||||
|
||||
@@ -0,0 +1,12 @@
|
||||
#ifndef CONFIG_H
|
||||
#define CONFIG_H
|
||||
|
||||
#ifndef PACKAGE
|
||||
#define PACKAGE "margen"
|
||||
#endif
|
||||
|
||||
#ifndef VERSION
|
||||
#define VERSION "(dev)"
|
||||
#endif
|
||||
|
||||
#endif
|
||||
@@ -1,7 +0,0 @@
|
||||
#ifndef CONST_H
|
||||
#define CONST_H
|
||||
|
||||
#define NAME "margen"
|
||||
#define VERSION "v1.1.0"
|
||||
|
||||
#endif
|
||||
+7
-8
@@ -1,8 +1,7 @@
|
||||
#include "args.h"
|
||||
#include "bmp.h"
|
||||
#include "const.h"
|
||||
#include "config.h"
|
||||
#include "rand.h"
|
||||
#include <math.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <time.h>
|
||||
@@ -18,11 +17,10 @@ unsigned char *current_line;
|
||||
|
||||
unsigned char generate_pixel(unsigned char depth, unsigned char top_pixel,
|
||||
unsigned char left_pixel) {
|
||||
float v = fminf(
|
||||
255.0, fmaxf(0.0, (rand_float(2.0) - 1.0) * global_params.var[depth] +
|
||||
((float)left_pixel) * slope +
|
||||
((float)top_pixel) * (1.0 - slope)));
|
||||
return (unsigned char)v;
|
||||
short k = rand_uchar(global_params.var[depth] + 1);
|
||||
short v = (rand_uchar(2) == 0 ? k : -k) + (left_pixel)*slope +
|
||||
(top_pixel) * (1.0 - slope);
|
||||
return (unsigned char)(v < 0 ? 0 : (v > 255 ? (unsigned char)255 : v));
|
||||
}
|
||||
|
||||
void generate_line() {
|
||||
@@ -62,6 +60,7 @@ void debug_parameters(parameters params) {
|
||||
printf(" width %d\n", params.width);
|
||||
printf(" height %d\n", params.height);
|
||||
printf(" pixel %d\n", params.size);
|
||||
printf(" slope %d\n", params.slope);
|
||||
if (params.monochrome) {
|
||||
printf(" color %u\n", params.start[0]);
|
||||
printf(" var. %u\n", params.var[0]);
|
||||
@@ -104,7 +103,7 @@ void print_time(parameters params, clock_t start) {
|
||||
|
||||
void generate(parameters params) {
|
||||
if (!params.quiet) {
|
||||
puts(NAME " " VERSION);
|
||||
puts(PACKAGE " " VERSION);
|
||||
}
|
||||
clock_t start = clock();
|
||||
init(params);
|
||||
|
||||
+15
-11
@@ -1,21 +1,25 @@
|
||||
#include <math.h>
|
||||
static unsigned long long mcg_state = 0xcafef00dd15ea5e5u; // Must be odd
|
||||
static unsigned long long const multiplier = 6364136223846793005u;
|
||||
|
||||
float seed;
|
||||
// https://en.wikipedia.org/wiki/Permuted_congruential_generator
|
||||
unsigned long rand(void) {
|
||||
unsigned long long x = mcg_state;
|
||||
unsigned count = (unsigned)(x >> 61);
|
||||
|
||||
void set_seed(unsigned long new_seed) { seed = (float)(new_seed % 1000000); }
|
||||
|
||||
float rand(float seed) {
|
||||
float v = powf(seed, 6. / 7.);
|
||||
v *= sinf(v) + 1.;
|
||||
return v - floorf(v);
|
||||
mcg_state = x * multiplier;
|
||||
x ^= x >> 22;
|
||||
return (unsigned long)(x >> (22 + count));
|
||||
}
|
||||
|
||||
float rand_float(const float max) { return rand(seed++) * max; }
|
||||
void set_seed(unsigned long long seed) {
|
||||
mcg_state = 2 * seed + 1;
|
||||
(void)rand();
|
||||
}
|
||||
|
||||
unsigned char rand_uchar(const unsigned int max) {
|
||||
return (unsigned char)(rand(seed++) * max);
|
||||
return max == 0 ? 0 : (unsigned char)(rand() % max);
|
||||
}
|
||||
|
||||
unsigned short rand_ushort(const unsigned int max) {
|
||||
return (unsigned short)(rand(seed++) * max);
|
||||
return max == 0 ? 0 : (unsigned short)(rand() % max);
|
||||
}
|
||||
|
||||
+1
-2
@@ -1,8 +1,7 @@
|
||||
#ifndef RAND_H
|
||||
#define RAND_H
|
||||
|
||||
void set_seed(unsigned long new_seed);
|
||||
float rand_float(const float max);
|
||||
void set_seed(unsigned long long seed);
|
||||
unsigned char rand_uchar(unsigned int max);
|
||||
unsigned short rand_ushort(unsigned int max);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user