[過去ログ] 【初心者歓迎】C/C++室 Ver.106【環境依存OK】 (1002レス)
1-

このスレッドは過去ログ倉庫に格納されています。
次スレ検索 歴削→次スレ 栞削→次スレ 過去ログメニュー
295: はちみつ餃子 ◆8X2XSCHEME 2020/10/27(火)10:47 ID:0uVZsG3C(1) AAS
>>290
抽象クラスを端的に言えば「実行時の型 (実装) で処理する」ための仕組みなのであって、
delete b; は *b の型が B のつもりで解体するってだけ。
296: 2020/10/27(火)11:47 ID:telUcSp6(2/3) AAS
はちみつはいつもずれてるな
297: はちみつ餃子 ◆8X2XSCHEME 2020/10/27(火)12:05 ID:TGoBbK5n(1) AAS
そうか。
298: 2020/10/27(火)13:39 ID:GDxeid4H(3/3) AAS
~B::B()の内部で~A::A()が呼び出しされてるだけだから
B::d() -> B::~B() -> A::d() -> A::~A()
で正しいんじゃないの~A::A()を普通に呼び出して
B::d()が呼ばれたら怖くない?
299: 2020/10/27(火)14:47 ID:telUcSp6(3/3) AAS
いくつかのクラス (A, B, C) をまとめて class X に対して friend にしたいとき
class X 内で
friend A, B, C;
と描くとエラーになります
friend A;
friend B;
friend C;
と描くしかないですか?

あと前方参照のために
class A, B, C;
省2
300: 2020/10/27(火)15:08 ID:GuZfhw+Q(1) AAS
なぜ後者を良くない書き方だと思った?
その書き方で良いじゃん
301
(1): 2020/10/28(水)09:57 ID:Mf8tEr2f(1/2) AAS
>>290
>>294
確認出来ました。
外部リンク:codepad.org
output の 9行目が Ad なので確信です。
302
(1): 2020/10/28(水)10:12 ID:3yQQm3er(1/2) AAS
僕は友達いないのですがfriend 0(;´Д⊂)と書くべきでしょうか?
303: 2020/10/28(水)10:35 ID:H1XGsoVq(1) AAS
0は識別子にできないので0にすら見離されてるな
304: 2020/10/28(水)11:08 ID:d52OC3St(1) AAS
>>302
あなたが誰かを勝手にfriendと宣言しても問題ありません。
ただ相手があなたにアクセスしないだけなので、現状と何ら変化はありません。
305
(2): 2020/10/28(水)11:38 ID:Mf8tEr2f(2/2) AAS
こんなこといいな出来たらいいな
#define A(X, Y, ...) X Y ; A(X, __VA_ARGS__)
A(class, hoge, fuga, hage)
A(friend, hoge, fuga, hage)
306: 2020/10/28(水)16:32 ID:m1O3OoyR(1) AAS
>>305
念のため言っとくけど俺はhageじゃないからな
307: 2020/10/28(水)16:47 ID:Gcn0+siH(1) AAS
じゃなかったとしても気にしてるのはわかった
308: 2020/10/28(水)17:31 ID:3yQQm3er(2/2) AAS
piyoにしてくれ…
309: 2020/10/28(水)19:02 ID:wsDCwUN2(1) AAS
友達がいないからハゲなのか
ハゲだから友達がいないのか
310: 2020/10/28(水)19:07 ID:URI3IFfr(1) AAS
ボクはgrault!
311: 2020/10/29(木)09:41 ID:RChHWwPC(1) AAS
>>305
一応出来るよ
トークン連結でA_30,A_29とかあらかじめ作っといたループ部分を呼べば、だけど
312
(2): 2020/10/29(木)12:02 ID:NknHXEaX(1) AAS
下記のようにvectorに追加するときにemplace_backを使って初期値を入れるにはどうすればよいでしょうか?

typedef struct aaa_{
char name; // charもしくはstd::stringでも可
uint64_t count;
} aaa;

std::vector<aaa> v_aaa;

char temp[] = "hoge";

// v_aaaの末尾に初期値を入れて追加。イメージ
v_aaa.emplace_back( aaa({name=temp, count=5}) )
313: 2020/10/29(木)12:11 ID:5Qrr6OP3(1) AAS
>>312
外部リンク:ideone.com
314: 2020/10/29(木)12:11 ID:9V9XS1Y8(1) AAS
無理じゃね?
structにコンストラクタを用意する訳にはいかんの?
315
(1): はちみつ餃子 ◆8X2XSCHEME 2020/10/29(木)15:34 ID:WswsrqDV(1/2) AAS
>>312
外部リンク:wandbox.org

こんな感じ?
316: 2020/10/29(木)15:38 ID:C1ySRMXt(1) AAS
暗黙のコピーコンストラクタか…
emplace_backの意味ねー
317: はちみつ餃子 ◆8X2XSCHEME 2020/10/29(木)16:06 ID:WswsrqDV(2/2) AAS
引数を受け取るところでも RVO の適用対象になるから余計なコピーはたぶんそんなに起こらないはずだと思う。
(ちゃんと検証してないので間違ってたらごめん。)
318: 2020/10/29(木)20:07 ID:rufTpjFS(1) AAS
push_backでいいじゃん
319: 2020/10/29(木)23:17 ID:BMEZnPdC(1/2) AAS
>>315
ありがとうございます。できました。
高速化のためにemplace_backを使っているのですが、もしかすると逆に余計なCOPYが発生している可能性もあるんですね。
320
(1): 2020/10/29(木)23:30 ID:BMEZnPdC(2/2) AAS
もう一つ質問です。

uint16_t num;
std::string str;

という2つの変数があった時、strを数値変換してnumに入れたいのですが、下記はどちらも間違ってはないですか?
どちらも戻り値はintとあったのですが、uint16で受けても問題ないのでしょうか?

num = std::stoi(str);
num = atoi(str.c_str());
321: 2020/10/30(金)00:49 ID:XnkdHuuj(1) AAS
問題があるかどうかはstrの仕様次第
uint16_tの範囲外があり得ないなら大丈夫、あり得るなら勿論ダメ
今時のコンパイラなら大きいものから小さいものへの暗黙の変換には警告が出る
警告消したいなら明示castして
322
(2): はちみつ餃子 ◆8X2XSCHEME 2020/10/30(金)09:22 ID:WoJDazC2(1/4) AAS
>>320
int から uint16_t の変換について

変換後の型で表せない範囲の値を変換しようとしたとき、変換後の型が符号なし整数型である場合には、
変換後の型が格納可能な最大値 + 1 で modulo を取った値になることになってる。
(変換後の型が符号付である場合には未定義。)

結果の大きさが確実に uint16_t の範囲に入るという確信がある状況であればもちろん問題ないし、
そうでないときも結果が未定義ではないという意味では問題ないが、
プログラムの意図に合致するかどうかは状況による。

----

文字列を数値に変換することについて、
省2
323: 2020/10/30(金)09:49 ID:7Hoin+z3(1) AAS
>>322
外部リンク:timsong-cpp.github.io
> If the destination type is signed, the value is unchanged if it can be represented in the destination type; otherwise, the value is implementation-defined.
未定義ではないね。移植性は損なわれるけど。
324
(2): 2020/10/30(金)11:26 ID:7MkyV1Cp(1) AAS
>>322
>変換後の型で表せない範囲の値を変換しようとしたとき、変換後の型が符号なし整数型である場合には、
>変換後の型が格納可能な最大値 + 1 で modulo を取った値になることになってる。
>(変換後の型が符号付である場合には未定義。)

結果的にそうなってるだけで実際は上位bit(byte)棄ててるだけじゃないの
325
(1): 2020/10/30(金)12:42 ID:Avmc/4l5(1) AAS
>>324
結果的にそうならないと規格準拠はうたえないし上位を無視してやるかどうかは実装の話だから処理系による
まあ他にいい方法は思いつかないけど
326: はちみつ餃子 ◆8X2XSCHEME 2020/10/30(金)13:29 ID:WoJDazC2(2/4) AAS
>>324
言語仕様で保証されている。
その仕様を実現するためにコンパイラがどうやるかは場合によるだろうけど、
単に上位を捨てることで実現しやすいと想定はしてると思う。
327: はちみつ餃子 ◆8X2XSCHEME 2020/10/30(金)13:31 ID:WoJDazC2(3/4) AAS
>>325
1 の補数を使っているときにマイナスの値が絡んでくるとちょっと調整が必要になるんじゃね?
328
(1): 2020/10/30(金)14:26 ID:NkdFBoQj(1/2) AAS
stoiとか" -1"とか食わせると-1のintになるんでしょ
parserとかゴリゴリ実装してんのかね
329: はちみつ餃子 ◆8X2XSCHEME 2020/10/30(金)14:36 ID:WoJDazC2(4/4) AAS
>>328
扱えるのは整数だけだし、マイナスの他には 0 か 0x が付く場合を処理できればいいのでそんなに複雑ではないと思う。
330: 2020/10/30(金)14:48 ID:NkdFBoQj(2/2) AAS
なるほどね
331
(4): 2020/10/31(土)22:42 ID:R+EB1+ZF(1) AAS
外部リンク:ideone.com

上記の44行目の「ここから〜」と70行目の「ここまで」の部分で変数p_aaa、p_bbbのstr変数を書き換えるという同等の処理をしているのですが、
実際のここの部分は何十行もあるので、メンテナンス性を良くするために、この共通部分を共有できないかと考えています。
関数化すればと思いましたが、引数の構造体が別物のため関数化できません。
何か方法はありますでしょうか?
332: 2020/10/31(土)22:51 ID:u29GL2G8(1/3) AAS
unsigned char* common(unsigned char* arg)
{
333
(1): 2020/10/31(土)22:54 ID:u29GL2G8(2/3) AAS
送信しちゃった
unsigned char* を受けて realloc し、 reallocの戻りの [9][10][11] を書き込みしつつ
reallocの戻りを返す (失敗は exit) そういう関数 common() で
 p_aaa->str = common(p_aaa->str);
 p_bbb->str = common(p_bbb->str);
こうまとめる感じ
334
(1): 2020/10/31(土)23:03 ID:u29GL2G8(3/3) AAS
ideone のコードがあくまで str の操作に終始してるので >>333 になる
共通のコードが type についても同じ操作するのなら

str, type だけを単発の構造体 BASE にして AAA, BBB は BASE を継承しておく
で、関数は BASE を受ける(必要なら BASE を返す or 参照渡しで書き換え)
335
(1): 2020/10/31(土)23:18 ID:3iDylFBH(1) AAS
offsetofで距離の値をメタ取得しメンバアクセスでなく剥いでchar*にすればいいと思うよ
336
(1): 2020/11/01(日)10:32 ID:6FKS57jf(1/3) AAS
>>331
テンプレート関数を使って、コードの上では一つの関数に見せかけておくようにする

前準備の箇所も同様

hsgAWF - Online C++0x Compiler & Debugging Tool - Ideone.com
外部リンク:ideone.com
337: 2020/11/01(日)11:12 ID:tm2facI/(1/2) AAS
>>301
>>294
どうあがいても無理ポ
外部リンク:codepad.org
外部リンク:codepad.org
338
(1): 331 2020/11/01(日)11:33 ID:caGW9eb5(1) AAS
>>334
関数にp_aaa->strを渡して値の書き換えを考えたのですが、関数内のreallocでアドレス変わるからその値を変えてもだめだ。
って思っていました。
ご提案の通りアドレス変わったものを戻り値で返してあげればいいですね。
その考えが抜けていました。

>>335
すみません、剥いでchar*にすればいいってところがよくわかりませんでした。。

>>336
今回以外のケースでも使いみちありそうなのでテンプレートについて調べてみました。
関数やclassを定義する先頭に<typename T, typename HOGE>のように可変できる独自の型を作れる。
省2
339: [337] 2020/11/01(日)11:33 ID:tm2facI/(2/2) AAS
呪縛から逃れられないでござる
外部リンク:codepad.org
340
(1): 2020/11/01(日)11:40 ID:6FKS57jf(2/3) AAS
>>338
テンプレートはだいたいそのようなもの
341
(1): 2020/11/01(日)13:11 ID:BdB3gM+x(1/3) AAS
こんな感じで定義したいときどうすればいい?

template <X>
class X {
public:
X() {}
~X() {}
};
342
(1): はちみつ餃子 ◆8X2XSCHEME 2020/11/01(日)13:51 ID:JHJcVuLz(1/2) AAS
>>341
それで定義したとして、どのように使えるものが出来上がればいいの?
343
(2): 2020/11/01(日)14:07 ID:BdB3gM+x(2/3) AAS
>>342

template <class X>
class A {
X *x;
public:
A(X *a) : x(a) {}
~A(){}
};

int x = 1;
A<int> a(&x);
省17
344: はちみつ餃子 ◆8X2XSCHEME 2020/11/01(日)14:14 ID:JHJcVuLz(2/2) AAS
>>343
その説明を見てもイマイチ要求がわからんのやが……。
全く同じ内容で別の型にしたいということなら幽霊型 (phantom type) を使うという手法はあるけど。
345
(1): 2020/11/01(日)14:15 ID:22aX9WTF(1/2) AAS
>>343
> A<A> b(new A<int>(&x)); ←ここエラー
その記述(特に A<A> という型)でどんな結果を期待していたのかわからない。

> みたいな A とよく似た B C D ... があるとき
A と B は何が違うのか(なぜ A ひとつではダメなのか)わからない。
346
(2): 2020/11/01(日)14:28 ID:BdB3gM+x(3/3) AAS
>>345
>その記述(特に A<A> という型)でどんな結果を期待していたのかわからない。
class A {
A *x;
public:
A(A *a) : x(a) {}
~A(){}
};
です

>A と B は何が違うのか(なぜ A ひとつではダメなのか)わからない。
省2
347: 2020/11/01(日)15:25 ID:QwbHyU2z(1) AAS
幼女が身振り手振り一生懸命しつもんしてると思うと萌えてくるな
348: 2020/11/01(日)15:35 ID:CKi2+wqr(1) AAS
母娘丼が好きです
349: 2020/11/01(日)16:29 ID:22aX9WTF(2/2) AAS
>>346
ごめんさっぱり見えてこないや。「最小限にしたつもり」で情報削りすぎてるんだろうな。
質問の基本として、望む結果、そのために書いたコード、実際の(望ましくない)結果、あたりはそろえてもらわないと
うまくお話しできない。
350
(3): 331 2020/11/01(日)19:17 ID:tQIBnCrw(1) AAS
>>340
ありがとうございます。勉強になりました。

ついでに追加で質問があります。
最初に投稿したコード →外部リンク:ideone.com
の36〜37行目で値と0x00を入れるのに2行使ってますが、これ以上簡素化はできないですよね?
36: memcpy(p_bbb->str, bbb_str_temp, 9);
37: p_bbb->str[9] = 0x00;

あと54〜56行では3行に分けて1バイトづつセットしてますが、ここを一気に入れる方法はありませんか?
イメージは21行目のcharを初期化するときのように {0x41, 0x41, 0x00} みたいな書き方ができないかなと思っているのですが。
54: p_aaa->str[9] = 0x41;
省2
351
(1): 2020/11/01(日)21:33 ID:6FKS57jf(3/3) AAS
>>350
こんなんになるんだろうか

lnDOFG - Online C++0x Compiler & Debugging Tool - Ideone.com
外部リンク:ideone.com

Cプログラミング診断室/珠玉の力作/文字列処理
外部リンク[html]:www.pro.or.jp
352: 2020/11/02(月)16:50 ID:P+uwjz0Z(1) AAS
>>346が言ってるのは多分、テンプレート引数によって異なる識別子のクラスを定義したいってことじゃね?
それは型の次元じゃなくて識別子の次元だからプリプロセッサでやるしかないと思うが
353: 2020/11/02(月)17:19 ID:gwxuwnSp(1) AAS
と思ったけどよく読むとなんか違うっぽいな・・すまん
354: 331 2020/11/02(月)21:24 ID:HalV34XN(1) AAS
>>351
charにキャストして書き込みですか。なるほどですね。
ありがとうございます。
355: 2020/11/05(木)02:53 ID:CsR+UXSo(1) AAS
c++14のconstexpr変数について質問です

constexpr変数は内部リンケージですので、グローバル定数をconstexpr変数で作ろうとすると複数の翻訳単位で実態が作成されてしまうと思います
c++17ではinline変数とすることでただ一つの実態を指すようにできますが、c++14ではどのようにすればよいのでしょうか?
コンパイラがよしなにしてくれますか?
356: 2020/11/05(木)13:17 ID:gh/oj34p(1) AAS
static constexpr
で後は良きに計らってもらえ。
357
(1): 2020/11/07(土)10:44 ID:PF2b8VJJ(1) AAS
>>350
ちょい亀だが、興味あったんで調べてみた。

自分の趣味的には可変引数テンプレートを使ってバイト列にダラダラ書き足していく
感じかな?対応関数増やせばいろんな型をバイト列に展開しやすい。
my_append(&p_aaa->str[9], &p_aaa->str[12], 0x41, 0x42, 0x00);

もう一つは std::initializer_list を使ったもの。リストの1つ目は unsigned char* の
書き出し位置を指定して、あとは int 値の羅列。
参照: 外部リンク:stackoverflow.com
my_append_helper() = { &p_bbb->str[9], 0x41, 0x42, 0 };

外部リンク:ideone.com
358: 350 2020/11/07(土)22:29 ID:CR7v1mZc(1) AAS
>>357

サンプルコードありがとうございます。
引数を可変で受け取ることができるんですね。

これ色んなところで使えそうですが、ぱっと見た感じちょっとクセがあって難しいですね。
思考が追いつかない。。
じっくり考えて理解してみます。
359
(1): 2020/11/08(日)13:25 ID:M0llHupc(1/2) AAS
float a = 1.234;
float b = 1.234f;
double c = 1.234;
double d = 1.234f;
これらの違いを教えてください
double に 1.234f を使って float に 1.234 を使うのが正しいんでしょうか?
360: 2020/11/08(日)14:18 ID:ahbNcVL+(1) AAS
ゥー
361: 2020/11/08(日)15:36 ID:8e1Utdpy(1) AAS
>>359
何も付けなければ整数リテラルはint 小数リテラルははdoubleとなる。
つまり
float a = 1.234; doubleをfloatに変換して代入
float b = 1.234f; floatをfloatに代入
double c = 1.234; doubleをdoubleに代入
double d = 1.234f; floatをdoubleに変換して代入
でfloatの値を指定したい時だけfを付ける。
362
(1): 2020/11/08(日)15:48 ID:M0llHupc(2/2) AAS
ありがとうございます
float a = 1.234;
これで警告が出ないのは不思議ですね
363: 2020/11/08(日)16:04 ID:l+XTZ4Mk(1) AAS
コンパイラの警告レベルの設定によるんじゃないの
364: はちみつ餃子 ◆8X2XSCHEME 2020/11/08(日)16:07 ID:jznHieWa(1/2) AAS
>>362
暗黙の型変換で処理される。
365
(1): 2020/11/08(日)16:32 ID:E458/dQk(1/2) AAS
以下のコンストラクタの書き方は正しいのでしょうか?
Duration(int data) : data_(data), negative_(false) { // メンバ初期化
if (data < 0) { // 条件を満たすとき上書き
data_ *= -1;
negative_ = true;
}
}
366: 2020/11/08(日)16:42 ID:1+QGrERy(1/3) AAS
>>365 まずどこが正しくないと思ってるのか言えよ。
367: 2020/11/08(日)17:28 ID:E458/dQk(2/2) AAS
Duration(int data)
: data_{data < 0 ? -data : data}
, negative_{data < 0} {}
と書けるのを発見しました。お目汚し失礼しました。
368
(1): 2020/11/08(日)18:41 ID:p8PLYZoN(1/7) AAS
下記のようにfor文の外で構造体を参照できるようにするにはどうすればよいですか?
newで生成するとmallocのように寿命が無いオブジェクトを生成できるとネットで見たのですが、そうなりませんでした。。

std::unordered_map<std::string, XXX*> unmap;
for(){
 xxx = new XXX ←構造体
 map["key"] = xxx; ←構造体のポインタを代入
}
map["key"] ←for文の外でxxxを参照できるようにしたい。
369
(2): 2020/11/08(日)19:17 ID:p8PLYZoN(2/7) AAS
変数名を間違えてるところがあったので訂正します。

std::unordered_map<std::string, XXX*> unmap;
for(){
 xxx = new XXX ←構造体
 unmap[key] = xxx; ←構造体のポインタを代入
}
unmap[key] ←for文の外でxxxを参照できるようにしたい。
370
(1): 2020/11/08(日)19:27 ID:1+QGrERy(2/3) AAS
>>368-369
書かれたコードを見る限り参照はできそうなので、何を見て参照できないと言っているのかがわからない。
371: 2020/11/08(日)19:43 ID:p8PLYZoN(3/7) AAS
>>370
そうなんですね。
もうちょっと複雑な条件があるのかな。。
ちなみに変数unmapはclassのpublicで定義していますがそれは関係ないですかね。
372: 2020/11/08(日)19:45 ID:p8PLYZoN(4/7) AAS
あと、newで構造体を生成したときにdelete関数を使わずに勝手に消えてしまうケースなどはないでしょうか?
373
(2): 2020/11/08(日)19:53 ID:JilxLgos(1/2) AAS
>>369
外部リンク:ideone.com
参照できた
374: ◆QZaw55cn4c 2020/11/08(日)19:54 ID:H3a4zXqH(1) AAS
コンパイルできるコードを 外部リンク:ideone.comに貼ってください
375: 2020/11/08(日)20:39 ID:DU8jO1r3(1) AAS
そもそも何かの勘違いか間違いでfor文のループに入ってないとエスパーしてみる
376: 2020/11/08(日)21:09 ID:p8PLYZoN(5/7) AAS
>>373
ありがとうございます。参照できてますね。
となると別の問題のようです。
for文内でprintf()すると出力されるのでループ内には入ってるようなのですが。。
どこかで変なことをやらかしてるんだと思います。

すみません、ちょっと考え方を変えようと思います。

>>373 の下記で変数mを定義していますが、このmから m.***() のようにしてXXXを生成できないでしょうか?
これであればmが生きている限りXXXは残ると思うので。

std::unordered_map<std::string, XXX*> m;
377
(1): 2020/11/08(日)21:13 ID:p8PLYZoN(6/7) AAS
イメージは下記のようなものです。
これで作成したXXXはfor文を抜けても生きているのでこの方法なら解決するかなと思いました。

std::vector<XXX> xxx_vector;
xxx.vector.emplace_back();
XXX* xxx = xxx.back();
378: 2020/11/08(日)21:19 ID:ejbE12Pn(1) AAS
変なことしなくてもnewしたものはdeleteするまで生きてる
そこじゃないとこがbugってるだけ
普通にbugを潰せ
379: はちみつ餃子 ◆8X2XSCHEME 2020/11/08(日)21:51 ID:jznHieWa(2/2) AAS
理解しないままで偶然に動くまで弄るってのは悪い手癖になるぞ。
380: 2020/11/08(日)22:35 ID:ygVNfudb(1) AAS
newの戻り値はブロック内だけ有効って思ってるとか?
何が変なのかさっぱり
381: 2020/11/08(日)23:06 ID:JilxLgos(2/2) AAS
>>377
forのあとで
XXX* xxx = m["0"];
をすればmからXXXを取り出せるけど
そういうことでもなく?
382
(2): 2020/11/08(日)23:19 ID:p8PLYZoN(7/7) AAS
すみません、色々調べていたら思いっきり勘違いしていました。
結論としてはnewできちんと保持されていて、
>>373 のコードで言うと、XXX.cの値を設定し忘れていて、forを抜けたあとでXXX.cを見て何もセットされてない!ってなってました。

この修正をすることになったきっかけが、最初
xxx = new XXX;
ではなく
struct XXX xxx;
でやったり、forを抜ける前とあとで
printf(%p\n");
でポインタが変わったり、とかを調査していてそれらとごっちゃになり、newでやっても消えてしまう。
省3
383: 2020/11/08(日)23:53 ID:1+QGrERy(3/3) AAS
>>382
次からは問題をちゃんと再現できるコードを作って相談しなよ。
そうすればその手の勘違いには自分で気付ける。
384
(1): 2020/11/09(月)12:58 ID:TXQrani0(1/2) AAS
>>382
プログラム書く前に最低でも入門書読むなり入門サイト見るなりして
基本的知識は持ってないとでたらめコード量産するだけ
お前向いてない

過去にも同じような指摘どっかでされてないか?
385
(1): 2020/11/09(月)17:08 ID:8vkBTKks(1) AAS
みんな似たようなことを通ってきてると思うけどね忘れてるだけで
386: 2020/11/09(月)17:30 ID:DrhUvdcE(1) AAS
実務で書いてるコードで問題あって
そこから問題が再現するエッセンスとなる最小部分を抽出してテストしてみるかー
抽出の過程でポカ発見は割とある

(最適化無しだと期待通り動いて最適化maxにするとセグフォしやがるタイプの追跡が辛い)
387: 2020/11/09(月)17:42 ID:TXQrani0(2/2) AAS
>>385
失敗や勘違いは誰にでもあるし
そのことは否定していない
388: 2020/11/09(月)17:44 ID:rzgY+aYD(1) AAS
最初の最初はセーブデータとかもexeファイルの後ろの方に付け足す感じなのかと思ってた
389: 2020/11/10(火)02:30 ID:0GoplVzE(1) AAS
向いてないのは>>384だと思う
390
(1): 2020/11/10(火)11:40 ID:08CevRpc(1) AAS
atan2(y, x) を多項式近似で高速化しようとしたけど
場合分けが多くて結局遠回りしてるような気がする
本当に高速化出来たんだろうか
391: 2020/11/10(火)12:00 ID:yqt88s80(1) AAS
推測するな、計測せよ
392: 2020/11/10(火)12:27 ID:OiV4Kgv1(1) AAS
標準ライブラリもテイラー展開で実装されているだろうから、相当小さい次数で打ち切らないと太刀打ちできないと思われ。
入力される値が有限個なら予め計算しておくのも手。
いずれにしても先に計測だね
393: 2020/11/10(火)13:47 ID:emhcDKaA(1) AAS
必要とする精度によるけど予め飛び飛びに計算しといて間は線形補間とかした方がいいかも
394: 2020/11/10(火)13:47 ID:3xGJBleZ(1) AAS
外部リンク[c]:github.com

2qが何かは知らんがおそらく倍クオリティーのatan2
詳細はさらに不明
有り難すぎて目がつぶれる
1-
あと 608 レスあります
スレ情報 赤レス抽出 画像レス抽出 歴の未読スレ AAサムネイル

ぬこの手 ぬこTOP 0.027s