VB6のプログラムでちょっとつまづいているのでどなたか分かる方いらっしゃいましたら助言お願いいたします。
今、sinカーブのような曲線があるとします。
このsinカーブの極大値、極小値をもとめたいんですが;
微分を使わずに簡単に行ういい方法ってないでしょうか?
ちなみに自分は y座標方向のデータをyy(800)の配列にすべてのデータを入れておいて
yの最大値をymax(50)のように配列しておき
範囲を手入力で指定し、for 文でループさせ、その中に条件式を書いて
求めています。実際にはこんな感じです。
これは最大値をもとめるときのものです
ymax(0)=0
for i= 0 to 800
if ymax(0)<y(i) then yymax(0)=y(i)
end if
next i
というような簡単な並べ替えでやっています。
範囲指定をせずこのような並べ替えの方法でうまく求める方法ってないものでしょうか?
長々とかいてしまいましたがどなたか分かる方いらっしゃいましたら
よろしくお願いします。
No.1ベストアンサー
- 回答日時:
微分といってもさほど難しく無いように思いますが
Y成分の現時点と次との傾きが0または逆転する部分を見つければいいのではないでしょうか
800個のデータがあるのであれば
dim oldAngle as Double, Angle as Double
dim cnt as integer
oldAngle = y(1) - y(0)
cnt = 0
for n = 1 to 799 ' 800-1
angle = y(n+1) - y(n)
if Sgn(oldAngle) <> sgn(Angle) or Angle = 0 then
ymax(cnt) = y(n)
cnt = cnt + 1
end if
next
# Angle=0は Round(Angle,8)などで丸めておいてからのほうがいいかも
早速の回答ありがとうございます。
すごくわかりやすくプログラムを書いてくださいまして本当に感謝してます。
無事に解決することができました<(_ _)>
また、自分のいってたデータ800個という点も考慮していただいた
すごく自分にあってる回答です
忙しいところ親身に対応していただきましてありがとうございます
感謝いたします
No.2
- 回答日時:
データの元になっているものがどういうものであるかによって、
指定すべき範囲が変わってくる可能性があります。
また、極小(大)値をとることに意味の無い関数もありますし、
点で分けることによって、正確な値が出ない可能性もあります。
要するに、元々の関数をある程度限定しないと、楽ちんな方法は
編み出せないということです。
そういう意味では微分から攻めるのが、いろんな関数に対応でき、
正確で簡単だと思うけど、、、、
早速の回答ありがとうございます。
そうですかあ;
確かに微分を使ってやりたいのはあるんですが、データのプロットがバラバラでとても関数に置きかえれるようなものではないんですよ;
もう決まっている関数に微分を適用するのであればできるとは思うのですが、デコボコしていて、またそれをどんな関数とみればいいのかよくわからなくて;
No.3
- 回答日時:
最大値、最小値を求める場合はご提示されたような
全範囲での比較で可能です。
極大(小)を求めるためには、前点と比べて
値が増えているか、減っているかを調べ、
その値が正から負(負から正)に変わる最初の
点を選べばよいわけです。(No1の方の回答通りです)
極大(小)が一点しかないとわかっているならば、
検索点数を少なくするロジックを作ることも可能でが、
件数が少ないなら(数万以下なら)全点で行っても
たいした負荷になるとは思えません。
また、計測機器等からのデータなのであれば読込時に
前点との比較等を行っておけば事後の処理も簡単になります。
また、データをデータベースに格納することにより、
より簡単にデータにアクセス、加工、解析等を行うことが
できるようになる可能性もあります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- Visual Basic(VBA) コード名シートA列と集計シートA列のコードが一致したら、コード名シートA5からk12の範囲をコピーし 1 2022/08/29 23:46
- Visual Basic(VBA) vba 等間隔の列に対しての計算 6 2022/05/17 20:15
- Visual Basic(VBA) 列と行の名前(重複あり)が交差するセルに、データを入力したい 2 2022/06/25 22:42
- Visual Basic(VBA) VBA横データを縦にしたいです 2 2023/08/08 19:38
- Visual Basic(VBA) 前回ご教授いただいたコードに覚えたてのループ処理で品名りんごAから順に20回for nextでループ 7 2023/01/13 22:01
- Excel(エクセル) VBAで組み合わせ算出やCOUNTIFSの処理を高速化したいです。 4 2022/04/07 02:38
- Visual Basic(VBA) Sheet3から2つの条件でオートフィルターで抽出した個数をSheet2へ入力するマクロで、一つ目の 4 2023/01/12 23:40
- Visual Basic(VBA) VBAの繰り返し処理について教えてください。 3 2022/08/02 13:21
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
エクセルで極大値を拾うには
Excel(エクセル)
-
エクセルの最小値抽出方法について
Excel(エクセル)
-
エクセルの散布図 近似曲線の最大値を知る方法(ウインドウズXP だと思うんですが・・・)
Windows Vista・XP
-
-
4
エクセル散布図の最大値の横軸値
その他(Microsoft Office)
-
5
エクセルでもVBAでもいいのですが
Excel(エクセル)
-
6
ピークの検出方法
数学
-
7
近似曲線の数式を手計算で出したい。
数学
-
8
vbaで極大値を抽出する方法
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
教えて下さい
-
多量のSUMIF式を軽くしたい
-
配列でデータが入っている要素...
-
モジュラス103の算出方法について
-
VBA 空白セルを削除ではない方...
-
この行は既に別のテーブルに属...
-
メモ帳(テキストデータ)をExc...
-
ユーザーフォームのテキストボ...
-
アクセス2000で画像データ...
-
GridViewの行の一部を複数行にする
-
VBA 判定文で理解できない結果...
-
Excelのマクロでワードのテキス...
-
エクセルVBAでもっと早く転記
-
VBAで「"」[']をエスケープする...
-
ページ数を求めたい
-
[VBA] CountIfに変数を使いたい
-
C言語について
-
VBAを使ってOutlookメール本文...
-
ブレーカー落ちで壊れたりしな...
-
S9タイプからXタイプにデータ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
教えて下さい
-
【エクセル】測定時間がバラバ...
-
配列でデータが入っている要素...
-
多量のSUMIF式を軽くしたい
-
エクセルで2つの時系列のデー...
-
Excelのマクロでワードのテキス...
-
メモ帳(テキストデータ)をExc...
-
VBA 空白セルを削除ではない方...
-
VBAを使ってOutlookメール本文...
-
Accessで該当データにフラグを...
-
合計3TBのデータのハッシュ値を...
-
シーケンサにパソコンからアク...
-
S9タイプからXタイプにデータ...
-
カンマからスラッシュに
-
VBAでシートからコンボボックス...
-
VBA 毎日取得するデータを順番...
-
ビットシフトについて
-
ユーザーフォームのテキストボ...
-
EXCELVBAでSQLserverからデータ...
-
特定のデータの抽出方法を教え...
おすすめ情報