elektron-lfo 1.0.2 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -66,14 +66,14 @@ function generateSquare(phase) {
66
66
  return phase < 0.5 ? 1 : -1;
67
67
  }
68
68
  function generateSawtooth(phase) {
69
- return phase * 2 - 1;
69
+ return 1 - phase * 2;
70
70
  }
71
71
  function generateExponential(phase) {
72
72
  const k = 4;
73
73
  return (Math.exp(phase * k) - 1) / (Math.exp(k) - 1);
74
74
  }
75
75
  function generateRamp(phase) {
76
- return 1 - phase;
76
+ return phase;
77
77
  }
78
78
  function generateRandom(phase, state) {
79
79
  const stepsPerCycle = 16;
@@ -283,7 +283,15 @@ function checkModeStop(config, state, previousPhase, currentPhase) {
283
283
  const isForward = config.speed >= 0;
284
284
  if (config.mode === "ONE") {
285
285
  if (state.cycleCount >= 1) {
286
- return { shouldStop: true, cycleCompleted: true };
286
+ if (isForward) {
287
+ if (startPhase === 0 || currentPhase >= startPhase) {
288
+ return { shouldStop: true, cycleCompleted: true };
289
+ }
290
+ } else {
291
+ if (startPhase === 0 || currentPhase <= startPhase) {
292
+ return { shouldStop: true, cycleCompleted: true };
293
+ }
294
+ }
287
295
  }
288
296
  } else if (config.mode === "HLF") {
289
297
  const halfPhase = (startPhase + 0.5) % 1;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "elektron-lfo",
3
- "version": "1.0.2",
3
+ "version": "1.0.4",
4
4
  "description": "Elektron LFO engine simulator implementation with CLI visualization",
5
5
  "main": "dist/index.js",
6
6
  "module": "src/index.ts",
@@ -40,10 +40,10 @@ export function generateSquare(phase: number): number {
40
40
 
41
41
  /**
42
42
  * Sawtooth waveform - Bipolar
43
- * Linear rise from -1 to +1
43
+ * Linear fall from +1 to -1 (with positive depth)
44
44
  */
45
45
  export function generateSawtooth(phase: number): number {
46
- return phase * 2 - 1;
46
+ return 1 - phase * 2;
47
47
  }
48
48
 
49
49
  /**
@@ -57,10 +57,10 @@ export function generateExponential(phase: number): number {
57
57
 
58
58
  /**
59
59
  * Ramp waveform - Unipolar (0 to +1)
60
- * Linear fall from +1 to 0
60
+ * Linear rise from 0 to +1
61
61
  */
62
62
  export function generateRamp(phase: number): number {
63
- return 1 - phase;
63
+ return phase;
64
64
  }
65
65
 
66
66
  /**
@@ -123,22 +123,22 @@ describe('Square Waveform', () => {
123
123
  });
124
124
 
125
125
  describe('Sawtooth Waveform', () => {
126
- test('starts at -1 at phase 0', () => {
127
- expect(generateSawtooth(0)).toBe(-1);
126
+ test('starts at +1 at phase 0', () => {
127
+ expect(generateSawtooth(0)).toBe(1);
128
128
  });
129
129
 
130
130
  test('is 0 at phase 0.5', () => {
131
131
  expect(generateSawtooth(0.5)).toBe(0);
132
132
  });
133
133
 
134
- test('approaches +1 at phase ~1', () => {
135
- expect(generateSawtooth(1)).toBe(1);
136
- expect(generateSawtooth(0.999)).toBeCloseTo(1, 2);
134
+ test('approaches -1 at phase ~1', () => {
135
+ expect(generateSawtooth(1)).toBe(-1);
136
+ expect(generateSawtooth(0.999)).toBeCloseTo(-1, 2);
137
137
  });
138
138
 
139
- test('is bipolar and linear', () => {
140
- expect(generateSawtooth(0.25)).toBeCloseTo(-0.5, 5);
141
- expect(generateSawtooth(0.75)).toBeCloseTo(0.5, 5);
139
+ test('is bipolar and linear (falling)', () => {
140
+ expect(generateSawtooth(0.25)).toBeCloseTo(0.5, 5);
141
+ expect(generateSawtooth(0.75)).toBeCloseTo(-0.5, 5);
142
142
  });
143
143
  });
144
144
 
@@ -165,12 +165,12 @@ describe('Exponential Waveform', () => {
165
165
  });
166
166
 
167
167
  describe('Ramp Waveform', () => {
168
- test('starts at 1 at phase 0', () => {
169
- expect(generateRamp(0)).toBe(1);
168
+ test('starts at 0 at phase 0', () => {
169
+ expect(generateRamp(0)).toBe(0);
170
170
  });
171
171
 
172
- test('ends at 0 at phase 1', () => {
173
- expect(generateRamp(1)).toBe(0);
172
+ test('ends at 1 at phase 1', () => {
173
+ expect(generateRamp(1)).toBe(1);
174
174
  });
175
175
 
176
176
  test('is 0.5 at phase 0.5', () => {
@@ -183,9 +183,9 @@ describe('Ramp Waveform', () => {
183
183
  expect(Math.max(...samples)).toBeLessThanOrEqual(1);
184
184
  });
185
185
 
186
- test('is linear', () => {
187
- expect(generateRamp(0.25)).toBe(0.75);
188
- expect(generateRamp(0.75)).toBe(0.25);
186
+ test('is linear (rising)', () => {
187
+ expect(generateRamp(0.25)).toBe(0.25);
188
+ expect(generateRamp(0.75)).toBe(0.75);
189
189
  });
190
190
  });
191
191
 
@@ -238,7 +238,7 @@ describe('generateWaveform', () => {
238
238
  expect(generateWaveform('SQR', 0.25, state).value).toBe(1);
239
239
  expect(generateWaveform('SAW', 0.5, state).value).toBe(0);
240
240
  expect(generateWaveform('EXP', 1, state).value).toBeCloseTo(1, 5);
241
- expect(generateWaveform('RMP', 0, state).value).toBe(1);
241
+ expect(generateWaveform('RMP', 0, state).value).toBe(0);
242
242
  });
243
243
  });
244
244