New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@d3fc/d3fc-random-data

Package Overview
Dependencies
Maintainers
3
Versions
24
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@d3fc/d3fc-random-data - npm Package Compare versions

Comparing version 3.0.17 to 3.0.18

build/d3fc-random-data.min.js

544

build/d3fc-random-data.js
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('d3-random'), require('d3-time')) :
typeof define === 'function' && define.amd ? define(['exports', 'd3-random', 'd3-time'], factory) :
(global = global || self, factory(global.fc = global.fc || {}, global.d3, global.d3));
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('d3-random'), require('d3-time')) :
typeof define === 'function' && define.amd ? define(['exports', 'd3-random', 'd3-time'], factory) :
(global = global || self, factory(global.fc = global.fc || {}, global.d3, global.d3));
}(this, function (exports, d3Random, d3Time) { 'use strict';
function geometricBrownianMotion () {
var period = 1;
var steps = 20;
var mu = 0.1;
var sigma = 0.1;
var random = d3Random.randomNormal();
function _typeof(obj) {
if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
_typeof = function (obj) {
return typeof obj;
};
} else {
_typeof = function (obj) {
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
};
}
var geometricBrownianMotion = function geometricBrownianMotion() {
var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
return _typeof(obj);
}
var timeStep = period / steps;
var pathData = [];
function geometricBrownianMotion () {
var period = 1;
var steps = 20;
var mu = 0.1;
var sigma = 0.1;
var random = d3Random.randomNormal();
for (var i = 0; i < steps + 1; i++) {
pathData.push(value);
var increment = random() * Math.sqrt(timeStep) * sigma + (mu - sigma * sigma / 2) * timeStep;
value = value * Math.exp(increment);
}
var geometricBrownianMotion = function geometricBrownianMotion() {
var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
var timeStep = period / steps;
var pathData = [];
return pathData;
};
for (var i = 0; i < steps + 1; i++) {
pathData.push(value);
var increment = random() * Math.sqrt(timeStep) * sigma + (mu - sigma * sigma / 2) * timeStep;
value = value * Math.exp(increment);
}
geometricBrownianMotion.period = function () {
if (!arguments.length) {
return period;
}
period = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
return pathData;
};
geometricBrownianMotion.steps = function () {
if (!arguments.length) {
return steps;
}
steps = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
geometricBrownianMotion.period = function () {
if (!arguments.length) {
return period;
}
geometricBrownianMotion.mu = function () {
if (!arguments.length) {
return mu;
}
mu = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
period = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
geometricBrownianMotion.sigma = function () {
if (!arguments.length) {
return sigma;
}
sigma = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
geometricBrownianMotion.steps = function () {
if (!arguments.length) {
return steps;
}
geometricBrownianMotion.random = function () {
if (!arguments.length) {
return random;
}
random = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
steps = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
return geometricBrownianMotion;
}
geometricBrownianMotion.mu = function () {
if (!arguments.length) {
return mu;
}
var createReboundMethod = (function (target, source, name) {
var method = source[name];
if (typeof method !== 'function') {
throw new Error('Attempt to rebind ' + name + ' which isn\'t a function on the source object');
}
return function () {
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
mu = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
var value = method.apply(source, args);
return value === source ? target : value;
};
});
geometricBrownianMotion.sigma = function () {
if (!arguments.length) {
return sigma;
}
var createTransform = function createTransform(transforms) {
return function (name) {
return transforms.reduce(function (name, fn) {
return name && fn(name);
}, name);
};
sigma = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
var rebindAll = (function (target, source) {
for (var _len = arguments.length, transforms = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
transforms[_key - 2] = arguments[_key];
}
geometricBrownianMotion.random = function () {
if (!arguments.length) {
return random;
}
var transform = createTransform(transforms);
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
random = arguments.length <= 0 ? undefined : arguments[0];
return geometricBrownianMotion;
};
try {
for (var _iterator = Object.keys(source)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
var name = _step.value;
return geometricBrownianMotion;
}
var result = transform(name);
if (result) {
target[result] = createReboundMethod(target, source, name);
}
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator.return) {
_iterator.return();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
var createReboundMethod = ((target, source, name) => {
const method = source[name];
return target;
});
if (typeof method !== 'function') {
throw new Error(`Attempt to rebind ${name} which isn't a function on the source object`);
}
function functor(v) {
return typeof v === 'function' ? v : function () {
return v;
};
return (...args) => {
var value = method.apply(source, args);
return value === source ? target : value;
};
});
const createTransform = transforms => name => transforms.reduce((name, fn) => name && fn(name), name);
var rebindAll = ((target, source, ...transforms) => {
const transform = createTransform(transforms);
for (const name of Object.keys(source)) {
const result = transform(name);
if (result) {
target[result] = createReboundMethod(target, source, name);
}
}
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) {
return typeof obj;
} : function (obj) {
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
return target;
});
function functor(v) {
return typeof v === 'function' ? v : function () {
return v;
};
}
function financial () {
var startDate = new Date();
var startPrice = 100;
var interval = d3Time.timeDay;
var intervalStep = 1;
var unitInterval = d3Time.timeYear;
var unitIntervalStep = 1;
var filter = null;
var volume = function volume() {
var normal = d3Random.randomNormal(1, 0.1);
return Math.ceil(normal() * 1000);
};
var gbm = geometricBrownianMotion();
function financial () {
var startDate = new Date();
var startPrice = 100;
var interval = d3Time.timeDay;
var intervalStep = 1;
var unitInterval = d3Time.timeYear;
var unitIntervalStep = 1;
var filter = null;
var getOffsetPeriod = function getOffsetPeriod(date) {
var unitMilliseconds = unitInterval.offset(date, unitIntervalStep) - date;
return (interval.offset(date, intervalStep) - date) / unitMilliseconds;
};
var volume = function volume() {
var normal = d3Random.randomNormal(1, 0.1);
return Math.ceil(normal() * 1000);
};
var calculateOHLC = function calculateOHLC(start, price) {
var period = getOffsetPeriod(start);
var prices = gbm.period(period)(price);
var ohlc = {
date: start,
open: prices[0],
high: Math.max.apply(Math, prices),
low: Math.min.apply(Math, prices),
close: prices[gbm.steps()]
};
ohlc.volume = volume(ohlc);
return ohlc;
};
var gbm = geometricBrownianMotion();
var getNextDatum = function getNextDatum(ohlc) {
var date = void 0,
price = void 0,
filtered = void 0;
do {
date = ohlc ? interval.offset(ohlc.date, intervalStep) : new Date(startDate.getTime());
price = ohlc ? ohlc.close : startPrice;
ohlc = calculateOHLC(date, price);
filtered = filter && !filter(ohlc);
} while (filtered);
return ohlc;
};
var getOffsetPeriod = function getOffsetPeriod(date) {
var unitMilliseconds = unitInterval.offset(date, unitIntervalStep) - date;
return (interval.offset(date, intervalStep) - date) / unitMilliseconds;
};
var makeStream = function makeStream() {
var latest = void 0;
var stream = {};
stream.next = function () {
var ohlc = getNextDatum(latest);
latest = ohlc;
return ohlc;
};
stream.take = function (numPoints) {
return stream.until(function (d, i) {
return !numPoints || numPoints < 0 || i === numPoints;
});
};
stream.until = function (comparison) {
var data = [];
var index = 0;
var ohlc = getNextDatum(latest);
var compared = comparison && !comparison(ohlc, index);
while (compared) {
data.push(ohlc);
latest = ohlc;
ohlc = getNextDatum(latest);
index += 1;
compared = comparison && !comparison(ohlc, index);
}
return data;
};
return stream;
};
var calculateOHLC = function calculateOHLC(start, price) {
var period = getOffsetPeriod(start);
var prices = gbm.period(period)(price);
var ohlc = {
date: start,
open: prices[0],
high: Math.max.apply(Math, prices),
low: Math.min.apply(Math, prices),
close: prices[gbm.steps()]
};
ohlc.volume = volume(ohlc);
return ohlc;
};
var financial = function financial(numPoints) {
return makeStream().take(numPoints);
};
financial.stream = makeStream;
var getNextDatum = function getNextDatum(ohlc) {
var date, price, filtered;
if (typeof Symbol !== 'function' || _typeof(Symbol.iterator) !== 'symbol') {
throw new Error('d3fc-random-data depends on Symbol. Make sure that you load a polyfill in older browsers. See README.');
do {
date = ohlc ? interval.offset(ohlc.date, intervalStep) : new Date(startDate.getTime());
price = ohlc ? ohlc.close : startPrice;
ohlc = calculateOHLC(date, price);
filtered = filter && !filter(ohlc);
} while (filtered);
return ohlc;
};
var makeStream = function makeStream() {
var latest;
var stream = {};
stream.next = function () {
var ohlc = getNextDatum(latest);
latest = ohlc;
return ohlc;
};
stream.take = function (numPoints) {
return stream.until(function (d, i) {
return !numPoints || numPoints < 0 || i === numPoints;
});
};
stream.until = function (comparison) {
var data = [];
var index = 0;
var ohlc = getNextDatum(latest);
var compared = comparison && !comparison(ohlc, index);
while (compared) {
data.push(ohlc);
latest = ohlc;
ohlc = getNextDatum(latest);
index += 1;
compared = comparison && !comparison(ohlc, index);
}
financial[Symbol.iterator] = function () {
var stream = makeStream();
return {
next: function next() {
return {
value: stream.next(),
done: false
};
}
};
};
return data;
};
financial.startDate = function () {
if (!arguments.length) {
return startDate;
}
startDate = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.startPrice = function () {
if (!arguments.length) {
return startPrice;
}
startPrice = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.interval = function () {
if (!arguments.length) {
return interval;
}
interval = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.intervalStep = function () {
if (!arguments.length) {
return intervalStep;
}
intervalStep = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.unitInterval = function () {
if (!arguments.length) {
return unitInterval;
}
unitInterval = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.unitIntervalStep = function () {
if (!arguments.length) {
return unitIntervalStep;
}
unitIntervalStep = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.filter = function () {
if (!arguments.length) {
return filter;
}
filter = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.volume = function () {
if (!arguments.length) {
return volume;
}
volume = functor(arguments.length <= 0 ? undefined : arguments[0]);
return financial;
};
return stream;
};
rebindAll(financial, gbm);
var financial = function financial(numPoints) {
return makeStream().take(numPoints);
};
return financial;
}
financial.stream = makeStream;
function skipWeekends (datum) {
var day = datum.date.getDay();
return !(day === 0 || day === 6);
if (typeof Symbol !== 'function' || _typeof(Symbol.iterator) !== 'symbol') {
throw new Error('d3fc-random-data depends on Symbol. Make sure that you load a polyfill in older browsers. See README.');
}
exports.randomFinancial = financial;
exports.randomGeometricBrownianMotion = geometricBrownianMotion;
exports.randomSkipWeekends = skipWeekends;
financial[Symbol.iterator] = function () {
var stream = makeStream();
return {
next: function next() {
return {
value: stream.next(),
done: false
};
}
};
};
Object.defineProperty(exports, '__esModule', { value: true });
financial.startDate = function () {
if (!arguments.length) {
return startDate;
}
startDate = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.startPrice = function () {
if (!arguments.length) {
return startPrice;
}
startPrice = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.interval = function () {
if (!arguments.length) {
return interval;
}
interval = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.intervalStep = function () {
if (!arguments.length) {
return intervalStep;
}
intervalStep = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.unitInterval = function () {
if (!arguments.length) {
return unitInterval;
}
unitInterval = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.unitIntervalStep = function () {
if (!arguments.length) {
return unitIntervalStep;
}
unitIntervalStep = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.filter = function () {
if (!arguments.length) {
return filter;
}
filter = arguments.length <= 0 ? undefined : arguments[0];
return financial;
};
financial.volume = function () {
if (!arguments.length) {
return volume;
}
volume = functor(arguments.length <= 0 ? undefined : arguments[0]);
return financial;
};
rebindAll(financial, gbm);
return financial;
}
function skipWeekends (datum) {
var day = datum.date.getDay();
return !(day === 0 || day === 6);
}
exports.randomFinancial = financial;
exports.randomGeometricBrownianMotion = geometricBrownianMotion;
exports.randomSkipWeekends = skipWeekends;
Object.defineProperty(exports, '__esModule', { value: true });
}));

@@ -6,2 +6,10 @@ # Change Log

## [3.0.18](https://github.com/d3fc/d3fc/compare/@d3fc/d3fc-random-data@3.0.17...@d3fc/d3fc-random-data@3.0.18) (2019-09-04)
**Note:** Version bump only for package @d3fc/d3fc-random-data
<a name="3.0.17"></a>

@@ -8,0 +16,0 @@ ## [3.0.17](https://github.com/d3fc/d3fc/compare/@d3fc/d3fc-random-data@3.0.16...@d3fc/d3fc-random-data@3.0.17) (2019-08-14)

{
"name": "@d3fc/d3fc-random-data",
"version": "3.0.17",
"version": "3.0.18",
"description": "Components for generating random data series based on stochastic processes",

@@ -32,3 +32,3 @@ "license": "MIT",

"dependencies": {
"@d3fc/d3fc-rebind": "^5.0.8",
"@d3fc/d3fc-rebind": "^5.0.9",
"d3-random": "^1.0.0",

@@ -39,3 +39,4 @@ "d3-time": "^1.0.0"

"access": "public"
}
},
"gitHead": "d216bebca76b9bde7456f1c06e768bc67814dd2e"
}

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc