
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を探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
教えて下さい
-
メモ帳(テキストデータ)をExc...
-
Sheet2の日付をキーにオートフ...
-
【エクセル】測定時間がバラバ...
-
マクロ初心者です、エクセルで...
-
ExcelからSQLサーバへデータを...
-
ユーザーフォームのテキストボ...
-
特定のデータの抽出方法を教え...
-
DataGridViewのデータの引渡し...
-
CString型の文字列連結について
-
[C言語] コメント文字列を無視...
-
javaでDBからデータを取ってき...
-
VBA 毎日取得するデータを順番...
-
命令を変数に応じて変化させる...
-
ページ数を求めたい
-
エクセルのVBAでFor文がわかり...
-
C# ソケット通信でデータ受信時...
-
[Excel] 関数のみでデータの整...
-
Fortranで/(スラッシュ)を含...
-
二分探索の平均探索回数
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
教えて下さい
-
【エクセル】測定時間がバラバ...
-
多量のSUMIF式を軽くしたい
-
配列でデータが入っている要素...
-
メモ帳(テキストデータ)をExc...
-
ユーザーフォームのテキストボ...
-
特定のデータの抽出方法を教え...
-
二分探索の平均探索回数
-
EXCELVBAでSQLserverからデータ...
-
Accessで該当データにフラグを...
-
VBA 空白セルを削除ではない方...
-
この行は既に別のテーブルに属...
-
Excel VBAでのオートフィルター...
-
[C言語] コメント文字列を無視...
-
エクセルで2つの時系列のデー...
-
アクセス2000で画像データ...
-
CString型の文字列連結について
-
カンマからスラッシュに
-
VBにおいてフォーム間の変数の...
-
<VB>String→Object
おすすめ情報