質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
Matplotlib

MatplotlibはPythonのおよび、NumPy用のグラフ描画ライブラリです。多くの場合、IPythonと連携して使われます。

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

2回答

1141閲覧

線形回帰した結果をMatplotlibで可視化する時のx軸データの指定方法について

Moriya

総合スコア3

Matplotlib

MatplotlibはPythonのおよび、NumPy用のグラフ描画ライブラリです。多くの場合、IPythonと連携して使われます。

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

0クリップ

投稿2021/05/04 04:33

線形回帰(説明変数2個)した結果、x1とx2の係数が得られ、それをMatplotlibの棒グラフで可視化したいです。グラフのイメージは横軸がx1とx2で縦軸にそれぞれの線形回帰した係数が表示される棒グラフです。

その際、plt.bar(x = ????)の部分にどのようなコードを記載してx軸を指定すればよいでしょうか。

線形回帰の際はpandasでインポートとしたcsvファイルからdfを作成し、ilocで特定の列を指定しました。グラフ作成時にplt.bar(x = df.iloc[:,1:3])とするとエラーが返ってきてしまいます。
どなたかご教授お願い致します。

import pandas as pd
import numpy as np
from sklearn import linear_model
import matplotlib.pyplot as plt

回帰モデルの呼び出し
clf = linear_model.LinearRegression()

説明変数にx1とx2のデータを使用
X = df.iloc[:,1:3].values

目的変数
Y = df.iloc[:,0].values

予測モデルを作成(重回帰)
clf.fit(X, Y)

回帰係数と切片の抽出
a = clf.coef_
b = clf.intercept_

回帰係数
print("線形回帰係数:", a) # 回帰係数:
print("線形回帰切片:", b) # 切片:
print("線形回帰決定係数:", clf.score(X, Y)) # 決定係数:

可視化
plt.figure(figsize=(10,7))
plt.bar(x = ????, height = clf.coef_)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

自己解決

x = df.columns[1:3]とすることで解決しました。

import pandas as pd
import numpy as np
from sklearn import linear_model
import matplotlib.pyplot as plt

回帰モデルの呼び出し
clf = linear_model.LinearRegression()

説明変数にx1とx2のデータを使用
X = df.iloc[:,1:3].values

目的変数
Y = df.iloc[:,0].values

予測モデルを作成(重回帰)
clf.fit(X, Y)

回帰係数と切片の抽出
a = clf.coef_
b = clf.intercept_

回帰係数
print("線形回帰係数:", a) # 回帰係数:
print("線形回帰切片:", b) # 切片:
print("線形回帰決定係数:", clf.score(X, Y)) # 決定係数:

可視化
plt.figure(figsize=(10,7))
plt.bar(x = df.columns[1:3], height = clf.coef_)

投稿2021/05/04 06:25

Moriya

総合スコア3

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

bar()メソッドは、列ではなく行データがいるようなので、転置するのではどうでしょうか。

Python

1plt.bar(x=df.iloc[:,1:3].T)

投稿2021/05/04 05:52

hide5stm

総合スコア426

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Moriya

2021/05/04 06:27

ご回答ありがとうございます。今回の場合は転置では上手く行きませんでしたが、転置をするやり方を知れたので勉強になりました。 ご教授ありがとうございます。 今回の場合ではx = df.columns[1:3]とすることで解決できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問