當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript lodash.sum函數代碼示例

本文整理匯總了TypeScript中lodash.sum函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript sum函數的具體用法?TypeScript sum怎麽用?TypeScript sum使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了sum函數的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: linear

export function linear(...as: [number, number][]): LinearResult {

  if (!as.length) {
    return {
      b: undefined,
      m: undefined,
      fn: () => undefined,
      r2: undefined
    }
  }

  const [xs, ys] = unzip(as)
  const [sum_x, sum_y] = [xs, ys].map(sum)
  const sum_x2 = sum(xs.map(_ => _*_))
  const sum_xy = sum(as.map(([a, b]) => a * b))
  const n = as.length
  const mean_y = mean(ys)

  const m = (n * sum_xy - sum_x * sum_y) / (n * sum_x2 - sum_x * sum_x)
  const b = (sum_y - m * sum_x) / n
  const fn = (x: number) => m*x + b

  // @see https://en.wikipedia.org/wiki/Coefficient_of_determination
  const ss_res = sum(as.map(([x, y]) => square(y - fn(x))))
  const ss_tot = sum(ys.map(y => square(y - mean_y)))
  const r2 = 1 - ss_res/ss_tot

  return {b, m, fn, r2}

}
開發者ID:bcherny,項目名稱:regress,代碼行數:30,代碼來源:index.ts

示例2:

		Array.from(ratingMap.values()).filter(mappedRatings => mappedRatings.length > 1).forEach(dupeRatings => {
			// update first
			const first = dupeRatings.shift();
			queries.push(first.update({ value: Math.round(sum(dupeRatings.map((r: RatingDocument) => r.value)) / dupeRatings.length) }));
			// delete the rest
			dupeRatings.forEach((r: RatingDocument) => queries.push(r.remove()));
		});
開發者ID:freezy,項目名稱:node-vpdb,代碼行數:7,代碼來源:user.util.ts

示例3: del

	/**
	 * Deletes a game.
	 *
	 * @see DELETE /v1/games/:id
	 * @param {Context} ctx Koa context
	 */
	public async del(ctx: Context) {

		const game = await state.models.Game.findOne({ id: sanitize(ctx.params.id) })
			.populate({ path: '_backglass' })
			.populate({ path: '_logo' })
			.exec();

		if (!game) {
			throw new ApiError('No such game with ID "%s".', ctx.params.id).status(404);
		}

		// check for release and backglass reference and fail if there are
		const refs: { [key: string]: number } = {
			releases: await state.models.Release.countDocuments({ _game: game._id }).exec(),
			backglasses: await state.models.Backglass.countDocuments({ _game: game._id }).exec(),
		};
		if (sum(values(refs)) > 0) {
			throw new ApiError('Cannot delete game because it is referenced by %s.', Object.keys(refs).map(f => `${refs[f]} ${f}`).join(' and '))
				.status(400).warn();
		}
		await game.remove();

		logger.info(ctx.state, '[GameApi.del] Game "%s" (%s) successfully deleted.', game.title, game.id);

		await apiCache.invalidateDeletedGame(ctx.state, game);

		// log event
		await LogEventUtil.log(ctx, 'delete_game', false, { game: omit(state.serializers.Game.simple(ctx, game), ['rating', 'counter']) }, { game: game._id });

		this.success(ctx, null, 204);
	}
開發者ID:freezy,項目名稱:node-vpdb,代碼行數:37,代碼來源:game.api.ts

示例4: evaluate

export default function evaluate(situation: Situation, camp: Camp): number {
  return _.sum(situation.getSlots().map( (chess, index) => {
    if (chess && chess.camp == camp) {
      return rules.of(chess).getScore(situation, index);
    } else {
      return 0;
    }
  }));
}
開發者ID:infinnie,項目名稱:WizardChess,代碼行數:9,代碼來源:evaluate.ts

示例5: function

 this.getActiveAddresses(wallet, inGap, reportFn, function(err, addresses) {
   reportFn("Active addresses:" + JSON.stringify(addresses));
   if (err) return cb(err);
   var utxos = _.map(_.flatten(_.map(addresses, "utxo")),"amount");
   var result = {
     addresses: addresses,
     balance: _.sum(utxos),
   }
   return cb(null, result);
 });
開發者ID:JDonadio,項目名稱:recovery-tool-ionic2,代碼行數:10,代碼來源:recovery.service.ts

示例6: refresh

    refresh() {
        this.playerCardsStrengths = this.ChanceCalculations.computeStrengths(this.currentDeck);
        this.strengthPercentageValues = this.playerCardsStrengths.map(strength => this.ChanceCalculations.computeStrengthPercentageValue(strength, this.Game.stack));

        let nonZeroChances = _.compact(this.strengthPercentageValues).length;
        if (nonZeroChances !== 0) {
            this.totalChance = _.sum(this.strengthPercentageValues) / nonZeroChances;
        } else {
            this.totalChance = 0;
        }
    }
開發者ID:Gelio,項目名稱:blackjack-calc,代碼行數:11,代碼來源:index.ts

示例7: Date

 return customers.map(customer => {
     const metadata = (customer.charges[0] && customer.charges[0].metadata) || customer.subscriptions.data[0] && customer.subscriptions.data[0].metadata
     return {
         email: customer.email,
         name: metadata && metadata.name,
         showOnList: metadata && metadata.showOnList,
         isMonthly: customer.subscriptions.data.length > 0,
         created: (new Date(customer.created * 1000)).toISOString(),
         total: sum(customer.charges.map(charge => charge.amount)) / 100
     }
 })
開發者ID:OurWorldInData,項目名稱:owid-grapher,代碼行數:11,代碼來源:exportStripeDonors.ts

示例8: runPing

async function runPing(url: string): Promise<number> {
  const pingUrl = async () => {
    const start = Date.now()

    await fetch(url)

    return Date.now() - start
  }
  const pings = await Promise.all([0,0].map(pingUrl))

  return sum(pings) / pings.length
}
開發者ID:sadeeqaji,項目名稱:graphcool-cli,代碼行數:12,代碼來源:ping.ts

示例9: recalculateStats

  recalculateStats() {
    this.maxMembers = 10 + (this.buildings.levels.Academy || 0);

    const numBuildings = _.size(Buildings);
    const totalLevel = _.sum(_.values(this.buildings.levels));

    this.level = Math.max(1, Math.floor(totalLevel / numBuildings));

    this.$statBoosts = {};

    if(this.$buildingInstances.GardenSmall) {
      const smallGardenLevel = this.buildings.levels.GardenSmall;
      const smallGardenBoost1 = this.getProperty('GardenSmall', 'StatBoost1');
      this.$statBoosts[smallGardenBoost1] = smallGardenLevel;
    }

    if(this.$buildingInstances.GardenMedium) {
      const mediumGardenLevel = this.buildings.levels.GardenMedium;
      const mediumGardenBoost1 = this.getProperty('GardenMedium', 'StatBoost1');
      const mediumGardenBoost2 = this.getProperty('GardenMedium', 'StatBoost2');
      this.$statBoosts[mediumGardenBoost1] = mediumGardenLevel * 20;

      let val = 0;
      switch(mediumGardenBoost2) {
        case 'gold':                    val = 10; break;
        case 'xp':                      val = 2; break;
        case 'itemFindRangeMultiplier': val = 0.05; break;
        case 'salvage':                 val = 1; break;
      }
      this.$statBoosts[mediumGardenBoost2] = mediumGardenLevel * val;
    }

    if(this.$buildingInstances.GardenLarge) {
      const largeGardenLevel = this.buildings.levels.GardenLarge;
      const largeGardenBoost1 = this.getProperty('GardenLarge', 'StatBoost1');
      const largeGardenBoost2 = this.getProperty('GardenLarge', 'StatBoost2');
      const largeGardenBoost3 = this.getProperty('GardenLarge', 'StatBoost3');

      this.$statBoosts[largeGardenBoost1] = largeGardenLevel;
      this.$statBoosts[largeGardenBoost2] = largeGardenLevel;

      let val = 0;
      switch(largeGardenBoost3) {
        case 'hp': case 'mp':           val = 1000; break;
        case 'hpregen': case 'mpregen': val = 200; break;
        case 'damageReduction':         val = 100; break;
      }

      this.$statBoosts[largeGardenBoost3] = largeGardenLevel * val;
    }
  }
開發者ID:IdleLands,項目名稱:IdleLands,代碼行數:51,代碼來源:guild.ts

示例10: function

 return function (engine, locale) {
     function pick(n: number, [[k, x], ...xs]): any {
         return (n <= k) ? x : pick(n - k, xs);
     }
     const total = sum(pool.map(e => e[0]));
     const head = integer(1, total)(engine);
     const result = pick(head, pool);
     if (result instanceof Arbitrary) {
         return result.makeGenerator()(engine, locale);
     }
     else {
         return result;
     };
 };
開發者ID:hychen,項目名稱:hycheck,代碼行數:14,代碼來源:pickers.ts


注:本文中的lodash.sum函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。