Visual Studio 2010 Part21
- 1 :デフォルトの名無しさん:2014/10/01(水) 13:07:56.43 ID:YKNuKmx4.net
- ■公式
http://www.microsoft.com/japan/visualstudio/products/2010-editions
http://www.microsoft.com/visualstudio/en-us/products/2010-editions (英語)
■フィードバック
https://connect.microsoft.com/VisualStudioJapan/content/content.aspx?ContentID=12487
https://connect.microsoft.com/VisualStudio/content/content.aspx?ContentID=14631 (英語)
■リンク
http://www.atmarkit.co.jp/fdotnet/dnfuture/vs10net4_01/vs10net4_01_01.html
http://blogs.msdn.com/b/visualstudio/
■Visual Studio2010 ダウンロード一覧
http://blogs.msdn.com/b/dd_jpn/archive/2010/04/28/10003084.aspx
■Visual Studio 2010 Express版 ダウンロード
http://www.microsoft.com/japan/msdn/vstudio/express/
■Visual Studio 2010 Service Pack 1
http://www.microsoft.com/downloads/ja-jp/details.aspx?familyid=75568aa6-8107-475d-948a-ef22627e57a5
Visual Studio2010 機能比較表
http://www.microsoft.com/japan/visualstudio/products
Visual C++ 機能比較表
http://msdn.microsoft.com/ja-jp/library/hs24szh9.aspx
■前スレ
Visual Studio 2010 Part20
http://peace.2ch.net/test/read.cgi/tech/1354608228/
- 239 :デフォルトの名無しさん:2021/11/03(水) 14:29:51.48 ID:6fv+OhcH.net
- あげ
- 240 :デフォルトの名無しさん:2021/11/09(火) 10:38:25.69 ID:dO6zD4He.net
- VisualStudio2010のC#で作成した2つのアプリ(A,Bとする)と1つのDLL(C.dllとする)
があって、C.dll内の関数のfloatやdoubleを使った計算が、Aから呼び出した場合とBから呼び出した場合
で異なる(誤差が出る)んだけど、何が原因なんだろう?ターゲットプラットフォームの
問題かと考えてAとBをx86にそろえたけど変わらない。
- 241 :デフォルトの名無しさん:2021/11/09(火) 10:58:49.78 ID:JlfStLi1.net
- AとBでDLL呼び出すための宣言が違ってるんじゃないか?
- 242 :デフォルトの名無しさん:2021/11/09(火) 11:24:03.51 ID:dO6zD4He.net
- >>241
早速の返信ありがとうございます。
ビンゴかもしれません!
今、条件を変えて調査中です・・
- 243 :デフォルトの名無しさん:2021/11/09(火) 11:27:24.81 ID:JLiNtnwO.net
- 宣言忘れで int とかな
- 244 :デフォルトの名無しさん:2021/11/09(火) 12:29:22.98 ID:dO6zD4He.net
- 238です。
宣言は確かに異なっていたのですが、合わせてみても結果はかわりませんでした。
- 245 :デフォルトの名無しさん:2021/11/09(火) 13:21:51.88 ID:11xPhQ7m.net
- DLLが実は二種類あるんだろ
- 246 :デフォルトの名無しさん:2021/11/09(火) 13:44:02.60 ID:dO6zD4He.net
- 誤差の出る部分を絞り込むと、math.sqrtに行き当たりました。
こんな感じです。
A:Math.sqrt(14) = 3.74165749549866
B:Math.sqrt(14) = 3.74165738677394
- 247 :デフォルトの名無しさん:2021/11/09(火) 14:01:45.25 ID:JLiNtnwO.net
- >>245
ほんそれ
>AとBをx86にそろえたけど
とか言ってるから x86 の DLL と x64 の DLL がありそうだし
- 248 :デフォルトの名無しさん:2021/11/09(火) 14:06:35.22 ID:JLiNtnwO.net
- どっち呼んでるかは確認してる?
https://docs.microsoft.com/ja-jp/dotnet/api/system.mathf.sqrt?view=net-5.0
https://docs.microsoft.com/ja-jp/dotnet/api/system.math.sqrt?view=net-5.0
- 249 :デフォルトの名無しさん:2021/11/09(火) 14:12:58.99 ID:JLiNtnwO.net
- とりあえず補足
http://codepad.org/evcGt5sW
- 250 :デフォルトの名無しさん:2021/11/09(火) 14:19:16.35 ID:GN60fzOT.net
- 確定っぽい
- 251 :デフォルトの名無しさん:2021/11/09(火) 14:59:14.95 ID:dO6zD4He.net
- >>248
>>249
ありがとうございます。ヒントになりそうなので、こちらの方向で調べてみます。
- 252 :デフォルトの名無しさん:2021/11/09(火) 16:31:34.45 ID:dO6zD4He.net
- >>248、>>249のヒントで、C.dll内にあるMath.Pow, Math.Sqrt, Math.Ceilingなど、
floatからdoubleにキャストされてしまう関数を再度floatにキャストしたり、小数部の
誤差を切り捨てるで、誤差を減らせることがわかりました。(なかったことにするとも言う)
最悪これでいきます。
AとBのアプリからC.dllの同じ関数を同じ引数で呼んでいるのに、なぜ戻り値が
異なるのかはわかっていません。そこがわかればスッキリ直せそうなのですが。
- 253 :デフォルトの名無しさん:2021/11/09(火) 16:48:46.70 ID:11xPhQ7m.net
- どっかで型変換しちゃってるんでしょ
面倒なことせずにABC全部doubleで統一したらいいよw
- 254 :デフォルトの名無しさん:2021/11/09(火) 18:24:21.94 ID:dO6zD4He.net
- どこかで型変換してしまっているんですかねぇ。。
お伝えできていませんでしたが、A、BからC.dllへ渡す引数はすべてInt型です。
C.dll内の数値計算でfloat,doubleが使われています。C.dll内で型変換を
してしまっているのなら、A,Bどちらからも条件は同じはずなのに・・
私としてはVisualStudioの設定の問題かと思ってこちらに書き込みましたが、
スレチな可能性が出てきましたので、この辺でおいとましようかと思います。
- 255 :デフォルトの名無しさん:2021/11/09(火) 18:25:07.92 ID:8kpY2GOq.net
- >AとBのアプリからC.dllの同じ関数を同じ引数で呼んでいる
あやCすぎる
- 256 :デフォルトの名無しさん:2021/11/09(火) 19:11:41.21 ID:11xPhQ7m.net
- ABはこのどちらかの問題があるはず
・dllに同じ値を渡してるつもりだけど、実は異なる値を渡してる
・dllから異なる値が返ってきてるつもりだけど、実は同じ値を受け取ってから異なる値にしてしまってる
Cは小数点の計算誤差を拡大してる状態だろうからそこも修正すべきだけど、とりあえず今回の問題とは無関係
まぁABCの全ソースをうpするぐらいじゃないとわからないな(一部ソースにするとたいていそこに問題あるから全ソースじゃないとダメ)
- 257 :デフォルトの名無しさん:2021/11/09(火) 19:20:31.38 ID:eGS5fyGL.net
- ABから完全に同一条件で同一のメソッドを呼んでいるかが最初に確認すべきことだと思うんだけど
そこを誰も聞かないのが凄いねw
- 258 :デフォルトの名無しさん:2021/11/10(水) 00:47:51.68 ID:UV3syQpY.net
- なにを期待してるんか知らんけど
そもそも真面目に答える義務なんて無いから
ノイズだらけの問題にまともな答えが来ると思ってる方が可笑しい
- 259 :デフォルトの名無しさん:2021/11/10(水) 08:39:33.56 ID:gxiWSUFZ.net
- 質問主です。
いいえ、皆さんの意見は参考になっています。ありがとうございます。
ソースコード全部は難しいので、現象を簡略化してみました。
C.dllに次の関数を用意し、A、Bから呼び出しました。
public static int test()
{
string tmpStr = "";
tmpStr += "Math.sqrt(2f) = " + System.Math.Sqrt(2.0f).ToString() + "\n";
tmpStr += "Math.sqrt(2d) = " + System.Math.Sqrt(2.0d).ToString() + "\n";
string tmpFileName = System.IO.Path.Combine(System.IO.Path.GetTempPath(), "debug.txt");
System.IO.File.WriteAllText(tmpFileName, tmpStr);
return 1;
}
結果は次の通りです。
A:
Math.sqrt(2f) = 1.41421353816986
Math.sqrt(2d) = 1.41421353816986
B:
Math.sqrt(2f) = 1.4142135623731
Math.sqrt(2d) = 1.4142135623731
A、Bと引数、結果のやり取りをしていないので、無意識の型変換はされていないと思うのですが、
見逃している点があるのでしょうか。
- 260 :デフォルトの名無しさん:2021/11/10(水) 09:27:09.70 ID:morNzhKw.net
- A は import Mathf
B は import Math
というオチとか
- 261 :デフォルトの名無しさん:2021/11/10(水) 09:32:32.80 ID:72cRDnd/.net
- 綺麗にAがfloat、Bがdoubleになってるな
省略した部分に問題があるよ
- 262 :デフォルトの名無しさん:2021/11/10(水) 11:58:23.46 ID:mPrRdq/u.net
- Math 使ってるつもりが Mathf が使われてるケース
https://shibuya24.info/entry/mathf_vs_math
- 263 :デフォルトの名無しさん:2021/11/10(水) 12:26:40.94 ID:gxiWSUFZ.net
- MathF、Aの結果がfloat、いろいろご助言ありがとうございます。
MathFについては、私も調べてみたのですが、.NETのVer.5から追加されており、
今使っているVS2010の.NET Ver.4では実装されていないようです。
とはいえ核心に近づいていると感じますので、同様の問題に引っかかっていないか、
調べています。
- 264 :デフォルトの名無しさん:2021/11/10(水) 12:38:22.20 ID:gxiWSUFZ.net
- 呼び出し方については、下記まで簡略化しました。
A,Bとも(BはFormAとFormBと読み替え)
namespace WindowsApplication1
{
public partial class FormA:Form
{
public FormA()
{
InitializeComponent();
tlib.tcls.test();
}
}
}
C.dllは
namespace tlib
{
public static class tcls
{
public static int test()
{
>>259と同じ
}
}
}
A、BともC.dllをソリューションエクスプローラーの「参照設定」から追加しました。
- 265 :デフォルトの名無しさん:2021/11/10(水) 12:56:54.42 ID:72cRDnd/.net
- 簡略した形式でいいから誰でも再現できるようにABC全ソース(プロジェクト一式)をzipでかためてどっかにうpしろって
>>264は言葉にしたら「ACとABは同じソースコードなのに結果が変わる」だからな。それはあり得ないんだよ
- 266 :デフォルトの名無しさん:2021/11/10(水) 13:03:25.84 ID:/xBD3bqR.net
- 実は C.dll が2個あるとかは?
A と B の置き場所カレントディレクトリを一緒にして C.dll もそこに置いて確認はしたか
- 267 :デフォルトの名無しさん:2021/11/10(水) 15:01:00.72 ID:gxiWSUFZ.net
- 全ソースを準備している途中で、どこかの段階でAの結果がBと一致するようになりました。
ありがとうございます。ここまでくれば徐々にAを戻していって、自力で原因に
たどり着けそうです。皆様の助言のおかげです。
- 268 :デフォルトの名無しさん:2021/11/10(水) 15:58:40.41 ID:4cUwoZ2K.net
- やっぱりここで言ってるのとは違って実際には「違うことやってるから違う結果が出た」だけの話だよねw
最初からそうだと思ったよ。
プロジェクトの設定にMath.Sqrtとかの結果に影響を与えるようなオプションなんて存在しないしw
- 269 :デフォルトの名無しさん:2021/11/10(水) 16:29:30.75 ID:VzdAvmBl.net
- コンパイルオプションで常にdoubleをfloatで計算するようなのあったっけ
- 270 :デフォルトの名無しさん:2021/11/10(水) 16:44:46.75 ID:gxiWSUFZ.net
- 質問主です。
原因は、ネットから落として来たフリーのDirectX関係のライブラリでした。
このライブラリの初期化前に実行するとSystem.Math.Sqrtは正しい(doubleの)
答えを返します。回避策としてSystem.Math.Powを使えそうです。
このライブラリがSystem.Mathに影響を与えるはずがない、と思い込んでいた私が
間違っておりました。
皆様のご助言、大変助かりました。
- 271 :デフォルトの名無しさん:2021/11/10(水) 17:23:35.18 ID:VzdAvmBl.net
- なるほど
>フリーのDirectX関係のライブラリ
kwsk
- 272 :デフォルトの名無しさん:2021/11/11(木) 01:04:23.31 ID:AIYNyyhT.net
- >>271
責任転嫁のために必死で考えたんだろうから、
あまり突っ込んでやるなよw
- 273 :デフォルトの名無しさん:2021/11/11(木) 09:18:55.62 ID:SpIFedoW.net
- 余計な事話さなければばれないのに
- 274 :デフォルトの名無しさん:2021/11/11(木) 09:27:27.85 ID:ixmAa2h+.net
- そりゃソースなんてうpりたくないですし…
- 275 :デフォルトの名無しさん:2021/11/11(木) 10:48:39.76 ID:xUMRmi1T.net
- 標準ライブラリの置き換えはわりとやるぞ
例えばPCのシステムタイム変更したくない/できないからkernel32のGetTimeZoneInformationの動作変えるとかさ
math.sqrtが置換できるのかは知らないけどdirectx系ならやりたくなってもおかしくない
- 276 :デフォルトの名無しさん:2021/11/12(金) 08:37:33.57 ID:/mOMSKGK.net
- 質問主です。
ライブラリの作者の方に相談したところ、これはDirect3D 9の仕様であり、計算速度を稼ぐために
CPUの浮動小数点演算の精度をfloatに変更するのがデフォルトになっているとのことでした。
それを無効化するオプションの設定方法を教えていただき、無事解決しました。
- 277 :デフォルトの名無しさん:2021/11/12(金) 10:36:52.59 ID:uCoii1J0.net
- >Direct3D 9の仕様
ほう
オプション描けよ
- 278 :デフォルトの名無しさん:2021/11/12(金) 10:51:59.06 ID:/mOMSKGK.net
- DirectXの初期化時にD3DCREATE_FPU_PRESERVEというフラグをセットすること
により、回避できるそうです。
- 279 :デフォルトの名無しさん:2021/11/12(金) 10:57:11.64 ID:uCoii1J0.net
- GJ
- 280 :デフォルトの名無しさん:2021/11/12(金) 11:09:39.08 ID:FZk+tejh.net
- https://docs.microsoft.com/ja-jp/windows/win32/direct3d9/d3dcreate
Direct3D 浮動小数点演算の精度を、呼び出し元のスレッドで使用される有効桁数に設定します。
このフラグを指定しない場合、Direct3D では、次の2つの理由により、
既定で単精度のラウンドツーニアモードが使用されます。
倍精度モードでは、Direct3D のパフォーマンスが低下します。
Direct3D の部分は、浮動小数点単位の例外がマスクされることを想定しています。
これらの例外をマスク解除と、未定義の動作が発生する可能性があります。
なるほど最近のバージョンでも起こり得るのかな
- 281 :デフォルトの名無しさん:2021/11/12(金) 13:01:11.41 ID:JADHf6kW.net
- Dirext3D内部の設定がSystem.Mathに影響を与えるってこと?w
よく知らんがFPU自体が演算精度の設定を持ってて、
プロセス全体の演算精度がそれに影響されるってこと?
聞いたことないけどマジならヤバいねw
- 282 :デフォルトの名無しさん:2021/11/12(金) 13:20:58.34 ID:vJNDJ1AG.net
- こんなのあった
Unable to make double calculations after D3D device created
https://stackoverflow.com/questions/8890429/unable-to-make-double-calculations-after-d3d-device-created
- 283 :デフォルトの名無しさん:2021/11/12(金) 18:48:12.56 ID:JnXYuZWY.net
- 割と見つかる
>>276 のDirectXのライブラリの作者の方のチョンボか
>>272 の言う通り本人か
http://slapper.sblo.jp/article/38594486.html
https://so-zou.jp/software/tech/library/managed-direct3d/troubleshooting/operation-precision.htm
http://scientistb.blog42.えふしー2.com/blog-entry-148.html
https://qiita.com/mod_poppo/items/9588b6f425ffe4b5c7bf
https://qiita.com/YamadaSan/items/63cdc124c191e3c3fff1
https://qiita.com/yuji_yasuhara/items/0f94f3b60b4525dd1e74
- 284 :デフォルトの名無しさん:2021/12/02(木) 21:49:14.57 ID:1bhUWA4L.net
- デバッグ時にのみ環境変数を設定したいのですが
プロジェクト→プロパティ構成プロパティ→デバッグ→環境
で設定しようとしても1つしか設定出来ません
hoge1=a
hoge2=b
のようにしてもhoge1のみしか有効になりません
解決策あるでしょうか?
- 285 :デフォルトの名無しさん:2021/12/02(木) 22:45:10.20 ID:yWr6GauZ.net
- pathを複数設定するときに複数行で書けず1行にしないといけなくて困ったことあるけど、それもだめなのかよ。なんとかしてもらいたいな
ソースコード中で#ifdef DEBUGとか使って設定したら?
- 286 :デフォルトの名無しさん:2022/09/09(金) 14:00:29.20 ID:070P2JiQ.net
- yotube-dlってVC2010を使ってるけど脆弱性とか大丈夫?
- 287 :デフォルトの名無しさん:2022/09/09(金) 14:48:17.39 ID:rZ/ATUsx.net
- 使っているのはexe化しているpy2exeだから、
心配なら最新のPython上で動かせばいい。
- 288 :デフォルトの名無しさん:2023/10/16(月) 13:25:52.86 ID:AH/C+Ejr.net
- 「好き」という言葉が僕に勇気を与えてくれるんだ
76 KB
新着レスの表示
掲示板に戻る
全部
前100
次100
最新50
read.cgi ver 2014.07.20.01.SC 2014/07/20 D ★