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

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

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

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

1回答

1049閲覧

グラフプロットを行いたい。

hataki7

総合スコア4

Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2020/07/21 22:44

前提・実現したいこと

まだ、慣れておらず何をどうしたらいいかわからない
グラフプロットしたいが、途中のエラーでプロットの項まで進めない。

発生している問題・エラーメッセージ

NameError Traceback (most recent call last) <ipython-input-1-18ad85d14bbd> in <module> 5 6 ----> 7 y = integrate.quad(lambda z: special.kv(5/3,z),x,np.inf) 8 F=x*y 9 plot((F),(x,0,10),title='test',xlabel='x',ylabel='F') NameError: name 'x' is not defined

該当のソースコード

import numpy as np import matplotlib.pyplot as plt import scipy.integrate as integrate import scipy.special as special y = integrate.quad(lambda z: special.kv(5/3,z),x,np.inf) F=x*y plot((F),(x,0,10),title='test',xlabel='x',ylabel='F')

試したこと

x=symbols('x')を行える。
from sympy import *
を入れるとエラー
AttributeError: 'function' object has no attribute 'quad
が出てしまい積分自体ができない。

補足情報(FW/ツールのバージョンなど)

windowsのWSLでanacondaを通して、jupyter notebookを使用。

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

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

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

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

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

jeanbiego

2020/07/22 01:55

積分範囲(x,inf)を変えて結果をプロットしたいのだと思うのですが、積分したいのは ∫ (special.kv(5/3,z)) dz ということですか? 更にその結果とxの積を取りたいのでしょうか。 具体的な数式を、手書きでもいいので載せてもらったほうが回答がつくと思います。
meg_

2020/07/22 01:59

「該当のソースコード」のコードにはxが定義されてませんので、「NameError: name 'x' is not defined」のエラーが出るのは当然かと思いますが、どこか別の場所で定義済なのでしょうか?
hataki7

2020/07/22 02:06 編集

ご指摘ありがとうございます。 x=変数 y=∫ (special.kv(5/3,z)) dz  範囲[x~∞] F=x*y   最終的にはグラフ横軸 x 縦軸 F での描画を行いたいのでxは定義していないですね。
guest

回答1

0

ベストアンサー

たとえば、下記のような感じでしょうか?

python3

1from scipy.special import kv 2import matplotlib.pyplot as plt 3from scipy.integrate import quad 4import numpy as np 5 6xs = np.linspace(0, 10, 11) 7f = lambda z: kv(5/3,z) 8fs = [quad(f,x,np.inf)[0]*x for x in xs] 9 10fig = plt.figure() 11ax = fig.add_subplot(1,1,1) 12ax.plot(xs,fs) 13ax.set_title('test') 14ax.set_xlabel('x') 15ax.set_ylabel('F') 16plt.show()

plot

投稿2020/07/22 02:12

編集2020/07/22 02:39
jeanbiego

総合スコア3966

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

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

hataki7

2020/07/22 02:26

流れとしてはそうですね。 F=x*(∫ (special.kv(5/3,z)) dz  範囲[x~∞]) なので、関数としては少し違う感じがします。
jeanbiego

2020/07/22 02:30

このコードは、kv(5/3,z)をx~∞まで積分した結果を、x = 0,1,...,10の11個得るものです。 具体的にはどの辺が違っていましたか? あと、計算結果とは合っていましたか?
hataki7

2020/07/22 02:37

具体的には、kv(5/3,z)をx~∞まで積分した結果[y] にxを掛けたもの [F]とxとの関係グラフを書きたいのですが、ブロードキャストのエラーが出てしまいます。
jeanbiego

2020/07/22 02:40

xとの積をとったものに変更してみました。
hataki7

2020/07/22 02:50

これです。おぉ。すごい。 こういう書き方なんですね。ありがとうございます。 pythonにまだ自分が慣れていないのでエラーメッセージでてんてこ舞いだったんですが、jeanbiegoさんのおかげ勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問