@xyo-network/crypto-nft-collection-witness-plugin 2.75.15 → 2.75.17
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/docs.json +16 -16
- package/package.json +15 -15
- package/dist/browser/Plugin.cjs +0 -199
- package/dist/browser/Plugin.cjs.map +0 -1
- package/dist/browser/Plugin.js +0 -182
- package/dist/browser/Plugin.js.map +0 -1
- package/dist/browser/Witness.cjs +0 -183
- package/dist/browser/Witness.cjs.map +0 -1
- package/dist/browser/Witness.js +0 -166
- package/dist/browser/Witness.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/getNftCollectionMetrics.cjs +0 -83
- package/dist/browser/lib/collectionMetrics/getNftCollectionMetrics.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/getNftCollectionMetrics.js +0 -60
- package/dist/browser/lib/collectionMetrics/getNftCollectionMetrics.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/index.cjs +0 -83
- package/dist/browser/lib/collectionMetrics/index.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/index.js +0 -60
- package/dist/browser/lib/collectionMetrics/index.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.cjs +0 -49
- package/dist/browser/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.js +0 -28
- package/dist/browser/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/calculatePropertyDistribution.cjs +0 -45
- package/dist/browser/lib/collectionMetrics/lib/calculatePropertyDistribution.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/calculatePropertyDistribution.js +0 -24
- package/dist/browser/lib/collectionMetrics/lib/calculatePropertyDistribution.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/distribution.cjs +0 -19
- package/dist/browser/lib/collectionMetrics/lib/distribution.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/distribution.js +0 -1
- package/dist/browser/lib/collectionMetrics/lib/distribution.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/index.cjs +0 -72
- package/dist/browser/lib/collectionMetrics/lib/index.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/index.js +0 -49
- package/dist/browser/lib/collectionMetrics/lib/index.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.cjs +0 -35
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.js +0 -14
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.cjs +0 -32
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.js +0 -11
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.cjs +0 -46
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.js +0 -23
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.js.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/index.cjs +0 -46
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/index.cjs.map +0 -1
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/index.js +0 -23
- package/dist/browser/lib/collectionMetrics/lib/probabilityDistributions/index.js.map +0 -1
- package/dist/browser/lib/getNftCollectionCount.cjs +0 -44
- package/dist/browser/lib/getNftCollectionCount.cjs.map +0 -1
- package/dist/browser/lib/getNftCollectionCount.js +0 -23
- package/dist/browser/lib/getNftCollectionCount.js.map +0 -1
- package/dist/browser/lib/getNftCollectionMetadata.cjs +0 -46
- package/dist/browser/lib/getNftCollectionMetadata.cjs.map +0 -1
- package/dist/browser/lib/getNftCollectionMetadata.js +0 -25
- package/dist/browser/lib/getNftCollectionMetadata.js.map +0 -1
- package/dist/browser/lib/getNftCollectionNfts.cjs +0 -60
- package/dist/browser/lib/getNftCollectionNfts.cjs.map +0 -1
- package/dist/browser/lib/getNftCollectionNfts.js +0 -39
- package/dist/browser/lib/getNftCollectionNfts.js.map +0 -1
- package/dist/browser/lib/index.cjs +0 -148
- package/dist/browser/lib/index.cjs.map +0 -1
- package/dist/browser/lib/index.js +0 -125
- package/dist/browser/lib/index.js.map +0 -1
- package/dist/browser/lib/nonEvaluableContractAddresses.cjs +0 -30
- package/dist/browser/lib/nonEvaluableContractAddresses.cjs.map +0 -1
- package/dist/browser/lib/nonEvaluableContractAddresses.js +0 -9
- package/dist/browser/lib/nonEvaluableContractAddresses.js.map +0 -1
- package/dist/node/Plugin.js +0 -206
- package/dist/node/Plugin.js.map +0 -1
- package/dist/node/Plugin.mjs +0 -185
- package/dist/node/Plugin.mjs.map +0 -1
- package/dist/node/Witness.js +0 -190
- package/dist/node/Witness.js.map +0 -1
- package/dist/node/Witness.mjs +0 -169
- package/dist/node/Witness.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/getNftCollectionMetrics.js +0 -90
- package/dist/node/lib/collectionMetrics/getNftCollectionMetrics.js.map +0 -1
- package/dist/node/lib/collectionMetrics/getNftCollectionMetrics.mjs +0 -63
- package/dist/node/lib/collectionMetrics/getNftCollectionMetrics.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/index.js +0 -90
- package/dist/node/lib/collectionMetrics/index.js.map +0 -1
- package/dist/node/lib/collectionMetrics/index.mjs +0 -63
- package/dist/node/lib/collectionMetrics/index.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.js +0 -53
- package/dist/node/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.js.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.mjs +0 -28
- package/dist/node/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/calculatePropertyDistribution.js +0 -49
- package/dist/node/lib/collectionMetrics/lib/calculatePropertyDistribution.js.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/calculatePropertyDistribution.mjs +0 -24
- package/dist/node/lib/collectionMetrics/lib/calculatePropertyDistribution.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/distribution.js +0 -19
- package/dist/node/lib/collectionMetrics/lib/distribution.js.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/distribution.mjs +0 -1
- package/dist/node/lib/collectionMetrics/lib/distribution.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/index.js +0 -78
- package/dist/node/lib/collectionMetrics/lib/index.js.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/index.mjs +0 -49
- package/dist/node/lib/collectionMetrics/lib/index.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.js +0 -39
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.js.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.mjs +0 -14
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.js +0 -36
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.js.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.mjs +0 -11
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.js +0 -51
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.js.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.mjs +0 -23
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/binomial/index.mjs.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/index.js +0 -51
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/index.js.map +0 -1
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/index.mjs +0 -23
- package/dist/node/lib/collectionMetrics/lib/probabilityDistributions/index.mjs.map +0 -1
- package/dist/node/lib/getNftCollectionCount.js +0 -48
- package/dist/node/lib/getNftCollectionCount.js.map +0 -1
- package/dist/node/lib/getNftCollectionCount.mjs +0 -23
- package/dist/node/lib/getNftCollectionCount.mjs.map +0 -1
- package/dist/node/lib/getNftCollectionMetadata.js +0 -50
- package/dist/node/lib/getNftCollectionMetadata.js.map +0 -1
- package/dist/node/lib/getNftCollectionMetadata.mjs +0 -25
- package/dist/node/lib/getNftCollectionMetadata.mjs.map +0 -1
- package/dist/node/lib/getNftCollectionNfts.js +0 -64
- package/dist/node/lib/getNftCollectionNfts.js.map +0 -1
- package/dist/node/lib/getNftCollectionNfts.mjs +0 -39
- package/dist/node/lib/getNftCollectionNfts.mjs.map +0 -1
- package/dist/node/lib/index.js +0 -158
- package/dist/node/lib/index.js.map +0 -1
- package/dist/node/lib/index.mjs +0 -128
- package/dist/node/lib/index.mjs.map +0 -1
- package/dist/node/lib/nonEvaluableContractAddresses.js +0 -34
- package/dist/node/lib/nonEvaluableContractAddresses.js.map +0 -1
- package/dist/node/lib/nonEvaluableContractAddresses.mjs +0 -9
- package/dist/node/lib/nonEvaluableContractAddresses.mjs.map +0 -1
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/lib/collectionMetrics/index.ts
|
|
21
|
-
var collectionMetrics_exports = {};
|
|
22
|
-
__export(collectionMetrics_exports, {
|
|
23
|
-
getNftCollectionMetrics: () => getNftCollectionMetrics
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(collectionMetrics_exports);
|
|
26
|
-
|
|
27
|
-
// src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts
|
|
28
|
-
var calculateAllPropertiesDistribution = (array) => {
|
|
29
|
-
const distribution = {};
|
|
30
|
-
array.forEach((item) => {
|
|
31
|
-
for (const property in item) {
|
|
32
|
-
if (Object.prototype.hasOwnProperty.call(item, property)) {
|
|
33
|
-
const value = item[property];
|
|
34
|
-
if (value !== void 0 && value !== null) {
|
|
35
|
-
const valueString = value.toString();
|
|
36
|
-
if (!distribution[property]) {
|
|
37
|
-
distribution[property] = { [valueString]: 1 };
|
|
38
|
-
} else if (!distribution[property][valueString]) {
|
|
39
|
-
;
|
|
40
|
-
distribution[property][valueString] = 1;
|
|
41
|
-
} else {
|
|
42
|
-
;
|
|
43
|
-
distribution[property][valueString] += 1;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
return distribution;
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts
|
|
53
|
-
var calculateBinomialParamsFromProbability = (n, p) => {
|
|
54
|
-
const mean = n * p;
|
|
55
|
-
const variance = n * p * (1 - p);
|
|
56
|
-
const stdDev = Math.sqrt(variance);
|
|
57
|
-
return { mean, p, stdDev, variance };
|
|
58
|
-
};
|
|
59
|
-
|
|
60
|
-
// src/lib/collectionMetrics/getNftCollectionMetrics.ts
|
|
61
|
-
var getNftCollectionMetrics = (nfts) => {
|
|
62
|
-
const traits = nfts.map((nft) => nft?.metadata?.attributes).filter((v) => v !== void 0).map((attributes2) => {
|
|
63
|
-
return Object.fromEntries(attributes2.map((attribute) => [attribute.trait_type, attribute.value]));
|
|
64
|
-
});
|
|
65
|
-
const distribution = calculateAllPropertiesDistribution(traits);
|
|
66
|
-
const n = nfts.length;
|
|
67
|
-
const attributes = Object.fromEntries(
|
|
68
|
-
Object.entries(distribution).filter((v) => v[1] !== void 0).map(([trait, entries]) => {
|
|
69
|
-
const traitCount = Object.values(entries).reduce((prev, curr) => prev + curr, 0);
|
|
70
|
-
const { p } = calculateBinomialParamsFromProbability(nfts.length, traitCount / n);
|
|
71
|
-
const values = Object.fromEntries(
|
|
72
|
-
Object.entries(entries).map(([value, traitValueCount]) => {
|
|
73
|
-
const { p: p2 } = calculateBinomialParamsFromProbability(n, traitValueCount / n);
|
|
74
|
-
const metrics = { binomial: { p: p2 }, count: traitValueCount };
|
|
75
|
-
return [value, metrics];
|
|
76
|
-
})
|
|
77
|
-
);
|
|
78
|
-
return [trait, { metrics: { binomial: { p }, count: traitCount }, values }];
|
|
79
|
-
})
|
|
80
|
-
);
|
|
81
|
-
return { metadata: { attributes } };
|
|
82
|
-
};
|
|
83
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/collectionMetrics/index.ts","../../../../src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts","../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts","../../../../src/lib/collectionMetrics/getNftCollectionMetrics.ts"],"sourcesContent":["export * from './getNftCollectionMetrics'\n","import { Distribution } from './distribution'\n\nexport const calculateAllPropertiesDistribution = <T>(array: T[]): Distribution<T> => {\n const distribution: Distribution<T> = {}\n\n array.forEach((item) => {\n for (const property in item) {\n if (Object.prototype.hasOwnProperty.call(item, property)) {\n const value = item[property as keyof T]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (!distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n }\n }\n }\n }\n })\n\n return distribution\n}\n","import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given the number of trials and success probability\n * @param n Number of trials\n * @param p Success probability\n * @returns The binomial distribution parameters\n */\nexport const calculateBinomialParamsFromProbability = (n: number, p: number): BinomialDistributionParameters => {\n // Mean (µ)\n const mean = n * p\n\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n\n return { mean, p, stdDev, variance }\n}\n","import { NftCollectionMetrics, NftTraitMetrics } from '@xyo-network/crypto-nft-collection-payload-plugin'\nimport { NftInfoFields, OpenSeaNftAttribute } from '@xyo-network/crypto-nft-payload-plugin'\n\nimport { calculateAllPropertiesDistribution, calculateBinomialParamsFromProbability } from './lib'\n\ntype TraitDistributionEntry = [string, { [key: string]: number }]\n\nexport const getNftCollectionMetrics = (nfts: NftInfoFields[]): NftCollectionMetrics => {\n const traits = nfts\n .map((nft) => nft?.metadata?.attributes as OpenSeaNftAttribute[] | undefined)\n .filter((v): v is OpenSeaNftAttribute[] => v !== undefined)\n .map((attributes) => {\n return Object.fromEntries(attributes.map((attribute) => [attribute.trait_type, attribute.value]))\n })\n const distribution = calculateAllPropertiesDistribution(traits)\n const n = nfts.length\n const attributes = Object.fromEntries(\n Object.entries(distribution)\n .filter((v): v is TraitDistributionEntry => v[1] !== undefined)\n .map(([trait, entries]) => {\n const traitCount = Object.values(entries).reduce((prev, curr) => prev + curr, 0)\n const { p } = calculateBinomialParamsFromProbability(nfts.length, traitCount / n)\n const values = Object.fromEntries(\n Object.entries(entries).map(([value, traitValueCount]) => {\n const { p } = calculateBinomialParamsFromProbability(n, traitValueCount / n)\n const metrics: NftTraitMetrics = { binomial: { p }, count: traitValueCount }\n return [value, metrics]\n }),\n )\n return [trait, { metrics: { binomial: { p }, count: traitCount }, values }]\n }),\n )\n return { metadata: { attributes } }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACEO,IAAM,qCAAqC,CAAI,UAAgC;AACpF,QAAM,eAAgC,CAAC;AAEvC,QAAM,QAAQ,CAAC,SAAS;AACtB,eAAW,YAAY,MAAM;AAC3B,UAAI,OAAO,UAAU,eAAe,KAAK,MAAM,QAAQ,GAAG;AACxD,cAAM,QAAQ,KAAK,QAAmB;AACtC,YAAI,UAAU,UAAa,UAAU,MAAM;AACzC,gBAAM,cAAc,MAAM,SAAS;AACnC,cAAI,CAAC,aAAa,QAAQ,GAAG;AAC3B,yBAAa,QAAQ,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE;AAAA,UAC9C,WAAW,CAAC,aAAa,QAAQ,EAAG,WAAW,GAAG;AAChD;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,IAAI;AAAA,UACrE,OAAO;AACL;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,KAAK;AAAA,UACtE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF,CAAC;AAED,SAAO;AACT;;;AChBO,IAAM,yCAAyC,CAAC,GAAW,MAA8C;AAE9G,QAAM,OAAO,IAAI;AAGjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAG9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AAEjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;;;ACZO,IAAM,0BAA0B,CAAC,SAAgD;AACtF,QAAM,SAAS,KACZ,IAAI,CAAC,QAAQ,KAAK,UAAU,UAA+C,EAC3E,OAAO,CAAC,MAAkC,MAAM,MAAS,EACzD,IAAI,CAACA,gBAAe;AACnB,WAAO,OAAO,YAAYA,YAAW,IAAI,CAAC,cAAc,CAAC,UAAU,YAAY,UAAU,KAAK,CAAC,CAAC;AAAA,EAClG,CAAC;AACH,QAAM,eAAe,mCAAmC,MAAM;AAC9D,QAAM,IAAI,KAAK;AACf,QAAM,aAAa,OAAO;AAAA,IACxB,OAAO,QAAQ,YAAY,EACxB,OAAO,CAAC,MAAmC,EAAE,CAAC,MAAM,MAAS,EAC7D,IAAI,CAAC,CAAC,OAAO,OAAO,MAAM;AACzB,YAAM,aAAa,OAAO,OAAO,OAAO,EAAE,OAAO,CAAC,MAAM,SAAS,OAAO,MAAM,CAAC;AAC/E,YAAM,EAAE,EAAE,IAAI,uCAAuC,KAAK,QAAQ,aAAa,CAAC;AAChF,YAAM,SAAS,OAAO;AAAA,QACpB,OAAO,QAAQ,OAAO,EAAE,IAAI,CAAC,CAAC,OAAO,eAAe,MAAM;AACxD,gBAAM,EAAE,GAAAC,GAAE,IAAI,uCAAuC,GAAG,kBAAkB,CAAC;AAC3E,gBAAM,UAA2B,EAAE,UAAU,EAAE,GAAAA,GAAE,GAAG,OAAO,gBAAgB;AAC3E,iBAAO,CAAC,OAAO,OAAO;AAAA,QACxB,CAAC;AAAA,MACH;AACA,aAAO,CAAC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,EAAE,GAAG,OAAO,WAAW,GAAG,OAAO,CAAC;AAAA,IAC5E,CAAC;AAAA,EACL;AACA,SAAO,EAAE,UAAU,EAAE,WAAW,EAAE;AACpC;","names":["attributes","p"]}
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
// src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts
|
|
2
|
-
var calculateAllPropertiesDistribution = (array) => {
|
|
3
|
-
const distribution = {};
|
|
4
|
-
array.forEach((item) => {
|
|
5
|
-
for (const property in item) {
|
|
6
|
-
if (Object.prototype.hasOwnProperty.call(item, property)) {
|
|
7
|
-
const value = item[property];
|
|
8
|
-
if (value !== void 0 && value !== null) {
|
|
9
|
-
const valueString = value.toString();
|
|
10
|
-
if (!distribution[property]) {
|
|
11
|
-
distribution[property] = { [valueString]: 1 };
|
|
12
|
-
} else if (!distribution[property][valueString]) {
|
|
13
|
-
;
|
|
14
|
-
distribution[property][valueString] = 1;
|
|
15
|
-
} else {
|
|
16
|
-
;
|
|
17
|
-
distribution[property][valueString] += 1;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
return distribution;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts
|
|
27
|
-
var calculateBinomialParamsFromProbability = (n, p) => {
|
|
28
|
-
const mean = n * p;
|
|
29
|
-
const variance = n * p * (1 - p);
|
|
30
|
-
const stdDev = Math.sqrt(variance);
|
|
31
|
-
return { mean, p, stdDev, variance };
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
// src/lib/collectionMetrics/getNftCollectionMetrics.ts
|
|
35
|
-
var getNftCollectionMetrics = (nfts) => {
|
|
36
|
-
const traits = nfts.map((nft) => nft?.metadata?.attributes).filter((v) => v !== void 0).map((attributes2) => {
|
|
37
|
-
return Object.fromEntries(attributes2.map((attribute) => [attribute.trait_type, attribute.value]));
|
|
38
|
-
});
|
|
39
|
-
const distribution = calculateAllPropertiesDistribution(traits);
|
|
40
|
-
const n = nfts.length;
|
|
41
|
-
const attributes = Object.fromEntries(
|
|
42
|
-
Object.entries(distribution).filter((v) => v[1] !== void 0).map(([trait, entries]) => {
|
|
43
|
-
const traitCount = Object.values(entries).reduce((prev, curr) => prev + curr, 0);
|
|
44
|
-
const { p } = calculateBinomialParamsFromProbability(nfts.length, traitCount / n);
|
|
45
|
-
const values = Object.fromEntries(
|
|
46
|
-
Object.entries(entries).map(([value, traitValueCount]) => {
|
|
47
|
-
const { p: p2 } = calculateBinomialParamsFromProbability(n, traitValueCount / n);
|
|
48
|
-
const metrics = { binomial: { p: p2 }, count: traitValueCount };
|
|
49
|
-
return [value, metrics];
|
|
50
|
-
})
|
|
51
|
-
);
|
|
52
|
-
return [trait, { metrics: { binomial: { p }, count: traitCount }, values }];
|
|
53
|
-
})
|
|
54
|
-
);
|
|
55
|
-
return { metadata: { attributes } };
|
|
56
|
-
};
|
|
57
|
-
export {
|
|
58
|
-
getNftCollectionMetrics
|
|
59
|
-
};
|
|
60
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts","../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts","../../../../src/lib/collectionMetrics/getNftCollectionMetrics.ts"],"sourcesContent":["import { Distribution } from './distribution'\n\nexport const calculateAllPropertiesDistribution = <T>(array: T[]): Distribution<T> => {\n const distribution: Distribution<T> = {}\n\n array.forEach((item) => {\n for (const property in item) {\n if (Object.prototype.hasOwnProperty.call(item, property)) {\n const value = item[property as keyof T]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (!distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n }\n }\n }\n }\n })\n\n return distribution\n}\n","import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given the number of trials and success probability\n * @param n Number of trials\n * @param p Success probability\n * @returns The binomial distribution parameters\n */\nexport const calculateBinomialParamsFromProbability = (n: number, p: number): BinomialDistributionParameters => {\n // Mean (µ)\n const mean = n * p\n\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n\n return { mean, p, stdDev, variance }\n}\n","import { NftCollectionMetrics, NftTraitMetrics } from '@xyo-network/crypto-nft-collection-payload-plugin'\nimport { NftInfoFields, OpenSeaNftAttribute } from '@xyo-network/crypto-nft-payload-plugin'\n\nimport { calculateAllPropertiesDistribution, calculateBinomialParamsFromProbability } from './lib'\n\ntype TraitDistributionEntry = [string, { [key: string]: number }]\n\nexport const getNftCollectionMetrics = (nfts: NftInfoFields[]): NftCollectionMetrics => {\n const traits = nfts\n .map((nft) => nft?.metadata?.attributes as OpenSeaNftAttribute[] | undefined)\n .filter((v): v is OpenSeaNftAttribute[] => v !== undefined)\n .map((attributes) => {\n return Object.fromEntries(attributes.map((attribute) => [attribute.trait_type, attribute.value]))\n })\n const distribution = calculateAllPropertiesDistribution(traits)\n const n = nfts.length\n const attributes = Object.fromEntries(\n Object.entries(distribution)\n .filter((v): v is TraitDistributionEntry => v[1] !== undefined)\n .map(([trait, entries]) => {\n const traitCount = Object.values(entries).reduce((prev, curr) => prev + curr, 0)\n const { p } = calculateBinomialParamsFromProbability(nfts.length, traitCount / n)\n const values = Object.fromEntries(\n Object.entries(entries).map(([value, traitValueCount]) => {\n const { p } = calculateBinomialParamsFromProbability(n, traitValueCount / n)\n const metrics: NftTraitMetrics = { binomial: { p }, count: traitValueCount }\n return [value, metrics]\n }),\n )\n return [trait, { metrics: { binomial: { p }, count: traitCount }, values }]\n }),\n )\n return { metadata: { attributes } }\n}\n"],"mappings":";AAEO,IAAM,qCAAqC,CAAI,UAAgC;AACpF,QAAM,eAAgC,CAAC;AAEvC,QAAM,QAAQ,CAAC,SAAS;AACtB,eAAW,YAAY,MAAM;AAC3B,UAAI,OAAO,UAAU,eAAe,KAAK,MAAM,QAAQ,GAAG;AACxD,cAAM,QAAQ,KAAK,QAAmB;AACtC,YAAI,UAAU,UAAa,UAAU,MAAM;AACzC,gBAAM,cAAc,MAAM,SAAS;AACnC,cAAI,CAAC,aAAa,QAAQ,GAAG;AAC3B,yBAAa,QAAQ,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE;AAAA,UAC9C,WAAW,CAAC,aAAa,QAAQ,EAAG,WAAW,GAAG;AAChD;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,IAAI;AAAA,UACrE,OAAO;AACL;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,KAAK;AAAA,UACtE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF,CAAC;AAED,SAAO;AACT;;;AChBO,IAAM,yCAAyC,CAAC,GAAW,MAA8C;AAE9G,QAAM,OAAO,IAAI;AAGjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAG9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AAEjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;;;ACZO,IAAM,0BAA0B,CAAC,SAAgD;AACtF,QAAM,SAAS,KACZ,IAAI,CAAC,QAAQ,KAAK,UAAU,UAA+C,EAC3E,OAAO,CAAC,MAAkC,MAAM,MAAS,EACzD,IAAI,CAACA,gBAAe;AACnB,WAAO,OAAO,YAAYA,YAAW,IAAI,CAAC,cAAc,CAAC,UAAU,YAAY,UAAU,KAAK,CAAC,CAAC;AAAA,EAClG,CAAC;AACH,QAAM,eAAe,mCAAmC,MAAM;AAC9D,QAAM,IAAI,KAAK;AACf,QAAM,aAAa,OAAO;AAAA,IACxB,OAAO,QAAQ,YAAY,EACxB,OAAO,CAAC,MAAmC,EAAE,CAAC,MAAM,MAAS,EAC7D,IAAI,CAAC,CAAC,OAAO,OAAO,MAAM;AACzB,YAAM,aAAa,OAAO,OAAO,OAAO,EAAE,OAAO,CAAC,MAAM,SAAS,OAAO,MAAM,CAAC;AAC/E,YAAM,EAAE,EAAE,IAAI,uCAAuC,KAAK,QAAQ,aAAa,CAAC;AAChF,YAAM,SAAS,OAAO;AAAA,QACpB,OAAO,QAAQ,OAAO,EAAE,IAAI,CAAC,CAAC,OAAO,eAAe,MAAM;AACxD,gBAAM,EAAE,GAAAC,GAAE,IAAI,uCAAuC,GAAG,kBAAkB,CAAC;AAC3E,gBAAM,UAA2B,EAAE,UAAU,EAAE,GAAAA,GAAE,GAAG,OAAO,gBAAgB;AAC3E,iBAAO,CAAC,OAAO,OAAO;AAAA,QACxB,CAAC;AAAA,MACH;AACA,aAAO,CAAC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,EAAE,GAAG,OAAO,WAAW,GAAG,OAAO,CAAC;AAAA,IAC5E,CAAC;AAAA,EACL;AACA,SAAO,EAAE,UAAU,EAAE,WAAW,EAAE;AACpC;","names":["attributes","p"]}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts
|
|
21
|
-
var calculateAllPropertiesDistribution_exports = {};
|
|
22
|
-
__export(calculateAllPropertiesDistribution_exports, {
|
|
23
|
-
calculateAllPropertiesDistribution: () => calculateAllPropertiesDistribution
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(calculateAllPropertiesDistribution_exports);
|
|
26
|
-
var calculateAllPropertiesDistribution = (array) => {
|
|
27
|
-
const distribution = {};
|
|
28
|
-
array.forEach((item) => {
|
|
29
|
-
for (const property in item) {
|
|
30
|
-
if (Object.prototype.hasOwnProperty.call(item, property)) {
|
|
31
|
-
const value = item[property];
|
|
32
|
-
if (value !== void 0 && value !== null) {
|
|
33
|
-
const valueString = value.toString();
|
|
34
|
-
if (!distribution[property]) {
|
|
35
|
-
distribution[property] = { [valueString]: 1 };
|
|
36
|
-
} else if (!distribution[property][valueString]) {
|
|
37
|
-
;
|
|
38
|
-
distribution[property][valueString] = 1;
|
|
39
|
-
} else {
|
|
40
|
-
;
|
|
41
|
-
distribution[property][valueString] += 1;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
return distribution;
|
|
48
|
-
};
|
|
49
|
-
//# sourceMappingURL=calculateAllPropertiesDistribution.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts"],"sourcesContent":["import { Distribution } from './distribution'\n\nexport const calculateAllPropertiesDistribution = <T>(array: T[]): Distribution<T> => {\n const distribution: Distribution<T> = {}\n\n array.forEach((item) => {\n for (const property in item) {\n if (Object.prototype.hasOwnProperty.call(item, property)) {\n const value = item[property as keyof T]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (!distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n }\n }\n }\n }\n })\n\n return distribution\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAEO,IAAM,qCAAqC,CAAI,UAAgC;AACpF,QAAM,eAAgC,CAAC;AAEvC,QAAM,QAAQ,CAAC,SAAS;AACtB,eAAW,YAAY,MAAM;AAC3B,UAAI,OAAO,UAAU,eAAe,KAAK,MAAM,QAAQ,GAAG;AACxD,cAAM,QAAQ,KAAK,QAAmB;AACtC,YAAI,UAAU,UAAa,UAAU,MAAM;AACzC,gBAAM,cAAc,MAAM,SAAS;AACnC,cAAI,CAAC,aAAa,QAAQ,GAAG;AAC3B,yBAAa,QAAQ,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE;AAAA,UAC9C,WAAW,CAAC,aAAa,QAAQ,EAAG,WAAW,GAAG;AAChD;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,IAAI;AAAA,UACrE,OAAO;AACL;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,KAAK;AAAA,UACtE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF,CAAC;AAED,SAAO;AACT;","names":[]}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
// src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts
|
|
2
|
-
var calculateAllPropertiesDistribution = (array) => {
|
|
3
|
-
const distribution = {};
|
|
4
|
-
array.forEach((item) => {
|
|
5
|
-
for (const property in item) {
|
|
6
|
-
if (Object.prototype.hasOwnProperty.call(item, property)) {
|
|
7
|
-
const value = item[property];
|
|
8
|
-
if (value !== void 0 && value !== null) {
|
|
9
|
-
const valueString = value.toString();
|
|
10
|
-
if (!distribution[property]) {
|
|
11
|
-
distribution[property] = { [valueString]: 1 };
|
|
12
|
-
} else if (!distribution[property][valueString]) {
|
|
13
|
-
;
|
|
14
|
-
distribution[property][valueString] = 1;
|
|
15
|
-
} else {
|
|
16
|
-
;
|
|
17
|
-
distribution[property][valueString] += 1;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
return distribution;
|
|
24
|
-
};
|
|
25
|
-
export {
|
|
26
|
-
calculateAllPropertiesDistribution
|
|
27
|
-
};
|
|
28
|
-
//# sourceMappingURL=calculateAllPropertiesDistribution.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts"],"sourcesContent":["import { Distribution } from './distribution'\n\nexport const calculateAllPropertiesDistribution = <T>(array: T[]): Distribution<T> => {\n const distribution: Distribution<T> = {}\n\n array.forEach((item) => {\n for (const property in item) {\n if (Object.prototype.hasOwnProperty.call(item, property)) {\n const value = item[property as keyof T]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (!distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n }\n }\n }\n }\n })\n\n return distribution\n}\n"],"mappings":";AAEO,IAAM,qCAAqC,CAAI,UAAgC;AACpF,QAAM,eAAgC,CAAC;AAEvC,QAAM,QAAQ,CAAC,SAAS;AACtB,eAAW,YAAY,MAAM;AAC3B,UAAI,OAAO,UAAU,eAAe,KAAK,MAAM,QAAQ,GAAG;AACxD,cAAM,QAAQ,KAAK,QAAmB;AACtC,YAAI,UAAU,UAAa,UAAU,MAAM;AACzC,gBAAM,cAAc,MAAM,SAAS;AACnC,cAAI,CAAC,aAAa,QAAQ,GAAG;AAC3B,yBAAa,QAAQ,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE;AAAA,UAC9C,WAAW,CAAC,aAAa,QAAQ,EAAG,WAAW,GAAG;AAChD;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,IAAI;AAAA,UACrE,OAAO;AACL;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,KAAK;AAAA,UACtE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF,CAAC;AAED,SAAO;AACT;","names":[]}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/lib/collectionMetrics/lib/calculatePropertyDistribution.ts
|
|
21
|
-
var calculatePropertyDistribution_exports = {};
|
|
22
|
-
__export(calculatePropertyDistribution_exports, {
|
|
23
|
-
calculatePropertyDistribution: () => calculatePropertyDistribution
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(calculatePropertyDistribution_exports);
|
|
26
|
-
var calculatePropertyDistribution = (array, property) => {
|
|
27
|
-
const distribution = {};
|
|
28
|
-
array.forEach((item) => {
|
|
29
|
-
const value = item[property];
|
|
30
|
-
if (value !== void 0 && value !== null) {
|
|
31
|
-
const valueString = value.toString();
|
|
32
|
-
if (!distribution[property]) {
|
|
33
|
-
distribution[property] = { [valueString]: 1 };
|
|
34
|
-
} else if (!distribution[property][valueString]) {
|
|
35
|
-
;
|
|
36
|
-
distribution[property][valueString] = 1;
|
|
37
|
-
} else {
|
|
38
|
-
;
|
|
39
|
-
distribution[property][valueString] += 1;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
return distribution;
|
|
44
|
-
};
|
|
45
|
-
//# sourceMappingURL=calculatePropertyDistribution.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/lib/collectionMetrics/lib/calculatePropertyDistribution.ts"],"sourcesContent":["import { Distribution } from './distribution'\n\nexport const calculatePropertyDistribution = <T>(array: T[], property: keyof T): Distribution<T> => {\n const distribution: Distribution<T> = {}\n array.forEach((item) => {\n const value = item[property]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (!distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n }\n }\n })\n return distribution\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAEO,IAAM,gCAAgC,CAAI,OAAY,aAAuC;AAClG,QAAM,eAAgC,CAAC;AACvC,QAAM,QAAQ,CAAC,SAAS;AACtB,UAAM,QAAQ,KAAK,QAAQ;AAC3B,QAAI,UAAU,UAAa,UAAU,MAAM;AACzC,YAAM,cAAc,MAAM,SAAS;AACnC,UAAI,CAAC,aAAa,QAAQ,GAAG;AAC3B,qBAAa,QAAQ,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE;AAAA,MAC9C,WAAW,CAAC,aAAa,QAAQ,EAAG,WAAW,GAAG;AAChD;AAAC,QAAC,aAAa,QAAQ,EAA6B,WAAW,IAAI;AAAA,MACrE,OAAO;AACL;AAAC,QAAC,aAAa,QAAQ,EAA6B,WAAW,KAAK;AAAA,MACtE;AAAA,IACF;AAAA,EACF,CAAC;AACD,SAAO;AACT;","names":[]}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
// src/lib/collectionMetrics/lib/calculatePropertyDistribution.ts
|
|
2
|
-
var calculatePropertyDistribution = (array, property) => {
|
|
3
|
-
const distribution = {};
|
|
4
|
-
array.forEach((item) => {
|
|
5
|
-
const value = item[property];
|
|
6
|
-
if (value !== void 0 && value !== null) {
|
|
7
|
-
const valueString = value.toString();
|
|
8
|
-
if (!distribution[property]) {
|
|
9
|
-
distribution[property] = { [valueString]: 1 };
|
|
10
|
-
} else if (!distribution[property][valueString]) {
|
|
11
|
-
;
|
|
12
|
-
distribution[property][valueString] = 1;
|
|
13
|
-
} else {
|
|
14
|
-
;
|
|
15
|
-
distribution[property][valueString] += 1;
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
|
-
return distribution;
|
|
20
|
-
};
|
|
21
|
-
export {
|
|
22
|
-
calculatePropertyDistribution
|
|
23
|
-
};
|
|
24
|
-
//# sourceMappingURL=calculatePropertyDistribution.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/lib/collectionMetrics/lib/calculatePropertyDistribution.ts"],"sourcesContent":["import { Distribution } from './distribution'\n\nexport const calculatePropertyDistribution = <T>(array: T[], property: keyof T): Distribution<T> => {\n const distribution: Distribution<T> = {}\n array.forEach((item) => {\n const value = item[property]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (!distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n }\n }\n })\n return distribution\n}\n"],"mappings":";AAEO,IAAM,gCAAgC,CAAI,OAAY,aAAuC;AAClG,QAAM,eAAgC,CAAC;AACvC,QAAM,QAAQ,CAAC,SAAS;AACtB,UAAM,QAAQ,KAAK,QAAQ;AAC3B,QAAI,UAAU,UAAa,UAAU,MAAM;AACzC,YAAM,cAAc,MAAM,SAAS;AACnC,UAAI,CAAC,aAAa,QAAQ,GAAG;AAC3B,qBAAa,QAAQ,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE;AAAA,MAC9C,WAAW,CAAC,aAAa,QAAQ,EAAG,WAAW,GAAG;AAChD;AAAC,QAAC,aAAa,QAAQ,EAA6B,WAAW,IAAI;AAAA,MACrE,OAAO;AACL;AAAC,QAAC,aAAa,QAAQ,EAA6B,WAAW,KAAK;AAAA,MACtE;AAAA,IACF;AAAA,EACF,CAAC;AACD,SAAO;AACT;","names":[]}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __copyProps = (to, from, except, desc) => {
|
|
7
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
8
|
-
for (let key of __getOwnPropNames(from))
|
|
9
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
10
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
11
|
-
}
|
|
12
|
-
return to;
|
|
13
|
-
};
|
|
14
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
15
|
-
|
|
16
|
-
// src/lib/collectionMetrics/lib/distribution.ts
|
|
17
|
-
var distribution_exports = {};
|
|
18
|
-
module.exports = __toCommonJS(distribution_exports);
|
|
19
|
-
//# sourceMappingURL=distribution.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/lib/collectionMetrics/lib/distribution.ts"],"sourcesContent":["export type Distribution<T> = {\n [K in keyof T]?: { [value: string]: number }\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=distribution.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/lib/collectionMetrics/lib/index.ts
|
|
21
|
-
var lib_exports = {};
|
|
22
|
-
__export(lib_exports, {
|
|
23
|
-
calculateAllPropertiesDistribution: () => calculateAllPropertiesDistribution,
|
|
24
|
-
calculateBinomialParamsFromOutcomes: () => calculateBinomialParamsFromOutcomes,
|
|
25
|
-
calculateBinomialParamsFromProbability: () => calculateBinomialParamsFromProbability
|
|
26
|
-
});
|
|
27
|
-
module.exports = __toCommonJS(lib_exports);
|
|
28
|
-
|
|
29
|
-
// src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts
|
|
30
|
-
var calculateAllPropertiesDistribution = (array) => {
|
|
31
|
-
const distribution = {};
|
|
32
|
-
array.forEach((item) => {
|
|
33
|
-
for (const property in item) {
|
|
34
|
-
if (Object.prototype.hasOwnProperty.call(item, property)) {
|
|
35
|
-
const value = item[property];
|
|
36
|
-
if (value !== void 0 && value !== null) {
|
|
37
|
-
const valueString = value.toString();
|
|
38
|
-
if (!distribution[property]) {
|
|
39
|
-
distribution[property] = { [valueString]: 1 };
|
|
40
|
-
} else if (!distribution[property][valueString]) {
|
|
41
|
-
;
|
|
42
|
-
distribution[property][valueString] = 1;
|
|
43
|
-
} else {
|
|
44
|
-
;
|
|
45
|
-
distribution[property][valueString] += 1;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
return distribution;
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.ts
|
|
55
|
-
var calculateBinomialParamsFromOutcomes = (outcomes) => {
|
|
56
|
-
const n = outcomes.length;
|
|
57
|
-
const sum = outcomes.reduce((acc, value) => acc + value, 0);
|
|
58
|
-
const p = sum / n;
|
|
59
|
-
const mean = n * p;
|
|
60
|
-
const variance = n * p * (1 - p);
|
|
61
|
-
const stdDev = Math.sqrt(variance);
|
|
62
|
-
return { mean, p, stdDev, variance };
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts
|
|
66
|
-
var calculateBinomialParamsFromProbability = (n, p) => {
|
|
67
|
-
const mean = n * p;
|
|
68
|
-
const variance = n * p * (1 - p);
|
|
69
|
-
const stdDev = Math.sqrt(variance);
|
|
70
|
-
return { mean, p, stdDev, variance };
|
|
71
|
-
};
|
|
72
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/lib/collectionMetrics/lib/index.ts","../../../../../src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts","../../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.ts","../../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts"],"sourcesContent":["export * from './calculateAllPropertiesDistribution'\nexport * from './distribution'\nexport * from './probabilityDistributions'\n","import { Distribution } from './distribution'\n\nexport const calculateAllPropertiesDistribution = <T>(array: T[]): Distribution<T> => {\n const distribution: Distribution<T> = {}\n\n array.forEach((item) => {\n for (const property in item) {\n if (Object.prototype.hasOwnProperty.call(item, property)) {\n const value = item[property as keyof T]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (!distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n }\n }\n }\n }\n })\n\n return distribution\n}\n","import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given a list of outcomes\n * @param outcomes List of outcomes, where 1 is a success and 0 is a failure\n * @returns The mean, standard deviation, and variance of the binomial distribution\n */\nexport const calculateBinomialParamsFromOutcomes = (outcomes: number[]): BinomialDistributionParameters => {\n const n = outcomes.length\n // Calculate p: the proportion of successes\n const sum = outcomes.reduce((acc, value) => acc + value, 0)\n const p = sum / n\n // Mean (µ)\n const mean = n * p\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n return { mean, p, stdDev, variance }\n}\n","import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given the number of trials and success probability\n * @param n Number of trials\n * @param p Success probability\n * @returns The binomial distribution parameters\n */\nexport const calculateBinomialParamsFromProbability = (n: number, p: number): BinomialDistributionParameters => {\n // Mean (µ)\n const mean = n * p\n\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n\n return { mean, p, stdDev, variance }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACEO,IAAM,qCAAqC,CAAI,UAAgC;AACpF,QAAM,eAAgC,CAAC;AAEvC,QAAM,QAAQ,CAAC,SAAS;AACtB,eAAW,YAAY,MAAM;AAC3B,UAAI,OAAO,UAAU,eAAe,KAAK,MAAM,QAAQ,GAAG;AACxD,cAAM,QAAQ,KAAK,QAAmB;AACtC,YAAI,UAAU,UAAa,UAAU,MAAM;AACzC,gBAAM,cAAc,MAAM,SAAS;AACnC,cAAI,CAAC,aAAa,QAAQ,GAAG;AAC3B,yBAAa,QAAQ,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE;AAAA,UAC9C,WAAW,CAAC,aAAa,QAAQ,EAAG,WAAW,GAAG;AAChD;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,IAAI;AAAA,UACrE,OAAO;AACL;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,KAAK;AAAA,UACtE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF,CAAC;AAED,SAAO;AACT;;;ACjBO,IAAM,sCAAsC,CAAC,aAAuD;AACzG,QAAM,IAAI,SAAS;AAEnB,QAAM,MAAM,SAAS,OAAO,CAAC,KAAK,UAAU,MAAM,OAAO,CAAC;AAC1D,QAAM,IAAI,MAAM;AAEhB,QAAM,OAAO,IAAI;AAEjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAE9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AACjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;;;ACXO,IAAM,yCAAyC,CAAC,GAAW,MAA8C;AAE9G,QAAM,OAAO,IAAI;AAGjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAG9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AAEjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;","names":[]}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
// src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts
|
|
2
|
-
var calculateAllPropertiesDistribution = (array) => {
|
|
3
|
-
const distribution = {};
|
|
4
|
-
array.forEach((item) => {
|
|
5
|
-
for (const property in item) {
|
|
6
|
-
if (Object.prototype.hasOwnProperty.call(item, property)) {
|
|
7
|
-
const value = item[property];
|
|
8
|
-
if (value !== void 0 && value !== null) {
|
|
9
|
-
const valueString = value.toString();
|
|
10
|
-
if (!distribution[property]) {
|
|
11
|
-
distribution[property] = { [valueString]: 1 };
|
|
12
|
-
} else if (!distribution[property][valueString]) {
|
|
13
|
-
;
|
|
14
|
-
distribution[property][valueString] = 1;
|
|
15
|
-
} else {
|
|
16
|
-
;
|
|
17
|
-
distribution[property][valueString] += 1;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
return distribution;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.ts
|
|
27
|
-
var calculateBinomialParamsFromOutcomes = (outcomes) => {
|
|
28
|
-
const n = outcomes.length;
|
|
29
|
-
const sum = outcomes.reduce((acc, value) => acc + value, 0);
|
|
30
|
-
const p = sum / n;
|
|
31
|
-
const mean = n * p;
|
|
32
|
-
const variance = n * p * (1 - p);
|
|
33
|
-
const stdDev = Math.sqrt(variance);
|
|
34
|
-
return { mean, p, stdDev, variance };
|
|
35
|
-
};
|
|
36
|
-
|
|
37
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts
|
|
38
|
-
var calculateBinomialParamsFromProbability = (n, p) => {
|
|
39
|
-
const mean = n * p;
|
|
40
|
-
const variance = n * p * (1 - p);
|
|
41
|
-
const stdDev = Math.sqrt(variance);
|
|
42
|
-
return { mean, p, stdDev, variance };
|
|
43
|
-
};
|
|
44
|
-
export {
|
|
45
|
-
calculateAllPropertiesDistribution,
|
|
46
|
-
calculateBinomialParamsFromOutcomes,
|
|
47
|
-
calculateBinomialParamsFromProbability
|
|
48
|
-
};
|
|
49
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/lib/collectionMetrics/lib/calculateAllPropertiesDistribution.ts","../../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.ts","../../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts"],"sourcesContent":["import { Distribution } from './distribution'\n\nexport const calculateAllPropertiesDistribution = <T>(array: T[]): Distribution<T> => {\n const distribution: Distribution<T> = {}\n\n array.forEach((item) => {\n for (const property in item) {\n if (Object.prototype.hasOwnProperty.call(item, property)) {\n const value = item[property as keyof T]\n if (value !== undefined && value !== null) {\n const valueString = value.toString()\n if (!distribution[property]) {\n distribution[property] = { [valueString]: 1 }\n } else if (!distribution[property]![valueString]) {\n ;(distribution[property] as Record<string, number>)[valueString] = 1\n } else {\n ;(distribution[property] as Record<string, number>)[valueString] += 1\n }\n }\n }\n }\n })\n\n return distribution\n}\n","import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given a list of outcomes\n * @param outcomes List of outcomes, where 1 is a success and 0 is a failure\n * @returns The mean, standard deviation, and variance of the binomial distribution\n */\nexport const calculateBinomialParamsFromOutcomes = (outcomes: number[]): BinomialDistributionParameters => {\n const n = outcomes.length\n // Calculate p: the proportion of successes\n const sum = outcomes.reduce((acc, value) => acc + value, 0)\n const p = sum / n\n // Mean (µ)\n const mean = n * p\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n return { mean, p, stdDev, variance }\n}\n","import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given the number of trials and success probability\n * @param n Number of trials\n * @param p Success probability\n * @returns The binomial distribution parameters\n */\nexport const calculateBinomialParamsFromProbability = (n: number, p: number): BinomialDistributionParameters => {\n // Mean (µ)\n const mean = n * p\n\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n\n return { mean, p, stdDev, variance }\n}\n"],"mappings":";AAEO,IAAM,qCAAqC,CAAI,UAAgC;AACpF,QAAM,eAAgC,CAAC;AAEvC,QAAM,QAAQ,CAAC,SAAS;AACtB,eAAW,YAAY,MAAM;AAC3B,UAAI,OAAO,UAAU,eAAe,KAAK,MAAM,QAAQ,GAAG;AACxD,cAAM,QAAQ,KAAK,QAAmB;AACtC,YAAI,UAAU,UAAa,UAAU,MAAM;AACzC,gBAAM,cAAc,MAAM,SAAS;AACnC,cAAI,CAAC,aAAa,QAAQ,GAAG;AAC3B,yBAAa,QAAQ,IAAI,EAAE,CAAC,WAAW,GAAG,EAAE;AAAA,UAC9C,WAAW,CAAC,aAAa,QAAQ,EAAG,WAAW,GAAG;AAChD;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,IAAI;AAAA,UACrE,OAAO;AACL;AAAC,YAAC,aAAa,QAAQ,EAA6B,WAAW,KAAK;AAAA,UACtE;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,EACF,CAAC;AAED,SAAO;AACT;;;ACjBO,IAAM,sCAAsC,CAAC,aAAuD;AACzG,QAAM,IAAI,SAAS;AAEnB,QAAM,MAAM,SAAS,OAAO,CAAC,KAAK,UAAU,MAAM,OAAO,CAAC;AAC1D,QAAM,IAAI,MAAM;AAEhB,QAAM,OAAO,IAAI;AAEjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAE9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AACjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;;;ACXO,IAAM,yCAAyC,CAAC,GAAW,MAA8C;AAE9G,QAAM,OAAO,IAAI;AAGjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAG9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AAEjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;","names":[]}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.ts
|
|
21
|
-
var calculateBinomialParamsFromOutcomes_exports = {};
|
|
22
|
-
__export(calculateBinomialParamsFromOutcomes_exports, {
|
|
23
|
-
calculateBinomialParamsFromOutcomes: () => calculateBinomialParamsFromOutcomes
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(calculateBinomialParamsFromOutcomes_exports);
|
|
26
|
-
var calculateBinomialParamsFromOutcomes = (outcomes) => {
|
|
27
|
-
const n = outcomes.length;
|
|
28
|
-
const sum = outcomes.reduce((acc, value) => acc + value, 0);
|
|
29
|
-
const p = sum / n;
|
|
30
|
-
const mean = n * p;
|
|
31
|
-
const variance = n * p * (1 - p);
|
|
32
|
-
const stdDev = Math.sqrt(variance);
|
|
33
|
-
return { mean, p, stdDev, variance };
|
|
34
|
-
};
|
|
35
|
-
//# sourceMappingURL=calculateBinomialParamsFromOutcomes.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.ts"],"sourcesContent":["import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given a list of outcomes\n * @param outcomes List of outcomes, where 1 is a success and 0 is a failure\n * @returns The mean, standard deviation, and variance of the binomial distribution\n */\nexport const calculateBinomialParamsFromOutcomes = (outcomes: number[]): BinomialDistributionParameters => {\n const n = outcomes.length\n // Calculate p: the proportion of successes\n const sum = outcomes.reduce((acc, value) => acc + value, 0)\n const p = sum / n\n // Mean (µ)\n const mean = n * p\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n return { mean, p, stdDev, variance }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAOO,IAAM,sCAAsC,CAAC,aAAuD;AACzG,QAAM,IAAI,SAAS;AAEnB,QAAM,MAAM,SAAS,OAAO,CAAC,KAAK,UAAU,MAAM,OAAO,CAAC;AAC1D,QAAM,IAAI,MAAM;AAEhB,QAAM,OAAO,IAAI;AAEjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAE9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AACjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;","names":[]}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.ts
|
|
2
|
-
var calculateBinomialParamsFromOutcomes = (outcomes) => {
|
|
3
|
-
const n = outcomes.length;
|
|
4
|
-
const sum = outcomes.reduce((acc, value) => acc + value, 0);
|
|
5
|
-
const p = sum / n;
|
|
6
|
-
const mean = n * p;
|
|
7
|
-
const variance = n * p * (1 - p);
|
|
8
|
-
const stdDev = Math.sqrt(variance);
|
|
9
|
-
return { mean, p, stdDev, variance };
|
|
10
|
-
};
|
|
11
|
-
export {
|
|
12
|
-
calculateBinomialParamsFromOutcomes
|
|
13
|
-
};
|
|
14
|
-
//# sourceMappingURL=calculateBinomialParamsFromOutcomes.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromOutcomes.ts"],"sourcesContent":["import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given a list of outcomes\n * @param outcomes List of outcomes, where 1 is a success and 0 is a failure\n * @returns The mean, standard deviation, and variance of the binomial distribution\n */\nexport const calculateBinomialParamsFromOutcomes = (outcomes: number[]): BinomialDistributionParameters => {\n const n = outcomes.length\n // Calculate p: the proportion of successes\n const sum = outcomes.reduce((acc, value) => acc + value, 0)\n const p = sum / n\n // Mean (µ)\n const mean = n * p\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n return { mean, p, stdDev, variance }\n}\n"],"mappings":";AAOO,IAAM,sCAAsC,CAAC,aAAuD;AACzG,QAAM,IAAI,SAAS;AAEnB,QAAM,MAAM,SAAS,OAAO,CAAC,KAAK,UAAU,MAAM,OAAO,CAAC;AAC1D,QAAM,IAAI,MAAM;AAEhB,QAAM,OAAO,IAAI;AAEjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAE9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AACjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;","names":[]}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts
|
|
21
|
-
var calculateBinomialParamsFromProbability_exports = {};
|
|
22
|
-
__export(calculateBinomialParamsFromProbability_exports, {
|
|
23
|
-
calculateBinomialParamsFromProbability: () => calculateBinomialParamsFromProbability
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(calculateBinomialParamsFromProbability_exports);
|
|
26
|
-
var calculateBinomialParamsFromProbability = (n, p) => {
|
|
27
|
-
const mean = n * p;
|
|
28
|
-
const variance = n * p * (1 - p);
|
|
29
|
-
const stdDev = Math.sqrt(variance);
|
|
30
|
-
return { mean, p, stdDev, variance };
|
|
31
|
-
};
|
|
32
|
-
//# sourceMappingURL=calculateBinomialParamsFromProbability.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../../../src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts"],"sourcesContent":["import { BinomialDistributionParameters } from '@xyo-network/crypto-nft-collection-payload-plugin'\n\n/**\n * Calculates the parameters of a binomial distribution given the number of trials and success probability\n * @param n Number of trials\n * @param p Success probability\n * @returns The binomial distribution parameters\n */\nexport const calculateBinomialParamsFromProbability = (n: number, p: number): BinomialDistributionParameters => {\n // Mean (µ)\n const mean = n * p\n\n // Variance (σ^2)\n const variance = n * p * (1 - p)\n\n // Standard Deviation (σ)\n const stdDev = Math.sqrt(variance)\n\n return { mean, p, stdDev, variance }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAQO,IAAM,yCAAyC,CAAC,GAAW,MAA8C;AAE9G,QAAM,OAAO,IAAI;AAGjB,QAAM,WAAW,IAAI,KAAK,IAAI;AAG9B,QAAM,SAAS,KAAK,KAAK,QAAQ;AAEjC,SAAO,EAAE,MAAM,GAAG,QAAQ,SAAS;AACrC;","names":[]}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
// src/lib/collectionMetrics/lib/probabilityDistributions/binomial/calculateBinomialParamsFromProbability.ts
|
|
2
|
-
var calculateBinomialParamsFromProbability = (n, p) => {
|
|
3
|
-
const mean = n * p;
|
|
4
|
-
const variance = n * p * (1 - p);
|
|
5
|
-
const stdDev = Math.sqrt(variance);
|
|
6
|
-
return { mean, p, stdDev, variance };
|
|
7
|
-
};
|
|
8
|
-
export {
|
|
9
|
-
calculateBinomialParamsFromProbability
|
|
10
|
-
};
|
|
11
|
-
//# sourceMappingURL=calculateBinomialParamsFromProbability.js.map
|