From c7ae2bf121b6ba09b8e417ab088af9d00d300ee0 Mon Sep 17 00:00:00 2001 From: Benjamin Matuszewski Date: Fri, 5 Oct 2018 16:25:42 +0200 Subject: [PATCH] retranspiled --- client/ProcessedSensors.js | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/client/ProcessedSensors.js b/client/ProcessedSensors.js index 6ab86cf..5b7af07 100644 --- a/client/ProcessedSensors.js +++ b/client/ProcessedSensors.js @@ -11,9 +11,9 @@ * - Orientation X (processed from acc and gyro) * - Orientation Y (processed from acc and gyro) * - Orientation Z (processed from acc and gyro) - * - gyro alpha (yaw) - * - gyro beta (pitch) - * - gyro gamma (roll) + * - gyro alpha (yaw) - degrees / ms + * - gyro beta (pitch) - degrees / ms + * - gyro gamma (roll) - degrees / ms * * @example * import { ProcessedSensors } from 'iml-motion'; @@ -28,14 +28,15 @@ this.motionInput=new lfoMotion.source.MotionInput();this.sampler=new lfoMotion.o this.intensity=new lfoMotion.operator.Intensity({feedback:0.7,gain:0.07});this.intensityNormSelect=new lfo.operator.Select({index:0});// boost this.intensityClip=new lfo.operator.Clip({min:0,max:1});this.intensityPower=new lfo.operator.Power({exponent:0.25});this.powerClip=new lfo.operator.Clip({min:0.15,max:1});this.powerScale=new lfo.operator.Scale({inputMin:0.15,inputMax:1,outputMin:0,outputMax:1});// bandpass this.normalizeAcc=new lfo.operator.Multiplier({factor:1/9.81});this.bandpass=new lfo.operator.Biquad({type:'bandpass',q:1,f0:5});this.bandpassGain=new lfo.operator.Multiplier({factor:1});// orientation filter -this.orientation=new lfoMotion.operator.Orientation();// merge and output +this.orientation=new lfoMotion.operator.Orientation();// gyroscopes scaling +this.gyroScale=new lfo.operator.Multiplier({factor:[1/1000,1/1000,1/1000]});// merge and output this.merger=new lfo.operator.Merger({frameSizes:[1,1,3,3,3]});this.bridge=new lfo.sink.Bridge({processFrame:this._emit,finalizeStream:this._emit});this.motionInput.connect(this.sampler);// for intensity and bandpass this.sampler.connect(this.accSelect);// intensity branch this.accSelect.connect(this.intensity);this.intensity.connect(this.intensityNormSelect);this.intensityNormSelect.connect(this.merger);// boost branch this.intensityNormSelect.connect(this.intensityClip);this.intensityClip.connect(this.intensityPower);this.intensityPower.connect(this.powerClip);this.powerClip.connect(this.powerScale);this.powerScale.connect(this.merger);// biquad branch this.accSelect.connect(this.normalizeAcc);this.normalizeAcc.connect(this.bandpass);this.bandpass.connect(this.bandpassGain);this.bandpassGain.connect(this.merger);// orientation this.sampler.connect(this.orientation);this.orientation.connect(this.merger);// gyroscpes -this.sampler.connect(this.gyroSelect);this.gyroSelect.connect(this.merger);this.merger.connect(this.bridge);this._listeners=new _set2.default();}/** +this.sampler.connect(this.gyroSelect);this.gyroSelect.connect(this.gyroScale);this.gyroScale.connect(this.merger);this.merger.connect(this.bridge);this._listeners=new _set2.default();}/** * Initialize the sensors * @return Promise */(0,_createClass3.default)(ProcessedSensors,[{key:'init',value:function init(){// do not override frameRate with values from motionInput as @@ -55,4 +56,4 @@ return this.motionInput.init();}/** * * @param {ProcessedSensorsListener} callback - Listener to delete */},{key:'removeListener',value:function removeListener(callback){this._listeners.delete(callback);}/** @private */},{key:'_emit',value:function _emit(frame){this._listeners.forEach(function(listener){return listener(frame.data);});}}]);return ProcessedSensors;}();exports.default=ProcessedSensors; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["lfo","lfoMotion","ProcessedSensors","frameRate","_emit","bind","motionInput","source","MotionInput","sampler","operator","Sampler","accSelect","Select","indexes","gyroSelect","intensity","Intensity","feedback","gain","intensityNormSelect","index","intensityClip","Clip","min","max","intensityPower","Power","exponent","powerClip","powerScale","Scale","inputMin","inputMax","outputMin","outputMax","normalizeAcc","Multiplier","factor","bandpass","Biquad","type","q","f0","bandpassGain","orientation","Orientation","merger","Merger","frameSizes","bridge","sink","Bridge","processFrame","finalizeStream","connect","_listeners","init","start","stop","callback","add","delete","frame","forEach","listener","data"],"mappings":"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","file":"index.js","sourcesContent":["import * as lfo from 'waves-lfo/client';\nimport * as lfoMotion from 'lfo-motion';\n\n/**\n * High-level abstraction that listen for raw sensors (accelerometers and\n * gyroscopes) and apply a set of preprocessing / filtering on it.\n *\n * The output is composed of 11 values:\n * - IntensityNorm\n * - IntensityNormBoost\n * - BandPass AccX\n * - BandPass AccY\n * - BandPass AccZ\n * - Orientation X (processed from acc and gyro)\n * - Orientation Y (processed from acc and gyro)\n * - Orientation Z (processed from acc and gyro)\n * - gyro alpha (yaw)\n * - gyro beta (pitch)\n * - gyro gamma (roll)\n *\n * @example\n * import { ProcessedSensors } from 'iml-motion';\n *\n * const processedSensors = new ProcessedSensors();\n * processedSensors.addListener(data => console.log(data));\n * processedSensors\n *  .init()\n *  .then(() => processedSensors.start());\n */\nclass ProcessedSensors {\n  constructor({\n    frameRate = 1 / 0.02,\n  } = {}) {\n    this.frameRate = frameRate;\n\n    this._emit = this._emit.bind(this);\n\n    // create the lfo graph\n    this.motionInput = new lfoMotion.source.MotionInput();\n\n    this.sampler = new lfoMotion.operator.Sampler({\n      frameRate: frameRate,\n    });\n\n    this.accSelect = new lfo.operator.Select({ indexes: [0, 1, 2] });\n    this.gyroSelect = new lfo.operator.Select({ indexes: [3, 4, 5] });\n\n    // intensity\n    this.intensity = new lfoMotion.operator.Intensity({\n      feedback: 0.7,\n      gain: 0.07,\n    });\n\n    this.intensityNormSelect = new lfo.operator.Select({ index: 0 });\n\n    // boost\n    this.intensityClip = new lfo.operator.Clip({ min: 0, max: 1 });\n    this.intensityPower = new lfo.operator.Power({ exponent: 0.25 });\n    this.powerClip = new lfo.operator.Clip({ min: 0.15, max: 1 });\n    this.powerScale = new lfo.operator.Scale({\n      inputMin: 0.15,\n      inputMax: 1,\n      outputMin: 0,\n      outputMax: 1,\n    });\n\n    // bandpass\n    this.normalizeAcc = new lfo.operator.Multiplier({ factor: 1 / 9.81 });\n    this.bandpass = new lfo.operator.Biquad({\n      type: 'bandpass',\n      q: 1,\n      f0: 5,\n    });\n    this.bandpassGain = new lfo.operator.Multiplier({ factor: 1 });\n\n    // orientation filter\n    this.orientation = new lfoMotion.operator.Orientation();\n\n    // merge and output\n    this.merger = new lfo.operator.Merger({\n      frameSizes: [1, 1, 3, 3, 3],\n    });\n\n    this.bridge = new lfo.sink.Bridge({\n      processFrame: this._emit,\n      finalizeStream: this._emit,\n    });\n\n    this.motionInput.connect(this.sampler);\n    // for intensity and bandpass\n    this.sampler.connect(this.accSelect);\n    // intensity branch\n    this.accSelect.connect(this.intensity);\n    this.intensity.connect(this.intensityNormSelect);\n    this.intensityNormSelect.connect(this.merger);\n    // boost branch\n    this.intensityNormSelect.connect(this.intensityClip);\n    this.intensityClip.connect(this.intensityPower);\n    this.intensityPower.connect(this.powerClip);\n    this.powerClip.connect(this.powerScale);\n    this.powerScale.connect(this.merger);\n    // biquad branch\n    this.accSelect.connect(this.normalizeAcc);\n    this.normalizeAcc.connect(this.bandpass);\n    this.bandpass.connect(this.bandpassGain);\n    this.bandpassGain.connect(this.merger);\n    // orientation\n    this.sampler.connect(this.orientation);\n    this.orientation.connect(this.merger);\n    // gyroscpes\n    this.sampler.connect(this.gyroSelect);\n    this.gyroSelect.connect(this.merger);\n\n    this.merger.connect(this.bridge);\n\n    this._listeners = new Set();\n  }\n\n  /**\n   * Initialize the sensors\n   * @return Promise\n   */\n  init() {\n    // do not override frameRate with values from motionInput as\n    // we resampler overrides the source sampleRate, cf. `constructor`\n    return this.motionInput.init();\n  }\n\n  /**\n   * Start listening to the sensors\n   */\n  start() {\n    this.motionInput.start();\n  }\n\n  /**\n   * Stop listening to the sensors\n   */\n  stop() {\n    this.motionInput.stop();\n  }\n\n  /**\n   * Add a listener to the module.\n   *\n   * @param {ProcessedSensorsListener} callback - Listener to register, the\n   *  callback is executed with an array containing the processed data from\n   *  the sensors\n   */\n  addListener(callback) {\n    this._listeners.add(callback);\n  }\n\n  /**\n   * Remove a listener from the module.\n   *\n   * @param {ProcessedSensorsListener} callback - Listener to delete\n   */\n  removeListener(callback) {\n    this._listeners.delete(callback);\n  }\n\n  /** @private */\n  _emit(frame) {\n    this._listeners.forEach(listener => listener(frame.data));\n  }\n\n}\n\nexport default ProcessedSensors;\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["lfo","lfoMotion","ProcessedSensors","frameRate","_emit","bind","motionInput","source","MotionInput","sampler","operator","Sampler","accSelect","Select","indexes","gyroSelect","intensity","Intensity","feedback","gain","intensityNormSelect","index","intensityClip","Clip","min","max","intensityPower","Power","exponent","powerClip","powerScale","Scale","inputMin","inputMax","outputMin","outputMax","normalizeAcc","Multiplier","factor","bandpass","Biquad","type","q","f0","bandpassGain","orientation","Orientation","gyroScale","merger","Merger","frameSizes","bridge","sink","Bridge","processFrame","finalizeStream","connect","_listeners","init","start","stop","callback","add","delete","frame","forEach","listener","data"],"mappings":"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","file":"index.js","sourcesContent":["import * as lfo from 'waves-lfo/client';\nimport * as lfoMotion from 'lfo-motion';\n\n/**\n * High-level abstraction that listen for raw sensors (accelerometers and\n * gyroscopes) and apply a set of preprocessing / filtering on it.\n *\n * The output is composed of 11 values:\n * - IntensityNorm\n * - IntensityNormBoost\n * - BandPass AccX\n * - BandPass AccY\n * - BandPass AccZ\n * - Orientation X (processed from acc and gyro)\n * - Orientation Y (processed from acc and gyro)\n * - Orientation Z (processed from acc and gyro)\n * - gyro alpha (yaw) - degrees / ms\n * - gyro beta (pitch) - degrees / ms\n * - gyro gamma (roll) - degrees / ms\n *\n * @example\n * import { ProcessedSensors } from 'iml-motion';\n *\n * const processedSensors = new ProcessedSensors();\n * processedSensors.addListener(data => console.log(data));\n * processedSensors\n *  .init()\n *  .then(() => processedSensors.start());\n */\nclass ProcessedSensors {\n  constructor({\n    frameRate = 1 / 0.02,\n  } = {}) {\n    this.frameRate = frameRate;\n\n    this._emit = this._emit.bind(this);\n\n    // create the lfo graph\n    this.motionInput = new lfoMotion.source.MotionInput();\n\n    this.sampler = new lfoMotion.operator.Sampler({\n      frameRate: frameRate,\n    });\n\n    this.accSelect = new lfo.operator.Select({ indexes: [0, 1, 2] });\n    this.gyroSelect = new lfo.operator.Select({ indexes: [3, 4, 5] });\n\n    // intensity\n    this.intensity = new lfoMotion.operator.Intensity({\n      feedback: 0.7,\n      gain: 0.07,\n    });\n\n    this.intensityNormSelect = new lfo.operator.Select({ index: 0 });\n\n    // boost\n    this.intensityClip = new lfo.operator.Clip({ min: 0, max: 1 });\n    this.intensityPower = new lfo.operator.Power({ exponent: 0.25 });\n    this.powerClip = new lfo.operator.Clip({ min: 0.15, max: 1 });\n    this.powerScale = new lfo.operator.Scale({\n      inputMin: 0.15,\n      inputMax: 1,\n      outputMin: 0,\n      outputMax: 1,\n    });\n\n    // bandpass\n    this.normalizeAcc = new lfo.operator.Multiplier({ factor: 1 / 9.81 });\n    this.bandpass = new lfo.operator.Biquad({\n      type: 'bandpass',\n      q: 1,\n      f0: 5,\n    });\n    this.bandpassGain = new lfo.operator.Multiplier({ factor: 1 });\n\n    // orientation filter\n    this.orientation = new lfoMotion.operator.Orientation();\n\n    // gyroscopes scaling\n    this.gyroScale = new lfo.operator.Multiplier({\n      factor: [1/1000, 1/1000, 1/1000],\n    });\n\n    // merge and output\n    this.merger = new lfo.operator.Merger({\n      frameSizes: [1, 1, 3, 3, 3],\n    });\n\n    this.bridge = new lfo.sink.Bridge({\n      processFrame: this._emit,\n      finalizeStream: this._emit,\n    });\n\n    this.motionInput.connect(this.sampler);\n    // for intensity and bandpass\n    this.sampler.connect(this.accSelect);\n    // intensity branch\n    this.accSelect.connect(this.intensity);\n    this.intensity.connect(this.intensityNormSelect);\n    this.intensityNormSelect.connect(this.merger);\n    // boost branch\n    this.intensityNormSelect.connect(this.intensityClip);\n    this.intensityClip.connect(this.intensityPower);\n    this.intensityPower.connect(this.powerClip);\n    this.powerClip.connect(this.powerScale);\n    this.powerScale.connect(this.merger);\n    // biquad branch\n    this.accSelect.connect(this.normalizeAcc);\n    this.normalizeAcc.connect(this.bandpass);\n    this.bandpass.connect(this.bandpassGain);\n    this.bandpassGain.connect(this.merger);\n    // orientation\n    this.sampler.connect(this.orientation);\n    this.orientation.connect(this.merger);\n    // gyroscpes\n    this.sampler.connect(this.gyroSelect);\n    this.gyroSelect.connect(this.gyroScale);\n    this.gyroScale.connect(this.merger);\n\n    this.merger.connect(this.bridge);\n\n    this._listeners = new Set();\n  }\n\n  /**\n   * Initialize the sensors\n   * @return Promise\n   */\n  init() {\n    // do not override frameRate with values from motionInput as\n    // we resampler overrides the source sampleRate, cf. `constructor`\n    return this.motionInput.init();\n  }\n\n  /**\n   * Start listening to the sensors\n   */\n  start() {\n    this.motionInput.start();\n  }\n\n  /**\n   * Stop listening to the sensors\n   */\n  stop() {\n    this.motionInput.stop();\n  }\n\n  /**\n   * Add a listener to the module.\n   *\n   * @param {ProcessedSensorsListener} callback - Listener to register, the\n   *  callback is executed with an array containing the processed data from\n   *  the sensors\n   */\n  addListener(callback) {\n    this._listeners.add(callback);\n  }\n\n  /**\n   * Remove a listener from the module.\n   *\n   * @param {ProcessedSensorsListener} callback - Listener to delete\n   */\n  removeListener(callback) {\n    this._listeners.delete(callback);\n  }\n\n  /** @private */\n  _emit(frame) {\n    this._listeners.forEach(listener => listener(frame.data));\n  }\n\n}\n\nexport default ProcessedSensors;\n"]} \ No newline at end of file