R 使い方 データフレーム 累積和を求める

バイオインフォ道場、くまぞうです。

データフレームやmatrixで累積和を求める機会ありませんか?「前の行の値」に「現在の行の値」を繰り返し足していくことで求められますが、せっかく「R」を使っているのに、for文やインデックスを使って求めるのも残念な感じがします。そんなときは、累積和を求めるcumsumを使うと便利です。累積和は「ある位置までの和」ですが、他にも「ある位置までの最大値・最小値」などを求める関数もあるので知っておくと役に立つことがあるかもしれません。

スポンサーリンク



累積和を求める

累積和を求めるには、cumsumを使います。使い方は簡単で、累積和を求めたいベクトルデータを渡せば、累積和のベクトルを返してくれます。

R> 1:10
 [1]  1  2  3  4  5  6  7  8  9 10
R> cumsum(1:10)
 [1]  1  3  6 10 15 21 28 36 45 55

計算ではデータフレームを使うことが多いと思いますが、データフレームの場合も使い方は簡単です。累積和を求めたい列データを渡せば、結果が返ってきます。求めたデータは新しい列データとして使うことが多いと思うので、within関数などと組み合わせて使うと大変便利です。

R> df <- data.frame(count=1:10)
   count
1      1
2      2
3      3
4      4
5      5
6      6
7      7
8      8
9      9
10    10

R> df <- within(df, cum_sum <- cumsum(count))
   count cum_sum
1      1       1
2      2       3
3      3       6
4      4      10
5      5      15
6      6      21
7      7      28
8      8      36
9      9      45
10    10      55

ある部位までの最小値・最大値

ある部位までの最小値を求めるcumminを使ってみました。ある部位までの最大値を求めたい場合は、cummaxで求めることができます。

R> df <- data.frame(number=sample(10))
   number
1       4
2       6
3       3
4       9
5      10
6       8
7       7
8       5
9       1
10      2

R> df <- within(df, cum_min <- cummin(number))
   number cum_min
1       4       4
2       6       4
3       3       3
4       9       3
5      10       3
6       8       3
7       7       3
8       5       3
9       1       1
10      2       1
スポンサーリンク





カテゴリー

今週よく読まれている記事

  1. 学会・会議で英語が絶望的にできなくて困るケース | オンライン開催で「英語力のなさ」を痛感した場合の対処法

    学会・会議で英語ができなくてに困るケース学会やイベント・会議などが、オンラインで開催される…
  2. r tidyverse 使い方 | 列 filter 絞り込み select関数 – dplyrパッケージ

    tidyverseで1つのデータフレームの列の絞り込みは、dplyrパッケージのselect関数を…
  3. プログラミングで疲れた脳をリフレッシュ 〜 鬼滅の刃「感動」と「やる気アップ」でストレス発散!

    ストレス発散は鬼滅で。「50%OFF」で読む!脳のパフォーマンスを上げるには、適度な休憩と…
  4. AWS ディスク容量不足 新しいボリュームを追加する

    バイオインフォマティクスでは大きなファイルを扱うことがあるので、ディスク不足に陥ることがあります。…
  5. 「知っている」と「知らない」とでは、もしものとき、大違いになる – コロナうつ対策

    コロナうつなどという言葉を聞くようになりましたが、派遣切り、解雇、リストラは、これから本格化します…

人気記事

  1. R言語

    R subset関数 データフレームやmatrixからの条件指定による行・列の抽出
    R の subset関数は、データフレームやマトリックスか…
  2. IGV, 解析ツール

    IGV 使い方 インストール〜便利な使い方まで | リファレンス・マッピングデータ・アノテーションを読み込んで表示しよう
    IGV(Integrative Genomics View…
  3. Excel, 統計

    z-score 計算方法 エクセル(Excel) 編
    統計処理で、大きく変化しているなどの判断基準にも使われる値…

おすすめ記事

  1. R言語, グラフ

    R 使い方 軸・ラベルの調整(向き・サイズ・色など) グラフの描き方
    Rによるplot(グラフ)の描画は、手軽で大変便利です。た…
  2. シェルスクリプト

    シェルスクリプト | ファイル存在チェック・空ファイルチェック
    bashでスクリプトを作成するときに、よく使うのがファイル…
  3. awk, シェルスクリプト

    bash 部分文字列・置換・長さ・連結・分割の文字列処理
    bashのよく使う文字列処理、部分文字列・置換・連結・長さ…