
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.3
- 回答日時:
最大値、最小値を求める場合はご提示されたような
全範囲での比較で可能です。
極大(小)を求めるためには、前点と比べて
値が増えているか、減っているかを調べ、
その値が正から負(負から正)に変わる最初の
点を選べばよいわけです。(No1の方の回答通りです)
極大(小)が一点しかないとわかっているならば、
検索点数を少なくするロジックを作ることも可能でが、
件数が少ないなら(数万以下なら)全点で行っても
たいした負荷になるとは思えません。
また、計測機器等からのデータなのであれば読込時に
前点との比較等を行っておけば事後の処理も簡単になります。
また、データをデータベースに格納することにより、
より簡単にデータにアクセス、加工、解析等を行うことが
できるようになる可能性もあります。

No.2
- 回答日時:
データの元になっているものがどういうものであるかによって、
指定すべき範囲が変わってくる可能性があります。
また、極小(大)値をとることに意味の無い関数もありますし、
点で分けることによって、正確な値が出ない可能性もあります。
要するに、元々の関数をある程度限定しないと、楽ちんな方法は
編み出せないということです。
そういう意味では微分から攻めるのが、いろんな関数に対応でき、
正確で簡単だと思うけど、、、、
早速の回答ありがとうございます。
そうですかあ;
確かに微分を使ってやりたいのはあるんですが、データのプロットがバラバラでとても関数に置きかえれるようなものではないんですよ;
もう決まっている関数に微分を適用するのであればできるとは思うのですが、デコボコしていて、またそれをどんな関数とみればいいのかよくわからなくて;
お探しの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も見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
教えて下さい
-
【エクセル】測定時間がバラバ...
-
メモ帳(テキストデータ)をExc...
-
ユーザーフォームのテキストボ...
-
二分探索の平均探索回数
-
<VB>String→Object
-
ビットシフトについて
-
VBにおいてフォーム間の変数の...
-
プログラミング python pandas ...
-
VBAを使ってOutlookメール本文...
-
EXCELVBAでSQLserverからデータ...
-
Excel VBA テキストインポート...
-
[VBA] CountIfに変数を使いたい
-
特定のデータの抽出方法を教え...
-
VBA 変数代入とループ処理につ...
-
VB RS-232C 通信プログラム
-
ブレーカー落ちで壊れたりしな...
-
配列でデータが入っている要素...
-
VBA 空白セルを削除ではない方...
-
postで引き渡したしたデータは...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
教えて下さい
-
配列でデータが入っている要素...
-
【エクセル】測定時間がバラバ...
-
メモ帳(テキストデータ)をExc...
-
ブレーカー落ちで壊れたりしな...
-
VBA 空白セルを削除ではない方...
-
特定のデータの抽出方法を教え...
-
この行は既に別のテーブルに属...
-
二分探索の平均探索回数
-
ユーザーフォームのテキストボ...
-
EXCELVBAでSQLserverからデータ...
-
CString型の文字列連結について
-
多量のSUMIF式を軽くしたい
-
S9タイプからXタイプにデータ...
-
Excel VBAでのオートフィルター...
-
ACCESSからEXCELに出力する際、...
-
[C言語] コメント文字列を無視...
-
C# ソケット通信でデータ受信時...
-
カンマからスラッシュに
-
アクセス2000で画像データ...
おすすめ情報