add wildnoise cmd

This commit is contained in:
Luna 2019-07-13 19:55:57 -03:00
parent a993c1dc0e
commit a71ff830ac
5 changed files with 64 additions and 2 deletions

View file

@ -138,10 +138,12 @@ Parameters:
- `feedback`: Feedback, 0..1, default 0
- `xfade_samp`: Crossfade samples (int), 0..5000, default 1250
## `noise split index seed repeat_bytes`
## `wildnoise/noise split index seed repeat_bytes`
Inject random noise on the image.
the `wildnoise` version gives a harder version than `noise`.
Parameters:
- `seed`, Random seed
- `repeat_bytes`, Amount of bytes to preload with random data and repeat

View file

@ -1,5 +1,5 @@
load :0;
noise 5 1 3981 10000;
noise 5 2 3982 0;
wildnoise 5 2 3982 0;
noise 5 3 3982 5;
quicksave;

View file

@ -50,3 +50,47 @@ pub const RandomNoise = struct {
}
}
};
pub const WildNoise = struct {
r: std.rand.DefaultPrng,
rand_buf: ?[]f32,
cnt: usize = 0,
pub fn init(
allocator: *std.mem.Allocator,
params: *plugins.ParamMap,
) !WildNoise {
const seed = @floatToInt(u64, params.get("seed").?.value);
const fillbytes = @floatToInt(usize, params.get("fill_bytes").?.value);
var r = std.rand.DefaultPrng.init(seed);
if (fillbytes > 0) {
var rand_buf = try allocator.alloc(f32, fillbytes);
for (rand_buf) |_, idx| {
rand_buf[idx] = @intToFloat(f32, r.random.int(u1));
}
return WildNoise{
.r = r,
.rand_buf = rand_buf,
};
} else {
return WildNoise{
.r = r,
.rand_buf = null,
};
}
}
pub fn run(self: *WildNoise, bufs: *RunBuffers) void {
if (self.rand_buf) |rand_buf| {
if (self.cnt >= rand_buf.len) self.cnt = 0;
bufs.out[0] = rand_buf[self.cnt];
self.cnt += 1;
} else {
bufs.out[0] = @intToFloat(f32, self.r.random.int(u1));
}
}
};

View file

@ -27,6 +27,7 @@ pub const CommandType = enum {
Vinyl,
RevDelay,
Noise,
WildNoise,
};
pub const Command = struct {
@ -157,6 +158,7 @@ pub const Lang = struct {
// custom implementations (not lv2)
_ = try self.keywords.put("noise", .Noise);
_ = try self.keywords.put("wildnoise", .WildNoise);
}
pub fn parse(self: *Lang, data: []const u8) !CommandList {

View file

@ -252,6 +252,11 @@ pub const Runner = struct {
try image.runCustomPlugin(custom.RandomNoise, pos, map);
}
fn wildNoiseCmd(self: *Runner, pos: Position, map: *ParamMap) !void {
var image = try self.getImage();
try image.runCustomPlugin(custom.WildNoise, pos, map);
}
fn runCommand(self: *Runner, cmd: *lang.Command) !void {
var params = ParamList.init(self.allocator);
defer params.deinit();
@ -403,6 +408,15 @@ pub const Runner = struct {
try self.noiseCmd(pos, &map);
},
.WildNoise => blk: {
const pos = try cmd.consumePosition();
try cmd.appendParamMap(&map, "seed");
try cmd.appendParamMap(&map, "fill_bytes");
try self.wildNoiseCmd(pos, &map);
},
else => blk: {
std.debug.warn("Unsupported command: {}\n", cmd.command);
break :blk RunError.UnknownCommand;