int _tmain(int argc, _TCHAR* argv[])
{
00E71000 push ebp
00E71001 mov ebp,esp
00E71003 and esp,0FFFFFFC0h
00E71006 sub esp,0C0h
00E7100C mov eax,dword ptr [___security_cookie (0E73000h)]
00E71011 xor eax,esp
00E71013 mov dword ptr [esp+0BCh],eax
int count = 16;
__int64 inputs_hex[16] = {
0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x1fedb1530240aa54,
00E7101A xor eax,eax
00E7101C mov dword ptr [esp+38h],eax
00E71020 mov dword ptr [esp+3Ch],eax
00E71024 mov dword ptr [esp+40h],eax
00E71028 mov dword ptr [esp+44h],eax
00E7102C mov dword ptr [esp+48h],eax
00E71030 mov dword ptr [esp+4Ch],eax
0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x1ff0af0d95025bc3,
00E71034 mov dword ptr [esp+58h],eax
00E71038 mov dword ptr [esp+5Ch],eax
00E7103C mov dword ptr [esp+60h],eax
00E71040 mov dword ptr [esp+64h],eax
00E71044 mov dword ptr [esp+68h],eax
00E71048 mov dword ptr [esp+6Ch],eax
0x1fc9353df6af376b, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000,
00E7104C mov dword ptr [esp+80h],eax
00E71053 mov dword ptr [esp+84h],eax
00E7105A mov dword ptr [esp+88h],eax
00E71061 mov dword ptr [esp+8Ch],eax
00E71068 mov dword ptr [esp+90h],eax
00E7106F mov dword ptr [esp+94h],eax
0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000
00E71076 mov dword ptr [esp+98h],eax
00E7107D mov dword ptr [esp+9Ch],eax
00E71084 mov dword ptr [esp+0A0h],eax
00E7108B mov dword ptr [esp+0A4h],eax
00E71092 mov dword ptr [esp+0A8h],eax
00E71099 mov dword ptr [esp+0ACh],eax
};
00E710A0 mov dword ptr [esp+0B0h],eax
00E710A7 mov dword ptr [esp+0B4h],eax
double* inputs = (double*)inputs_hex;
double norm = calc_norm_and_regulate(count, inputs, false);
00E710AE lea eax,[esp+38h]
00E710B2 push eax
00E710B3 mov dword ptr [esp+54h],240AA54h
00E710BB mov dword ptr [esp+58h],1FEDB153h
00E710C3 mov dword ptr [esp+74h],95025BC3h
00E710CB mov dword ptr [esp+78h],1FF0AF0Dh
00E710D3 mov dword ptr [esp+7Ch],0F6AF376Bh
00E710DB mov dword ptr [esp+80h],1FC9353Dh
00E710E6 call calc_norm_and_regulate<double> (0E71130h)
00E710EB fst qword ptr [esp+34h]
fprintf(stdout, "[2]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00E710EF mov edx,dword ptr [esp+34h]
00E710F3 push ecx
00E710F4 mov ecx,dword ptr [esp+3Ch]
00E710F8 fstp qword ptr [esp]
00E710FB push ecx
00E710FC push edx
00E710FD push offset string "[2]0x%016llX:%.19lg\n" (0E720F4h)
00E71102 call dword ptr [__imp____iob_func (0E7209Ch)]
00E71108 add eax,20h
00E7110B push eax
00E7110C call dword ptr [__imp__fprintf (0E720A4h)]
return 0;
}
00E71112 mov ecx,dword ptr [esp+0D4h]
00E71119 add esp,18h
00E7111C xor ecx,esp
00E7111E xor eax,eax
00E71120 call __security_check_cookie (0E711ABh)
00E71125 mov esp,ebp
00E71127 pop ebp
00E71128 ret
--- ソース ファイルがありません -------------------------------------------------------------
00E71129 int 3
00E7112A int 3
00E7112B int 3
00E7112C int 3
00E7112D int 3
00E7112E int 3
00E7112F int 3
--- c:\mingw\msys\1.0\home\root\double2\double2\double2.cpp --------------------
#include "stdafx.h"
#include <stdio.h>
#include <stdint.h>
#include <math.h>
template<typename T> static double calc_norm_and_regulate(int num, T* r, bool regulate){ // <float> for debug.
00E71130 push ebp
00E71131 mov ebp,esp
double norm = 0;
00E71133 fldz
00E71135 sub esp,10h
00E71138 push ebx
00E71139 push esi
00E7113A push edi
for (int i = 0; i < num; i++) {
00E7113B xor esi,esi
00E7113D lea ecx,[ecx]
norm += (double)r[i] * (double)r[i];
00E71140 mov eax,dword ptr [r]
00E71143 fld qword ptr [eax+esi*8]
fprintf(stdout, "[0]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00E71146 sub esp,8
00E71149 fmul st(0),st
00E7114B faddp st(1),st
00E7114D fst qword ptr [norm]
00E71150 mov edi,dword ptr [ebp-8]
00E71153 fstp qword ptr [esp]
00E71156 mov ebx,dword ptr [norm]
00E71159 push edi
00E7115A push ebx
00E7115B push offset string "[0]0x%016llX:%.19lg\n" (0E7210Ch)
00E71160 call dword ptr [__imp____iob_func (0E7209Ch)]
00E71166 add eax,20h
00E71169 push eax
00E7116A call dword ptr [__imp__fprintf (0E720A4h)]
}
fprintf(stdout, "[1]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00E71170 fld qword ptr [norm]
00E71173 inc esi
00E71174 add esp,18h
00E71177 cmp esi,10h
00E7117A jl calc_norm_and_regulate<double>+10h (0E71140h)
00E7117C sub esp,8
00E7117F fstp qword ptr [esp]
00E71182 push edi
00E71183 push ebx
00E71184 push offset string "[1]0x%016llX:%.19lg\n" (0E72124h)
00E71189 call dword ptr [__imp____iob_func (0E7209Ch)]
00E7118F add eax,20h
00E71192 push eax
00E71193 call dword ptr [__imp__fprintf (0E720A4h)]
norm = sqrt(norm);
00E71199 fld qword ptr [norm]
00E7119C add esp,18h
00E7119F call _CIsqrt (0E719A0h)
if (regulate)
for (int i=0;i<num;i++)
r[i] = (T)(r[i]/norm);
return norm;
}
00E711A4 pop edi
00E711A5 pop esi
00E711A6 pop ebx
00E711A7 mov esp,ebp
00E711A9 pop ebp
00E711AA ret

int _tmain(int argc, _TCHAR* argv[])
{
00E71000  push        ebp  
00E71001  mov         ebp,esp  
00E71003  and         esp,0FFFFFFC0h  
00E71006  sub         esp,0C0h  
00E7100C  mov         eax,dword ptr [___security_cookie (0E73000h)]  
00E71011  xor         eax,esp  
00E71013  mov         dword ptr [esp+0BCh],eax  
	int count = 16;
	__int64 inputs_hex[16] = {
		0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x1fedb1530240aa54,
00E7101A  xor         eax,eax  
00E7101C  mov         dword ptr [esp+38h],eax  
00E71020  mov         dword ptr [esp+3Ch],eax  
00E71024  mov         dword ptr [esp+40h],eax  
00E71028  mov         dword ptr [esp+44h],eax  
00E7102C  mov         dword ptr [esp+48h],eax  
00E71030  mov         dword ptr [esp+4Ch],eax  
		0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x1ff0af0d95025bc3,
00E71034  mov         dword ptr [esp+58h],eax  
00E71038  mov         dword ptr [esp+5Ch],eax  
00E7103C  mov         dword ptr [esp+60h],eax  
00E71040  mov         dword ptr [esp+64h],eax  
00E71044  mov         dword ptr [esp+68h],eax  
00E71048  mov         dword ptr [esp+6Ch],eax  
		0x1fc9353df6af376b, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000,
00E7104C  mov         dword ptr [esp+80h],eax  
00E71053  mov         dword ptr [esp+84h],eax  
00E7105A  mov         dword ptr [esp+88h],eax  
00E71061  mov         dword ptr [esp+8Ch],eax  
00E71068  mov         dword ptr [esp+90h],eax  
00E7106F  mov         dword ptr [esp+94h],eax  
		0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000
00E71076  mov         dword ptr [esp+98h],eax  
00E7107D  mov         dword ptr [esp+9Ch],eax  
00E71084  mov         dword ptr [esp+0A0h],eax  
00E7108B  mov         dword ptr [esp+0A4h],eax  
00E71092  mov         dword ptr [esp+0A8h],eax  
00E71099  mov         dword ptr [esp+0ACh],eax  
	};
00E710A0  mov         dword ptr [esp+0B0h],eax  
00E710A7  mov         dword ptr [esp+0B4h],eax  
	double* inputs = (double*)inputs_hex;
	double norm = calc_norm_and_regulate(count, inputs, false);
00E710AE  lea         eax,[esp+38h]  
00E710B2  push        eax  
00E710B3  mov         dword ptr [esp+54h],240AA54h  
00E710BB  mov         dword ptr [esp+58h],1FEDB153h  
00E710C3  mov         dword ptr [esp+74h],95025BC3h  
00E710CB  mov         dword ptr [esp+78h],1FF0AF0Dh  
00E710D3  mov         dword ptr [esp+7Ch],0F6AF376Bh  
00E710DB  mov         dword ptr [esp+80h],1FC9353Dh  
00E710E6  call        calc_norm_and_regulate<double> (0E71130h)  
00E710EB  fst         qword ptr [esp+34h]  
	fprintf(stdout, "[2]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00E710EF  mov         edx,dword ptr [esp+34h]  
00E710F3  push        ecx  
00E710F4  mov         ecx,dword ptr [esp+3Ch]  
00E710F8  fstp        qword ptr [esp]  
00E710FB  push        ecx  
00E710FC  push        edx  
00E710FD  push        offset string "[2]0x%016llX:%.19lg\n" (0E720F4h)  
00E71102  call        dword ptr [__imp____iob_func (0E7209Ch)]  
00E71108  add         eax,20h  
00E7110B  push        eax  
00E7110C  call        dword ptr [__imp__fprintf (0E720A4h)]  
	return 0;
}
00E71112  mov         ecx,dword ptr [esp+0D4h]  
00E71119  add         esp,18h  
00E7111C  xor         ecx,esp  
00E7111E  xor         eax,eax  
00E71120  call        __security_check_cookie (0E711ABh)  
00E71125  mov         esp,ebp  
00E71127  pop         ebp  
00E71128  ret  
--- ソース ファイルがありません -------------------------------------------------------------
00E71129  int         3  
00E7112A  int         3  
00E7112B  int         3  
00E7112C  int         3  
00E7112D  int         3  
00E7112E  int         3  
00E7112F  int         3  
--- c:\mingw\msys\1.0\home\root\double2\double2\double2.cpp --------------------
#include "stdafx.h"
#include <stdio.h>
#include <stdint.h>
#include <math.h>

template<typename T> static double calc_norm_and_regulate(int num, T* r, bool regulate){ // <float> for debug.
00E71130  push        ebp  
00E71131  mov         ebp,esp  
	double norm = 0;
00E71133  fldz  
00E71135  sub         esp,10h  
00E71138  push        ebx  
00E71139  push        esi  
00E7113A  push        edi  
	for (int i = 0; i < num; i++) {
00E7113B  xor         esi,esi  
00E7113D  lea         ecx,[ecx]  
		norm += (double)r[i] * (double)r[i];
00E71140  mov         eax,dword ptr [r]  
00E71143  fld         qword ptr [eax+esi*8]  
		fprintf(stdout, "[0]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00E71146  sub         esp,8  
00E71149  fmul        st(0),st  
00E7114B  faddp       st(1),st  
00E7114D  fst         qword ptr [norm]  
00E71150  mov         edi,dword ptr [ebp-8]  
00E71153  fstp        qword ptr [esp]  
00E71156  mov         ebx,dword ptr [norm]  
00E71159  push        edi  
00E7115A  push        ebx  
00E7115B  push        offset string "[0]0x%016llX:%.19lg\n" (0E7210Ch)  
00E71160  call        dword ptr [__imp____iob_func (0E7209Ch)]  
00E71166  add         eax,20h  
00E71169  push        eax  
00E7116A  call        dword ptr [__imp__fprintf (0E720A4h)]  
	}
	fprintf(stdout, "[1]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00E71170  fld         qword ptr [norm]  
00E71173  inc         esi  
00E71174  add         esp,18h  
00E71177  cmp         esi,10h  
00E7117A  jl          calc_norm_and_regulate<double>+10h (0E71140h)  
00E7117C  sub         esp,8  
00E7117F  fstp        qword ptr [esp]  
00E71182  push        edi  
00E71183  push        ebx  
00E71184  push        offset string "[1]0x%016llX:%.19lg\n" (0E72124h)  
00E71189  call        dword ptr [__imp____iob_func (0E7209Ch)]  
00E7118F  add         eax,20h  
00E71192  push        eax  
00E71193  call        dword ptr [__imp__fprintf (0E720A4h)]  
	norm = sqrt(norm);
00E71199  fld         qword ptr [norm]  
00E7119C  add         esp,18h  
00E7119F  call        _CIsqrt (0E719A0h)  
	if (regulate)
		for (int i=0;i<num;i++)
			r[i] = (T)(r[i]/norm);
	return norm;
}
00E711A4  pop         edi  
00E711A5  pop         esi  
00E711A6  pop         ebx  
00E711A7  mov         esp,ebp  
00E711A9  pop         ebp  
00E711AA  ret  
