Seti@Home optimized science apps and information
Optimized Seti@Home apps => Windows => Topic started by: _heinz on 22 Jun 2007, 07:30:56 pm
-
Hi all,
as you know I use Visual Studio 2005 Express to develop optomized sourcecode. See thread "optimized sources".
Now I decide use parallel Visual Studio Codename Orcas, Professional Edition, which is now available as Version 9.0.20404.0 Beta1 with Microsoft .NET Framework Version 2.0.50727
--------------------------------------------------------------------------------------
The download is more than 5,4 GB. Installation runs without any problems.
After the installation we must install Intel IPP 5.2 Beta, and MKL 9.0 because we want tu use it.
Now we can start it(MVS Orcas) and set the necessary include and Lib paths under "Tool" --->Options --->Projects and Solutions --->VC++ Directories ---->executable Files, Include Files, Library Files
We must convert the application to the new development environment.
We go to File --->New ---->Project From Existing Code --->Visual C++ ---->and go to the directory where we have our seti project stored, ....\client\winbuild\seti_boinc.sln
When all parts are sucessful converted we can start to compile.
-----------------------------------------------------------------------------------------------------------------------------
at first we compile our libs in the folowing order
1. glut32
2. image_libs
3. jpeglib
4. libboinc
5. libboincapi
6. non_ICC
7. setiboincdb
8. Optimizer
and at last
9. seti_boinc
That“s it.
Or you go to the Solution Explorer ---->right click on Solution “seti_boinc“ ----> choose "Build Solution" then it runs automatic.
Now we will do that.
-------------------------------------------------------------------------------------------------------------------
If you want to see the whole compile you can download the attached file boinc_orcas.txt
1 error occured in libboinc and a lot of warnings
util.C
c:\i\sc\vs90\boinc\lib\util.h(81) : warning C4996: 'std::transform': Function call with parameters that may be unsafe - this call
relies on the caller to check that the passed values are correct. To disable this warning, use -D_SCL_SECURE_NO_WARNINGS. See
documentation on how to use Visual C++ 'Checked Iterators'
c:\I\VS9\VC\include\algorithm(708) : see declaration of 'std::transform'
stackwalker_win.cpp
..\..\..\boinc\lib\stackwalker_win.cpp(614) : error C2664: 'BOOL (HANDLE,PSYM_ENUMMODULES_CALLBACK64,PVOID)' : cannot convert
parameter 2 from 'overloaded-function' to 'PSYM_ENUMMODULES_CALLBACK64'
None of the functions with this name in scope match the target type
------------------------------------------------------------------------------------------------------------------------------
the rest of the project compiles without any error, but with a lot warnings always util.h(81) : warning C4996: 'std::transform': Function call with parameters that may be unsafe -
if we now compile seti_boinc we will get a error because libboinc.lib is not available.
libboinc compiles without any error, but a lot of warnings from util.h(81) std::transform
-----------------------------------------------------------------------------------------------------------------------------
....
LINK : fatal error LNK1181: cannot open input file 'libboinc.lib'
seti_boinc - 1 error(s), 23 warning(s)
----------------------------------------------------------------------------------------------
Thats a good result, still 1 error in the Project.
Now I will search ::)
any suggestions are welcome
regards seti_britta ~heinz
[attachment deleted by admin]
-
Hi Simon, Crunch3r, Joe
just I looked through the original source 2.2B and found a file stackwalker.patch from 17.10.2006. Do you know which problem has patched in stackwalker ?
regards heinz
-
Hi Simon, Crunch3r, Joe
just I looked through the original source 2.2B and found a file stackwalker.patch from 17.10.2006. Do you know which problem has patched in stackwalker ?
regards heinz
http://www.google.de/search?q=PSYM_ENUMMODULES_CALLBACK64&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:de:official&client=firefox-a
Google can help --> http://boinc.berkeley.edu/trac/ticket/115
:-X
-
Merci Crunch3r,
thats the solution of the stackwalker problem I have had.
stackwalker compiles now.
Compiling...
stackwalker_win.cpp
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
libboinc - 0 error(s), 0 warning(s)
========== Build: 1 succeeded, 0 failed, 0 up-to-date, 0 skipped ==========
But the link fails with 1 unresolved external
Compiling...
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.20404 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved.
cl /Od /Ob2 /Oi /Ot /Oy /GT /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\jpeglib" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\image_libs" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\db" /I "C:\I\SC\vs90\boinc\client\win" /I "C:\I\SC\vs90\boinc\lib" /I "C:\I\SC\vs90\boinc\api" /I "C:\I\SC\vs90\boinc" /I "." /I "../../../boinc/api" /I "../../../boinc/lib" /I ".." /I "glut" /D "WIN32" /D "_WIN32" /D "NDEBUG" /D "_WINDOWS" /D "NBOINC_APP_GRAPHICS" /D "CLIENT" /D "_MT" /D "USE_IPP" /D "USE_SSE2" /D "_VC80_UPGRADE=0x0600" /D "_MBCS" /GF /Gm /EHsc /MT /Zp16 /Gy /Fp".\Release/seti_boinc.pch" /Fo".\Release32-NOGFX\\" /Fd".\Release32-NOGFX\vc90.pdb" /FR".\Release32-NOGFX\\" /W3 /c /Wp64 /Zi /TP "..\analyzeFuncs.cpp"
analyzeFuncs.cpp
C:\I\SC\vs90\boinc\lib\util.h(81) : warning C4996: 'std::transform': Function call with parameters that may be unsafe - this call relies on the caller to check that the passed values are correct. To disable this warning, use -D_SCL_SECURE_NO_WARNINGS. See documentation on how to use Visual C++ 'Checked Iterators'
c:\I\VS9\VC\include\algorithm(708) : see declaration of 'std::transform'
-----IPP-----
-----SSE2-----
Linking...
Microsoft (R) Incremental Linker Version 9.00.20404
Copyright (C) Microsoft Corporation. All rights reserved.
"/OUT:.\Release32-NOGFX\seti_boinc.exe" /INCREMENTAL:NO "/LIBPATH:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" "/LIBPATH:C:\I\INTEL\IPP\5.2_beta\ia32\lib" "/LIBPATH:C:\I\INTEL\MKL\9.0\ia32\lib" "/LIBPATH:C:\masm32\lib" "/LIBPATH:C:\I\VS8\VC\lib" "/LIBPATH:C:\I\SDK\Lib" "/LIBPATH:C:\masm32\m32lib" "/LIBPATH:C:\I\SDK\Lib\AMD64" "/LIBPATH:C:\I\SDK\Lib\IA64" /MANIFEST:NO "/MANIFESTUAC:level='asInvoker' uiAccess='false'" "/PDB:c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\seti_boinc.pdb" /MAP /SUBSYSTEM:WINDOWS /DYNAMICBASE:NO /MACHINE:X86 glut32.lib glut.lib glu32.lib Optimizer.lib image_libs.lib jpeglib.lib libboinc.lib libboincapi.lib non_ICC.lib setiboincdb.lib ippsmerged.lib ippvmmerged.lib ippchmerged.lib ippcorel.lib delayimp.lib libcpmt.lib WinMM.lib OpenGL32.lib Kernel32.Lib oldnames.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib
".\Release32-NOGFX\analyzeFuncs.obj"
".\Release32-NOGFX\analyzePoT.obj"
".\Release32-NOGFX\analyzeReport.obj"
".\Release32-NOGFX\app_ipc.obj"
".\Release32-NOGFX\boinc_api.obj"
".\Release32-NOGFX\chirpfft.obj"
".\Release32-NOGFX\fft8g.obj"
".\Release32-NOGFX\filesys.obj"
".\Release32-NOGFX\gaussfit.obj"
".\Release32-NOGFX\gdata.obj"
".\Release32-NOGFX\graphics_api.obj"
".\Release32-NOGFX\graphics_data.obj"
".\Release32-NOGFX\gutil.obj"
".\Release32-NOGFX\lcgamm.obj"
".\Release32-NOGFX\main.obj"
".\Release32-NOGFX\malloc_a.obj"
".\Release32-NOGFX\parse.obj"
".\Release32-NOGFX\progress.obj"
".\Release32-NOGFX\pulsefind.obj"
".\Release32-NOGFX\s_util.obj"
".\Release32-NOGFX\sah_gfx.obj"
".\Release32-NOGFX\sah_gfx_base.obj"
".\Release32-NOGFX\schema_master.obj"
".\Release32-NOGFX\seti.obj"
".\Release32-NOGFX\seti_header.obj"
".\Release32-NOGFX\shmem.obj"
".\Release32-NOGFX\spike.obj"
".\Release32-NOGFX\sqlblob.obj"
".\Release32-NOGFX\sqlrow.obj"
".\Release32-NOGFX\tgalib.obj"
".\Release32-NOGFX\timecvt.obj"
".\Release32-NOGFX\util.obj"
".\Release32-NOGFX\version.obj"
".\Release32-NOGFX\windows_opengl.obj"
".\Release32-NOGFX\worker.obj"
".\Release32-NOGFX\xml_util.obj"
s_util.obj : error LNK2019: unresolved external symbol "public: static void __cdecl std::_Locinfo::_Locinfo_ctor(class std::_Locinfo *,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &)" (?_Locinfo_ctor@_Locinfo@std@@SAXPAV12@ABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@2@@Z) referenced in function "public: __thiscall std::_Locinfo::_Locinfo(class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &)" (??0_Locinfo@std@@QAE@ABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@1@@Z)
schema_master.obj : error LNK2001: unresolved external symbol "public: static void __cdecl std::_Locinfo::_Locinfo_ctor(class std::_Locinfo *,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &)" (?_Locinfo_ctor@_Locinfo@std@@SAXPAV12@ABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@2@@Z)
seti.obj : error LNK2001: unresolved external symbol "public: static void __cdecl std::_Locinfo::_Locinfo_ctor(class std::_Locinfo *,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &)" (?_Locinfo_ctor@_Locinfo@std@@SAXPAV12@ABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@2@@Z)
xml_util.obj : error LNK2001: unresolved external symbol "public: static void __cdecl std::_Locinfo::_Locinfo_ctor(class std::_Locinfo *,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &)" (?_Locinfo_ctor@_Locinfo@std@@SAXPAV12@ABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@2@@Z)
.\Release32-NOGFX\seti_boinc.exe : fatal error LNK1120: 1 unresolved externals
Creating browse information file...
Microsoft Browse Information Maintenance Utility Version 9.00.20404
Copyright (C) Microsoft Corporation. All rights reserved.
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
seti_boinc - 5 error(s), 23 warning(s)
========== Rebuild All: 0 succeeded, 1 failed, 0 skipped ==========
Can anybody help with the ext ref problem ?
regards heinz
-
seti_boinc compile and link now without any error ;D
--------------------------------------------------------------------------
------ Rebuild All started: Project: seti_boinc, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'seti_boinc', configuration 'Release32-NOGFX|Win32'
Compiling...
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.20404 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved.
cl /Od /Ob2 /Oi /Ot /Oy /GT /I "." /I "../../../boinc/api" /I "../../../boinc/client/win" /I "../../../boinc/lib" /I ".." /I "glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\db" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\jpeglib" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\image_libs" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" /I "C:\I\SC\vs90\boinc" /I "C:\I\SC\vs90\boinc\api" /I "C:\I\SC\vs90\boinc\client\win" /I "C:\I\SC\vs90\boinc\lib" /D "WIN32" /D "_WIN32" /D "_WINDOWS" /D "NBOINC_APP_GRAPHICS" /D "CLIENT" /D "_MT" /D "USE_IPP" /D "USE_SSE2" /D "_DEBUG" /D "_VC80_UPGRADE=0x0600" /D "_MBCS" /GF /Gm /EHsc /MTd /Zp16 /Gy /Fp".\Release/seti_boinc.pch" /Fo".\Release32-NOGFX\\" /Fd".\Release32-NOGFX\vc90.pdb" /FR".\Release32-NOGFX\\" /W3 /c /Wp64 /Zi /TP "..\..\db\xml_util.cpp"
"..\worker.cpp"
"..\..\..\boinc\api\windows_opengl.C"
"..\version.cpp"
"..\..\..\boinc\lib\util.C"
"..\timecvt.cpp"
"..\..\image_libs\tgalib.cpp"
"..\..\db\sqlrow.cpp"
"..\..\db\sqlblob.cpp"
"..\spike.cpp"
"..\..\..\boinc\lib\shmem.C"
"..\seti_header.cpp"
"..\seti.cpp"
"..\..\db\schema_master.cpp"
"..\sah_gfx_base.cpp"
"..\sah_gfx.cpp"
"..\s_util.cpp"
"..\pulsefind.cpp"
"..\progress.cpp"
"..\..\..\boinc\lib\parse.C"
"..\malloc_a.cpp"
"..\main.cpp"
"..\lcgamm.cpp"
"..\..\..\boinc\api\gutil.C"
"..\..\..\boinc\api\graphics_data.C"
"..\..\..\boinc\api\graphics_api.C"
"..\gdata.cpp"
"..\gaussfit.cpp"
"..\..\..\boinc\lib\filesys.C"
"..\fft8g.cpp"
"..\chirpfft.cpp"
"..\..\..\boinc\api\boinc_api.C"
"..\..\..\boinc\lib\app_ipc.C"
"..\analyzeReport.cpp"
"..\analyzePoT.cpp"
"..\analyzeFuncs.cpp"
analyzeFuncs.cpp
-----IPP-----
-----SSE2-----
analyzePoT.cpp
--- BenSpectrum ---
analyzeReport.cpp
app_ipc.C
boinc_api.C
chirpfft.cpp
fft8g.cpp
filesys.C
gaussfit.cpp
gdata.cpp
graphics_api.C
graphics_data.C
gutil.C
lcgamm.cpp
main.cpp
malloc_a.cpp
parse.C
progress.cpp
pulsefind.cpp
s_util.cpp
Generating Code...
Compiling...
sah_gfx.cpp
sah_gfx_base.cpp
schema_master.cpp
seti.cpp
seti_header.cpp
..\seti_header.cpp(93) : warning C4267: 'initializing' : conversion from 'size_t' to 'int', possible loss of data
shmem.C
spike.cpp
sqlblob.cpp
sqlrow.cpp
tgalib.cpp
timecvt.cpp
util.C
version.cpp
windows_opengl.C
worker.cpp
xml_util.cpp
Generating Code...
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\db\xml_util.cpp(663) : warning C4717: 'xml_match_tag' : recursive on all control paths, function will cause runtime stack overflow
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\db\xml_util.cpp(689) : warning C4717: 'xml_find_tag' : recursive on all control paths, function will cause runtime stack overflow
Linking...
Microsoft (R) Incremental Linker Version 9.00.20404
Copyright (C) Microsoft Corporation. All rights reserved.
"/OUT:.\Release32-NOGFX\seti_boinc.exe" "/LIBPATH:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer\Release32-NOGFX" "/LIBPATH:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" "/LIBPATH:C:\I\INTEL\IPP\5.2_beta\ia32\lib" "/LIBPATH:C:\I\INTEL\MKL\9.0\ia32\lib" "/LIBPATH:C:\I\VS9\VC\lib" "/LIBPATH:C:\masm32\lib" "/LIBPATH:C:\I\SDK\Lib" "/LIBPATH:C:\masm32\m32lib" "/LIBPATH:C:\I\SDK\Lib\IA64" "/LIBPATH:C:\I\SDK\Lib\AMD64" /MANIFEST:NO "/MANIFESTUAC:level='asInvoker' uiAccess='false'" /DEBUG "/PDB:c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\seti_boinc.pdb" /MAP /SUBSYSTEM:WINDOWS /DYNAMICBASE:NO /MACHINE:X86 glut32.lib glu32.lib Optimizer.lib image_libs.lib jpeglib.lib libboinc.lib libboincapi.lib non_ICC.lib setiboincdb.lib ippsmerged.lib ippvmmerged.lib ippchmerged.lib ippcorel.lib delayimp.lib libcpmtd.lib WinMM.lib OpenGL32.lib Kernel32.Lib oldnames.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib
".\Release32-NOGFX\analyzeFuncs.obj"
".\Release32-NOGFX\analyzePoT.obj"
".\Release32-NOGFX\analyzeReport.obj"
".\Release32-NOGFX\app_ipc.obj"
".\Release32-NOGFX\boinc_api.obj"
".\Release32-NOGFX\chirpfft.obj"
".\Release32-NOGFX\fft8g.obj"
".\Release32-NOGFX\filesys.obj"
".\Release32-NOGFX\gaussfit.obj"
".\Release32-NOGFX\gdata.obj"
".\Release32-NOGFX\graphics_api.obj"
".\Release32-NOGFX\graphics_data.obj"
".\Release32-NOGFX\gutil.obj"
".\Release32-NOGFX\lcgamm.obj"
".\Release32-NOGFX\main.obj"
".\Release32-NOGFX\malloc_a.obj"
".\Release32-NOGFX\parse.obj"
".\Release32-NOGFX\progress.obj"
".\Release32-NOGFX\pulsefind.obj"
".\Release32-NOGFX\s_util.obj"
".\Release32-NOGFX\sah_gfx.obj"
".\Release32-NOGFX\sah_gfx_base.obj"
".\Release32-NOGFX\schema_master.obj"
".\Release32-NOGFX\seti.obj"
".\Release32-NOGFX\seti_header.obj"
".\Release32-NOGFX\shmem.obj"
".\Release32-NOGFX\spike.obj"
".\Release32-NOGFX\sqlblob.obj"
".\Release32-NOGFX\sqlrow.obj"
".\Release32-NOGFX\tgalib.obj"
".\Release32-NOGFX\timecvt.obj"
".\Release32-NOGFX\util.obj"
".\Release32-NOGFX\version.obj"
".\Release32-NOGFX\windows_opengl.obj"
".\Release32-NOGFX\worker.obj"
".\Release32-NOGFX\xml_util.obj"
Creating browse information file...
Microsoft Browse Information Maintenance Utility Version 9.00.20404
Copyright (C) Microsoft Corporation. All rights reserved.
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
seti_boinc - 0 error(s), 3 warning(s)
========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ==========
regards heinz ;D
-
Merci Gecko,
it shows that Orcas Version 9.0.20404.0 Beta1 is usable to compile the seti_app. ;D
Next step is testing and debugging aplication.
Work is going on.
regards Heinz
-
The test shows that there are problems in seti_parse_wu_header.
--------------------------------
here is the Callers graph
main ---> it goes to worker()
run_stage = POSTINIT;
retval = boinc_init();
if ( !retval ) worker(); <-------
worker.cpp(239): retval = read_wu_state(); <------
read_wu_state() <--------
Calls to 'seti_parse_wu' ----->
worker.cpp(136): retval = seti_parse_wu( f, analysis_state );
Calls to 'seti_parse_wu_header' ----->
seti.cpp(1004): retval = seti_parse_wu_header( f );
before the statement
buffer += buf;
debugger show: --->
+ buf 0x0012edc4 "</workunit_header>
" char [256]
+ buffer "<workunit_header>
<name>01mr99ab.14893.2848.703400.3.151</name>
<group_info>
<tape_info>
<name>01mr99ab</name>
<start_time>2451239.5778227</start_time>
<last_block_time>2451239.5778227</last_block_time>
<last_block_done>2848</last_block_done>
<missed>0</missed>
<tape_quality>0</tape_quality>
<sb_id>0</sb_id>
</tape_info>
<nam std::basic_string<char,std::char_traits<char>,std::allocator<char> >
...... the whole WU is filled in last shows --->
<subband_desc>
<number>151</number>
<center>1418978879.8359</center>
<base>1418974607.375</base>
<sample_rate>9765.625</sample_rate>
</subband_desc>
<sb_id>0</sb_id>
-----------------------------------------------------------------------------------
after the statement above we can see tha last entry
</workunit_header>
is done now..... so far OK
if ( wu ) delete wu;
wu = new workunit( buffer ); <-------------- here is a problem
buffer is filled properly
it starts with --->
<workunit_header>
<name>01mr99ab.14893.2848.703400.3.151</name>
<group_info>
<tape_info>
<name>01mr99ab</name>
<start_time>2451239.5778227</start_time>
....
....
ended with
<subband_desc>
<number>151</number>
<center>1418978879.8359</center>
<base>1418974607.375</base>
<sample_rate>9765.625</sample_rate>
</subband_desc>
<sb_id>0</sb_id>
</workunit_header>
-------------------------------------------------------
ok
now we entry the statement
and switch to dbgnew.cpp
55 void *res = _nh_malloc_dbg( cb, 1, nBlockUse, szFileName, nLine );
we see all parameters are properly filled
cb 1544 unsigned int
nBlockUse 1 int
nLine 254 int
res 0x00000000 void *
+ szFileName 0x005db0e8 "..\seti_header.cpp" const char *
now we execute 55
we switch to dbgheap.c
269 void * pvBlk = _nh_malloc_dbg_impl(nSize, nhFlag, nBlockUse, szFileName, nLine, &errno_tmp);
we see all parameter are properly filled
+ &errno_tmp 0x0012ec8c int *
errno_tmp 0 int
nBlockUse 1 int
nLine 254 int
nSize 1544 unsigned int
nhFlag 1 int
pvBlk 0x0012edc5 void *
+ szFileName 0x005db0e8 "..\seti_header.cpp" const char *
now we execute 269
we switch to
239 pvBlk = _heap_alloc_dbg_impl(nSize, nBlockUse, szFileName, nLine, errno_tmp);
all parameters are properly filled
+ errno_tmp 0x0012ec8c int *
nBlockUse 1 int
nLine 254 int
nSize 1544 unsigned int
nhFlag 1 int
pvBlk 0x00000001 void *
+ szFileName 0x005db0e8 "..\seti_header.cpp" const char *
and execute 239
and come back
pvBlk 0x0037ab58 void *
how we can see pvBlk is filled
allocation was sucessful and we came back from dbgnew.cpp
66 return res;
res 0x0037ab58 void *
......
......
......
so we go on and come to xmemory
pointer allocate(size_type _Count)
{ // allocate array of _Count elements
return (_Allocate(_Count, (pointer)0));
debug shows ---->
_Count 7248 unsigned int
we switch to dbgheap
269 void * pvBlk = _nh_malloc_dbg_impl(nSize, nhFlag, nBlockUse, szFileName, nLine, &errno_tmp);
and see parameters are not properly filled
+ &errno_tmp 0x0012e9a4 int *
errno_tmp 0 int
nBlockUse 1 int
nLine 0 int
nSize 7248 unsigned int
nhFlag 0 int
pvBlk 0x0012ebd4 void *
+ szFileName 0x00000000 <Bad Ptr> const char *
-------------------------
szFileName has bad pointer
we switch to
239 pvBlk = _heap_alloc_dbg_impl(nSize, nBlockUse, szFileName, nLine, errno_tmp);
+ errno_tmp 0x0012e9a4 int *
nBlockUse 1 int
nLine 0 int
nSize 7248 unsigned int
nhFlag 0 int
pvBlk 0x00000000 void *
+ szFileName 0x00000000 <Bad Ptr> const char *
--------------------
and execute
.......
and came back to xmemory
pointer allocate(size_type _Count)
{ // allocate array of _Count elements
return (_Allocate(_Count, (pointer)0));
}
_Count 7248 unsigned int
+ this 0x0012ec74 std::allocator<char> * const
and execute
......
.......
come now to dbgheap.c
429 pHead = (_CrtMemBlockHeader *)_heap_alloc_base(blockSize);
debugger shows --->
blockSize 7284 unsigned int
nSize 7248 unsigned int
+ pHead 0x7c91ee18 {pBlockHeaderNext=0x83ec8b55 pBlockHeaderPrev=0x565308ec szFileName=0x8bfc5557 <Bad Ptr> ...} _CrtMemBlockHeader *
and execute
come now to malloc.c
121 if (__active_heap == __SYSTEM_HEAP) {
122 return HeapAlloc(_crtheap, 0, size ? size : 1);
debug shows --->
__active_heap 1 int
_crtheap 0x00370000 void *
size 7284 unsigned int
and execute
and come back to dbgheap
429 pHead = (_CrtMemBlockHeader *)_heap_alloc_base(blockSize);
debug shows ---->
‡ _heap_alloc_base returned 0x01220048 void *
blockSize 7284 unsigned int
nSize 7248 unsigned int
+ pHead 0x7c91ee18 {pBlockHeaderNext=0x83ec8b55 pBlockHeaderPrev=0x565308ec szFileName=0x8bfc5557 <Bad Ptr> ...} _CrtMemBlockHeader *
------------------
and execute
switch to
239 pvBlk = _heap_alloc_dbg_impl(nSize, nBlockUse, szFileName, nLine, errno_tmp);
debug shows ---->
‡ _heap_alloc_dbg_impl returned 0x01220068 void *
+ errno_tmp 0x0012e884 int *
nBlockUse 1 int
nLine 0 int
nSize 7248 unsigned int
nhFlag 0 int
pvBlk 0x00000000 void *
+ szFileName 0x00000000 <Bad Ptr> const char *
--------------
and execute
come to dbgheap.c
429 pHead = (_CrtMemBlockHeader *)_heap_alloc_base(blockSize);
debug shows ---->
blockSize 7284 unsigned int
nSize 7248 unsigned int
+ pHead 0x00000000 {pBlockHeaderNext=??? pBlockHeaderPrev=??? szFileName=??? ...} _CrtMemBlockHeader *
--------------
and execute
and switch to malloc.c
121 if (__active_heap == __SYSTEM_HEAP) {
122 return HeapAlloc(_crtheap, 0, size ? size : 1); <------here
debug shows --->
__active_heap 1 int
_crtheap 0x00370000 void *
size 7284 unsigned int
and get in 122 ----->
Unhandled exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
--------------------------------
wieso da nach 0x00030ffc geschrieben wird ist mir noch unklar
there again the errors:
First-chance exception at 0x7c93a321 in seti_boinc.exe: 0xC00000FD: Stack overflow.
First-chance exception at 0x7c812a7b in seti_boinc.exe: Microsoft C++ exception: std::bad_alloc at memory location 0x000337e4..
First-chance exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
Unhandled exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
------------------------------------------------
we look after blockSize
found in dbgheap.c line 421
421 blockSize = sizeof(_CrtMemBlockHeader) + nSize + nNoMansLandSize;
debug shows ----->
nSize = 7248
_CrtMemBlockHeader = {pBlockHeaderNext=??? pBlockHeaderPrev=??? szFileName=??? ...}
blockSize = 7284
nNoMansLandSize ----> can“t find it
--------------------------------------------------
uhhhhhhhhhh.... must search
any suggestions ???
heinz
-
The test shows that there are problems in seti_parse_wu_header.
...
--------------
and execute
and switch to malloc.c
121 if (__active_heap == __SYSTEM_HEAP) {
122 return HeapAlloc(_crtheap, 0, size ? size : 1); <------here
debug shows --->
__active_heap 1 int
_crtheap 0x00370000 void *
size 7284 unsigned int
and get in 122 ----->
Unhandled exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
--------------------------------
wieso da nach 0x00030ffc geschrieben wird ist mir noch unklar
there again the errors:
First-chance exception at 0x7c93a321 in seti_boinc.exe: 0xC00000FD: Stack overflow.
First-chance exception at 0x7c812a7b in seti_boinc.exe: Microsoft C++ exception: std::bad_alloc at memory location 0x000337e4..
First-chance exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
Unhandled exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
------------------------------------------------
we look after blockSize
found in dbgheap.c line 421
421 blockSize = sizeof(_CrtMemBlockHeader) + nSize + nNoMansLandSize;
debug shows ----->
nSize = 7248
_CrtMemBlockHeader = {pBlockHeaderNext=??? pBlockHeaderPrev=??? szFileName=??? ...}
blockSize = 7284
nNoMansLandSize ----> can“t find it
--------------------------------------------------
uhhhhhhhhhh.... must search
any suggestions ???
heinz
A possible explanation to read abaout your problem you can find here (http://www.codeguru.com/cpp/w-p/win32/tutorials/article.php/c9535__1) (VS6) or if you search at msdn.
-
Merci Urs ,
made this short sample and look what is going on there. It works, no error occured....means testsystem works correct.
int main(int argc, char* argv[])
{
char *buffer = new char[12];
delete [] buffer;
return 0;
}
--------------------------------------------------
reading the documentation of this problem in Codeguru...
looking now... searching differences....
Heinz
-
Compiled the whole stuff now new again
------------------------------------------------------------
------ Rebuild All started: Project: setiboincdb, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'setiboincdb', configuration 'Release32-NOGFX|Win32'
Compiling...
sqlblob.cpp
xml_util.cpp
sqlrow.cpp
sqlint8.cpp
Generating Code...
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\db\xml_util.cpp(663) : warning C4717: 'xml_match_tag' : recursive on all control paths, function will cause runtime stack overflow
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\db\xml_util.cpp(689) : warning C4717: 'xml_find_tag' : recursive on all control paths, function will cause runtime stack overflow
Creating library...
Microsoft (R) Library Manager Version 9.00.20404
Copyright (C) Microsoft Corporation. All rights reserved.
"/OUT:.\Release32-NOGFX\setiboincdb.lib" "/LIBPATH:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX"
".\Release32-NOGFX\sqlblob.obj"
".\Release32-NOGFX\sqlint8.obj"
".\Release32-NOGFX\sqlrow.obj"
".\Release32-NOGFX\xml_util.obj"
sqlint8.obj : warning LNK4221: no public symbols found; archive member will be inaccessible
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
setiboincdb - 0 error(s), 3 warning(s)
------ Rebuild All started: Project: Optimizer, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'Optimizer', configuration 'Release32-NOGFX|Win32'
Compiling...
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.20404 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved.
cl /Od /Ob2 /Oi /Ot /Oy /GT /I "../../../boinc/win_build" /I ".." /I "..\.." /I "..\..\..\boinc\lib" /I "../../../boinc/api" /I "../../db" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer" /I "C:\I\INTEL\IPP\5.2_beta\ia32\tools\staticlib" /I "C:\I\INTEL\IPP\5.2_beta\ia32\include" /D "USE_IPP" /D "USE_SSE2" /D "WIN32" /D "_WIN32" /D "_WINDOWS" /D "_CONSOLE" /D "_DEBUG" /D "_LIB" /D "_MT" /D "CLIENT" /D "NBOINC_APP_GRAPHICS" /D "_UNICODE" /D "UNICODE" /D "_VC80_UPGRADE=0x0710" /D "_MBCS" /GF /FD /EHsc /MTd /Zp16 /Gy /Fo"Release32-NOGFX\\" /Fd"Release32-NOGFX\vc90.pdb" /W3 /c /Wp64 /Zi /Gd /TP /FI "win-config.h" ".\AKfoldSSE.cpp"
".\opt_VIS2.cpp"
".\opt_VIS.cpp"
".\opt_SSE2.cpp"
".\opt_SSE.cpp"
".\opt_os_interface.cpp"
".\opt_MMX.cpp"
".\opt_MDMX.cpp"
".\opt_FPU.cpp"
".\opt_altivec.cpp"
".\opt_3Dnow.cpp"
".\opt_3Dnow+.cpp"
".\memspeed.cpp"
".\FoldTst.cpp"
".\cpuid_tbl.cpp"
".\cpu_x86.cpp"
".\BHSSEfold.cpp"
".\benchmark.cpp"
AKfoldSSE.cpp
-----IPP-----
-----SSE2/em-----
opt_VIS2.cpp
opt_VIS.cpp
opt_SSE2.cpp
opt_SSE.cpp
.\opt_SSE.cpp(147) : warning C4311: 'type cast' : pointer truncation from 'const float *__w64 ' to 'unsigned int'
opt_os_interface.cpp
.\opt_os_interface.cpp(92) : warning C4552: '<<' : operator has no effect; expected operator with side-effect
opt_MMX.cpp
opt_MDMX.cpp
opt_FPU.cpp
opt_altivec.cpp
opt_3Dnow.cpp
opt_3Dnow+.cpp
memspeed.cpp
FoldTst.cpp
cpuid_tbl.cpp
cpu_x86.cpp
.\cpu_x86.cpp(549) : warning C4311: 'type cast' : pointer truncation from 'void *' to 'uint32'
.\cpu_x86.cpp(550) : warning C4312: 'type cast' : conversion from 'uint32' to 'void *' of greater size
BHSSEfold.cpp
-----IPP-----
-----SSE2/em-----
benchmark.cpp
-----IPP-----
-----SSE2-----
-----ipp-----
-----sse2-----
Generating Code...
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(133) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(134) : warning C4700: uninitialized local variable 'sum2' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(163) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(164) : warning C4700: uninitialized local variable 'sum2' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(193) : warning C4700: uninitialized local variable 'tmp1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(194) : warning C4700: uninitialized local variable 'tmp2' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(195) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(196) : warning C4700: uninitialized local variable 'sum2' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(234) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(235) : warning C4700: uninitialized local variable 'sum2' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(271) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(272) : warning C4700: uninitialized local variable 'sum2' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(324) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(351) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(377) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\memspeed.cpp(402) : warning C4700: uninitialized local variable 'sum1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\opt_3dnow.cpp(105) : warning C4730: 'amd_tableSum2' : mixing _m64 and floating point expressions may result in incorrect code
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\opt_3dnow.cpp(103) : warning C4730: 'amd_tableSum2' : mixing _m64 and floating point expressions may result in incorrect code
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\opt_3dnow.cpp(148) : warning C4730: 'amd_f_sum' : mixing _m64 and floating point expressions may result in incorrect code
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\opt_sse2.cpp(404) : warning C4700: uninitialized local variable 'temp0' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\opt_sse2.cpp(405) : warning C4700: uninitialized local variable 'temp1' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\opt_sse2.cpp(406) : warning C4700: uninitialized local variable 'temp2' used
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\client\optimizer\opt_sse2.cpp(407) : warning C4700: uninitialized local variable 'temp3' used
Compiling...
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.20404 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved.
cl /Od /Ob2 /Oi /Ot /Oy /GT /I "../../../boinc/win_build" /I ".." /I "..\.." /I "..\..\..\boinc\lib" /I "../../../boinc/api" /I "../../db" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer" /I "C:\I\INTEL\IPP\5.2_beta\ia32\tools\staticlib" /I "C:\I\INTEL\IPP\5.2_beta\ia32\include" /D "USE_IPP" /D "USE_SSE2" /D "WIN32" /D "_WIN32" /D "_WINDOWS" /D "_CONSOLE" /D "_DEBUG" /D "_LIB" /D "_MT" /D "CLIENT" /D "NBOINC_APP_GRAPHICS" /D "_UNICODE" /D "UNICODE" /D "_VC80_UPGRADE=0x0710" /D "_MBCS" /GF /FD /EHsc /MTd /Zp16 /Gy /FA /Fa"Release32-NOGFX\\" /Fo"Release32-NOGFX\\" /Fd"Release32-NOGFX\vc90.pdb" /W3 /c /Wp64 /Zi /Gd /TP /FI "win-config.h" /fp:fast
".\opt_unopt.cpp"
opt_unopt.cpp
Compiling...
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.20404 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved.
cl /Od /Ob2 /Oi /Ot /Oy /GT /I "../../../boinc/win_build" /I ".." /I "..\.." /I "..\..\..\boinc\lib" /I "../../../boinc/api" /I "../../db" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer" /I "C:\I\INTEL\IPP\5.2_beta\ia32\tools\staticlib" /I "C:\I\INTEL\IPP\5.2_beta\ia32\include" /D "USE_SSE3" /D "USE_IPP" /D "USE_SSE2" /D "WIN32" /D "_WIN32" /D "_WINDOWS" /D "_CONSOLE" /D "_DEBUG" /D "_LIB" /D "_MT" /D "CLIENT" /D "NBOINC_APP_GRAPHICS" /D "_UNICODE" /D "UNICODE" /D "_VC80_UPGRADE=0x0710" /D "_MBCS" /GF /FD /EHsc /MTd /Zp16 /Gy /Fo"Release32-NOGFX\\" /Fd"Release32-NOGFX\vc90.pdb" /W3 /c /Wp64 /Zi /Gd /TP /FI "win-config.h" ".\opt_SSE3.cpp"
opt_SSE3.cpp
Creating library...
Microsoft (R) Library Manager Version 9.00.20404
Copyright (C) Microsoft Corporation. All rights reserved.
"/OUT:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX/Optimizer.lib" "/LIBPATH:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer\Release32-NOGFX" "/LIBPATH:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" Kernel32.Lib
".\Release32-NOGFX\AKfoldSSE.obj"
".\Release32-NOGFX\benchmark.obj"
".\Release32-NOGFX\BHSSEfold.obj"
".\Release32-NOGFX\cpu_x86.obj"
".\Release32-NOGFX\cpuid_tbl.obj"
".\Release32-NOGFX\FoldTst.obj"
".\Release32-NOGFX\memspeed.obj"
".\Release32-NOGFX\opt_3Dnow+.obj"
".\Release32-NOGFX\opt_3Dnow.obj"
".\Release32-NOGFX\opt_altivec.obj"
".\Release32-NOGFX\opt_FPU.obj"
".\Release32-NOGFX\opt_MDMX.obj"
".\Release32-NOGFX\opt_MMX.obj"
".\Release32-NOGFX\opt_os_interface.obj"
".\Release32-NOGFX\opt_SSE.obj"
".\Release32-NOGFX\opt_SSE2.obj"
".\Release32-NOGFX\opt_SSE3.obj"
".\Release32-NOGFX\opt_unopt.obj"
".\Release32-NOGFX\opt_VIS.obj"
".\Release32-NOGFX\opt_VIS2.obj"
opt_VIS.obj : warning LNK4221: no public symbols found; archive member will be inaccessible
opt_MDMX.obj : warning LNK4221: no public symbols found; archive member will be inaccessible
opt_altivec.obj : warning LNK4221: no public symbols found; archive member will be inaccessible
opt_3Dnow+.obj : warning LNK4006: "void __fastcall copy_MMX(char *,char const *,int)" (?copy_MMX@@YIXPADPBDH@Z) already defined in opt_MMX.obj; second definition ignored
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer\Release32-NOGFX\BuildLog.htm"
Optimizer - 0 error(s), 31 warning(s)
------ Rebuild All started: Project: seti_boinc, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'seti_boinc', configuration 'Release32-NOGFX|Win32'
Compiling...
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.20404 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved.
cl /Od /Ob2 /Oi /Ot /Oy /GT /I "." /I "../../../boinc/api" /I "../../../boinc/client/win" /I "../../../boinc/lib" /I ".." /I "glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\db" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\jpeglib" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\image_libs" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" /I "C:\I\SC\vs90\boinc" /I "C:\I\SC\vs90\boinc\api" /I "C:\I\SC\vs90\boinc\client\win" /I "C:\I\SC\vs90\boinc\lib" /D "WIN32" /D "_WIN32" /D "_WINDOWS" /D "NBOINC_APP_GRAPHICS" /D "CLIENT" /D "_MT" /D "USE_IPP" /D "USE_SSE2" /D "_DEBUG" /D "_VC80_UPGRADE=0x0600" /D "_MBCS" /GF /Gm /EHsc /MTd /Zp16 /Gy /Fp".\Release/seti_boinc.pch" /Fo".\Release32-NOGFX\\" /Fd".\Release32-NOGFX\vc90.pdb" /FR".\Release32-NOGFX\\" /W3 /c /Wp64 /Zi /TP "..\..\db\xml_util.cpp"
"..\worker.cpp"
"..\..\..\boinc\api\windows_opengl.C"
"..\version.cpp"
"..\..\..\boinc\lib\util.C"
"..\timecvt.cpp"
"..\..\image_libs\tgalib.cpp"
"..\..\db\sqlrow.cpp"
"..\..\db\sqlblob.cpp"
"..\spike.cpp"
"..\..\..\boinc\lib\shmem.C"
"..\seti_header.cpp"
"..\seti.cpp"
"..\..\db\schema_master.cpp"
"..\sah_gfx_base.cpp"
"..\sah_gfx.cpp"
"..\s_util.cpp"
"..\pulsefind.cpp"
"..\progress.cpp"
"..\..\..\boinc\lib\parse.C"
"..\malloc_a.cpp"
"..\main.cpp"
"..\lcgamm.cpp"
"..\..\..\boinc\api\gutil.C"
"..\..\..\boinc\api\graphics_data.C"
"..\..\..\boinc\api\graphics_api.C"
"..\gdata.cpp"
"..\gaussfit.cpp"
"..\..\..\boinc\lib\filesys.C"
"..\fft8g.cpp"
"..\chirpfft.cpp"
"..\..\..\boinc\api\boinc_api.C"
"..\..\..\boinc\lib\app_ipc.C"
"..\analyzeReport.cpp"
"..\analyzePoT.cpp"
analyzePoT.cpp
--- BenSpectrum ---
analyzeReport.cpp
app_ipc.C
boinc_api.C
chirpfft.cpp
fft8g.cpp
filesys.C
gaussfit.cpp
gdata.cpp
graphics_api.C
graphics_data.C
gutil.C
lcgamm.cpp
main.cpp
malloc_a.cpp
parse.C
progress.cpp
pulsefind.cpp
s_util.cpp
sah_gfx.cpp
Generating Code...
Compiling...
sah_gfx_base.cpp
schema_master.cpp
seti.cpp
seti_header.cpp
..\seti_header.cpp(93) : warning C4267: 'initializing' : conversion from 'size_t' to 'int', possible loss of data
shmem.C
spike.cpp
sqlblob.cpp
sqlrow.cpp
tgalib.cpp
timecvt.cpp
util.C
version.cpp
windows_opengl.C
worker.cpp
xml_util.cpp
Generating Code...
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\db\xml_util.cpp(663) : warning C4717: 'xml_match_tag' : recursive on all control paths, function will cause runtime stack overflow
c:\i\sc\vs90\seti_boinc_2k3_2.2b-ben-joe\db\xml_util.cpp(689) : warning C4717: 'xml_find_tag' : recursive on all control paths, function will cause runtime stack overflow
Compiling...
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.20404 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved.
cl /Od /Ob2 /Oi /Ot /Oy /GT /I "." /I "../../../boinc/api" /I "../../../boinc/client/win" /I "../../../boinc/lib" /I ".." /I "glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\db" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\jpeglib" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\image_libs" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" /I "C:\I\SC\vs90\boinc" /I "C:\I\SC\vs90\boinc\api" /I "C:\I\SC\vs90\boinc\client\win" /I "C:\I\SC\vs90\boinc\lib" /D "WIN32" /D "_WIN32" /D "_WINDOWS" /D "NBOINC_APP_GRAPHICS" /D "CLIENT" /D "_MT" /D "USE_IPP" /D "USE_SSE2" /D "_DEBUG" /D "_VC80_UPGRADE=0x0600" /D "_MBCS" /GF /Gm /EHsc /MTd /Zp16 /Gy /Fp".\Release/seti_boinc.pch" /Fo".\Release32-NOGFX\\" /Fd".\Release32-NOGFX\vc90.pdb" /FR".\Release32-NOGFX\\" /W3 /c /Wp64 /Zi /TP "..\analyzeFuncs.cpp"
analyzeFuncs.cpp
-----IPP-----
-----SSE2-----
Linking...
Microsoft (R) Incremental Linker Version 9.00.20404
Copyright (C) Microsoft Corporation. All rights reserved.
"/OUT:.\Release32-NOGFX\seti_boinc.exe" "/LIBPATH:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer\Release32-NOGFX" "/LIBPATH:C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" "/LIBPATH:C:\I\INTEL\IPP\5.2_beta\ia32\lib" "/LIBPATH:C:\I\INTEL\MKL\9.0\ia32\lib" "/LIBPATH:C:\I\VS9\VC\lib" "/LIBPATH:C:\masm32\lib" "/LIBPATH:C:\I\SDK\Lib" "/LIBPATH:C:\masm32\m32lib" "/LIBPATH:C:\I\SDK\Lib\IA64" "/LIBPATH:C:\I\SDK\Lib\AMD64" /MANIFEST:NO "/MANIFESTUAC:level='asInvoker' uiAccess='false'" /DEBUG "/PDB:c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\seti_boinc.pdb" /MAP /SUBSYSTEM:WINDOWS /DYNAMICBASE:NO /MACHINE:X86 glut32.lib glu32.lib Optimizer.lib image_libs.lib jpeglib.lib libboinc.lib libboincapi.lib non_ICC.lib setiboincdb.lib ippsmerged.lib ippvmmerged.lib ippchmerged.lib ippcorel.lib delayimp.lib libcpmtd.lib WinMM.lib OpenGL32.lib Kernel32.Lib oldnames.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib
".\Release32-NOGFX\analyzeFuncs.obj"
".\Release32-NOGFX\analyzePoT.obj"
".\Release32-NOGFX\analyzeReport.obj"
".\Release32-NOGFX\app_ipc.obj"
".\Release32-NOGFX\boinc_api.obj"
".\Release32-NOGFX\chirpfft.obj"
".\Release32-NOGFX\fft8g.obj"
".\Release32-NOGFX\filesys.obj"
".\Release32-NOGFX\gaussfit.obj"
".\Release32-NOGFX\gdata.obj"
".\Release32-NOGFX\graphics_api.obj"
".\Release32-NOGFX\graphics_data.obj"
".\Release32-NOGFX\gutil.obj"
".\Release32-NOGFX\lcgamm.obj"
".\Release32-NOGFX\main.obj"
".\Release32-NOGFX\malloc_a.obj"
".\Release32-NOGFX\parse.obj"
".\Release32-NOGFX\progress.obj"
".\Release32-NOGFX\pulsefind.obj"
".\Release32-NOGFX\s_util.obj"
".\Release32-NOGFX\sah_gfx.obj"
".\Release32-NOGFX\sah_gfx_base.obj"
".\Release32-NOGFX\schema_master.obj"
".\Release32-NOGFX\seti.obj"
".\Release32-NOGFX\seti_header.obj"
".\Release32-NOGFX\shmem.obj"
".\Release32-NOGFX\spike.obj"
".\Release32-NOGFX\sqlblob.obj"
".\Release32-NOGFX\sqlrow.obj"
".\Release32-NOGFX\tgalib.obj"
".\Release32-NOGFX\timecvt.obj"
".\Release32-NOGFX\util.obj"
".\Release32-NOGFX\version.obj"
".\Release32-NOGFX\windows_opengl.obj"
".\Release32-NOGFX\worker.obj"
".\Release32-NOGFX\xml_util.obj"
Creating browse information file...
Microsoft Browse Information Maintenance Utility Version 9.00.20404
Copyright (C) Microsoft Corporation. All rights reserved.
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
seti_boinc - 0 error(s), 3 warning(s)
------ Rebuild All started: Project: libboincapi, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'libboincapi', configuration 'Release32-NOGFX|Win32'
Compiling...
boinc_api.C
windows_opengl.C
texture.C
reduce_main.C
reduce_lib.C
gutil_text.C
gutil.C
graphics_impl.C
graphics_data.C
graphics_api.C
Generating Code...
Creating library...
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
libboincapi - 0 error(s), 0 warning(s)
------ Rebuild All started: Project: libboinc, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'libboinc', configuration 'Release32-NOGFX|Win32'
Compiling...
app_ipc.C
util.C
stackwalker_win.cpp
shmem.C
proxy_info.C
prefs.C
parse.C
miofile.C
mfile.C
mem_usage.C
md5_file.C
md5.c
hostinfo.C
filesys.C
diagnostics_win.C
diagnostics.C
Generating Code...
Creating library...
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
libboinc - 0 error(s), 0 warning(s)
------ Rebuild All started: Project: jpeglib, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'jpeglib', configuration 'Release32-NOGFX|Win32'
Compiling...
jcapimin.c
rdtarga.c
rdswitch.c
rdrle.c
rdppm.c
rdgif.c
rdcolmap.c
rdbmp.c
jutils.c
jquant2.c
jquant1.c
jmemnobs.c
jmemmgr.c
jidctred.c
jidctint.c
jidctfst.c
jidctflt.c
jfdctint.c
jfdctfst.c
jfdctflt.c
Generating Code...
Compiling...
jerror.c
jdtrans.c
jdsample.c
jdpostct.c
jdphuff.c
jdmerge.c
jdmaster.c
jdmarker.c
jdmainct.c
jdinput.c
jdhuff.c
jddctmgr.c
jdcolor.c
jdcoefct.c
jdatasrc.c
jdatadst.c
jdapistd.c
jdapimin.c
jctrans.c
jcsample.c
Generating Code...
Compiling...
jcprepct.c
jcphuff.c
jcparam.c
jcomapi.c
jcmaster.c
jcmarker.c
jcmainct.c
jcinit.c
jchuff.c
jcdctmgr.c
jccolor.c
jccoefct.c
jcapistd.c
Generating Code...
Creating library...
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
jpeglib - 0 error(s), 0 warning(s)
------ Rebuild All started: Project: image_libs, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'image_libs', configuration 'Release32-NOGFX|Win32'
Compiling...
bmplib.cpp
tgalib.cpp
Generating Code...
Creating library...
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
image_libs - 0 error(s), 0 warning(s)
------ Rebuild All started: Project: glut32, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'glut32', configuration 'Release32-NOGFX|Win32'
Compiling...
glut_roman.c
win32_x11.c
win32_util.c
win32_glx.c
glut_swidth.c
glut_stroke.c
Generating Code...
Creating library...
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
glut32 - 0 error(s), 0 warning(s)
------ Rebuild All started: Project: non_ICC, Configuration: Release32-NOGFX Win32 ------
Deleting intermediate and output files for project 'non_ICC', configuration 'Release32-NOGFX|Win32'
Compiling...
cl : Command line warning D9025 : overriding '/Od' with '/O2'
cl : Command line warning D9035 : option 'Og' has been deprecated and will be removed in a future release
dummy_code.cpp
Creating library...
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\non_ICC\Release32-NOGFX\BuildLog.htm"
non_ICC - 0 error(s), 2 warning(s)
========== Rebuild All: 9 succeeded, 0 failed, 0 skipped ==========
-
Hallo Heinz,
have you managed to run some WUs successfully with the apps you compiled on VS Orcas/2008?
Regards,
Simon.
-
Hi Simon,
answering your question: no till now.
In both applications the program runs into the same error with the allocation during retval = seti_parse_wu_header( f ); in seti.cpp
-------------
seti_header.cpp
254 wu = new workunit( buffer ); //seti_britta:here I have a problem
--------------
if we left xml_matchtag the last time, s is filled with the complete WU inclusive </workunit_header> means the wu is complete.
then we switch to xstring.c
__CLR_OR_THIS_CALL basic_string(const _Elem *_Ptr)
: _Mybase()
{ // construct from [_Ptr, <null>)
_Tidy();
assign(_Ptr);
}
and _Ptr points to the beginning of the wu.
--------------------------------------------------------------
then to xstring
1074 if (_Grow(_Count))
{ // make room and assign new stuff
_Traits_helper::copy_s<_Traits>(_Myptr(), _Myres, _Ptr, _Count);
_Eos(_Count);
}
_Count shows:
_Count 7232 unsigned int
-----------------------------------------------------------------------------------
then to xstring
2123 _Copy(_Newsize, _Mysize); // reallocate to grow
_Newsize shows:
_Newsize 7232 unsigned int
-----------------------------------------------------------------------------------
then to xstring
2093 _Ptr = _Mybase::_Alval.allocate(_Newres + 1);
_Newres shows:
_Newres 7247 unsigned int
-----------------------------------------------------------------------------------
then to xmemory 145
143 pointer allocate(size_type _Count)
144 { // allocate array of _Count elements
145 return (_Allocate(_Count, (pointer)0));
146 }
_Count shows:
_Count 7248 unsigned int
---------------------------------------------------------------------------------
then to xmemory 43
// allocate storage for _Count elements of type _Ty
43 return ((_Ty _FARQ *)::operator new(_Count * sizeof (_Ty)));
_Count 7248 unsigned int
--------------------------------------------------------------------------------------
then to new.cpp 59
59 while ((p = malloc(size)) == 0)
size 7248 unsigned int
p 0x0003195c void *
---------------------------------------------------------------------------------------
then to dbgmalloc 56
56 void *res = _nh_malloc_dbg(nSize, _newmode, _NORMAL_BLOCK, NULL, 0);
nSize 7248 unsigned int
res 0x00031a74 void *
-----------------------------------------------------------------------------------------
then to dbgheap.c 296
296 void * pvBlk = _nh_malloc_dbg_impl(nSize, nhFlag, nBlockUse, szFileName, nLine, &errno_tmp);
nSize 7248 unsigned int
nhFlag 0 int
nBlockUse 1 int
+ szFileName 0x00000000 <Bad Ptr> const char *
nLine 0 int
pvBlk 0x0062d2a8 void *
errno_tmp 0 int
--------------------------------------------------------------------------------------------
then to dbgheap.c 239
239 pvBlk = _heap_alloc_dbg_impl(nSize, nBlockUse, szFileName, nLine, errno_tmp);
nSize 7248 unsigned int
nhFlag 0 int
nBlockUse 1 int
+ szFileName 0x00000000 <Bad Ptr> const char *
nLine 0 int
pvBlk 0x00000000 void *
+ errno_tmp 0x000317a4 int *
----------------------------------------------------------------------------------------
then to dbgheap.c 429
429 pHead = (_CrtMemBlockHeader *)_heap_alloc_base(blockSize);
nSize 7248 unsigned int
nBlockUse 1 int
+ szFileName 0x00000000 <Bad Ptr> const char *
nLine 0 int
+ errno_tmp 0x000317a4 int *
blockSize 7284 unsigned int
lRequest 7306 long
+ pHead 0x00000000 {pBlockHeaderNext=??? pBlockHeaderPrev=??? szFileName=??? ...} _CrtMemBlockHeader *
retval 0x00000000 void *
fIgnore 0 int
-----------------------------------------------------------------------------------------
then to malloc.c 129
129 return HeapAlloc(_crtheap, 0, size ? size : 1); <------problem app crashes
size 7284 unsigned int
pvReturn 0x00000001 void *
Unhandled exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
the errors from output:
First-chance exception at 0x7c93a321 in seti_boinc.exe: 0xC00000FD: Stack overflow.
First-chance exception at 0x7c812a7b in seti_boinc.exe: Microsoft C++ exception: std::bad_alloc at memory location 0x000337e4..
First-chance exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
Unhandled exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
---------------------------------------------------
I did read the hints from Urs, but till now I did not found a solution of this problem...
----------------------------------------------------------------------------------------------------------------------
regards heinz
-
Hi all,
At the moment I“m testing the mmx client.
be patient, work is going on.
regards heinz
-
Hi all,
At the moment I╢m testing the mmx client.
be patient, work is going on.
regards heinz
Very cool Heinz! Good luck!
-
Hi folks,
the summer and the vacations are over so I am back.
my diskless dual 200MMX is now in the case and running again.
pulsefind.cpp ---> its necessary to have a look on it to make some optimizations.
regards heinz~seti_britta
-
pulsefind.cpp ---> squeezed the code.
it compiles well --->
------ Build started: Project: seti_boinc, Configuration: Release32-NOGFX Win32 ------
Compiling...
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 15.00.20404 for 80x86
Copyright (C) Microsoft Corporation. All rights reserved.
cl /Od /Ob2 /Oi /Ot /Oy /GT /I "." /I "../../../boinc/api" /I "../../../boinc/client/win" /I "../../../boinc/lib" /I ".." /I "glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\db" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\glut" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\jpeglib" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\Optimizer" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\image_libs" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build" /I "C:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX" /I "C:\I\SC\vs90\boinc" /I "C:\I\SC\vs90\boinc\api" /I "C:\I\SC\vs90\boinc\client\win" /I "C:\I\SC\vs90\boinc\lib" /D "WIN32" /D "_WIN32" /D "_WINDOWS" /D "NBOINC_APP_GRAPHICS" /D "CLIENT" /D "_MT" /D "USE_IPP" /D "USE_SSE2" /D "_DEBUG" /D "_VC80_UPGRADE=0x0600" /D "_MBCS" /GF /Gm /EHsc /MTd /Zp16 /Gy /Fp".\Release/seti_boinc.pch" /Fo".\Release32-NOGFX\\" /Fd".\Release32-NOGFX\vc90.pdb" /FR".\Release32-NOGFX\\" /W3 /c /Wp64 /Zi /TP "..\pulsefind.cpp"
pulsefind.cpp
Build log was saved at "file://c:\I\SC\vs90\seti_boinc_2k3_2.2B-Ben-Joe\client\win_build\Release32-NOGFX\BuildLog.htm"
seti_boinc - 0 error(s), 0 warning(s)
========== Build: 1 succeeded, 0 failed, 0 up-to-date, 0 skipped ==========
new FPU-optimized folding subroutines are short, very compact and hopefull quick
heinz ~seti_britta ;D
-
Did you compile whole client under Orcas already?
Any performance comparision?
-
Did you compile whole client under Orcas already?
Any performance comparision?
yes whole client is compiled, read one site back and you can see it.
I get still a stackoverflow when execute... so no performance comparison are possible at time.
I“m serching... maybe its a alloc problem.
-
Compiled now FFTW-3.1.2 under Orcas too
here is the first result ---->
fftw-3.1.2 benchfsse(orcas) started
benchf_sse.exe -opatient 64 128 256 512 1024 2048 4096
Problem: 64, setup: 32.54 ms, time: 2.33 us, ``mflops'': 823.7
Problem: 128, setup: 79.49 ms, time: 6.43 us, ``mflops'': 697.23
Problem: 256, setup: 196.37 ms, time: 14.25 us, ``mflops'': 718.72
Problem: 512, setup: 470.92 ms, time: 31.01 us, ``mflops'': 743
Problem: 1024, setup: 866.86 ms, time: 70.68 us, ``mflops'': 724.4
Problem: 2048, setup: 2.17 s, time: 155.61 us, ``mflops'': 723.88
Problem: 4096, setup: 7.27 s, time: 329.37 us, ``mflops'': 746.15
fftw-3.1.2 benchfsse ended.
-----------------------------------------------------------------------------------------------------
It shows that this complex FFTW project compiles fine and run with Orcas too.
regards heinz ;D
-
Hi Jason,
here are some short comments to compile FFTW-3.1.2
there are 3 projects in FFTW
1. bench
2. libfftw
3. wisdom
----------------------------------------------------------------------------
before you can compile, you must make some individual settings in config.h
you found config.h in the root of fftw-3.1.2
read docu for understanding.....
at first we must compile libfftw to create the library
then we can compile bench and link against this library to get the bench.exe file.
if you set this in the project-dependencies you need still call bench for compile the two
-------------------------------------------------------------------------------
------ Rebuild All started: Project: libfftw, Configuration: Release float SSE Win32 ------
Deleting intermediate and output files for project 'libfftw', configuration 'Release float SSE|Win32'
Compiling...
sse2.c
sse.c
Generating Code...
Compiling...
apiplan.c
version.c
the-planner.c
rdft2-pad.c
print-plan.c
plan-r2r.c
plan-r2r-3d.c
plan-r2r-2d.c
plan-r2r-1d.c
plan-many-r2r.c
plan-many-dft.c
plan-many-dft-r2c.c
plan-many-dft-c2r.c
plan-guru-split-dft.c
........ and so on... there are ~ 100 programs
........
buffered.c
awake.c
assert.c
alloc.c
Generating Code...
Compiling...
align.c
Generating Code...
Creating library...
Build log was saved at "file://c:\I\SC\vs90\fftw-3.1.2\win32\libfftw___Win32_Release_float_SSE\BuildLog.htm"
libfftw - 0 error(s), 50 warning(s)
========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ==========
now we compile bench ----->
------ Rebuild All started: Project: bench, Configuration: Release float SSE Win32 ------
Deleting intermediate and output files for project 'bench', configuration 'Release float SSE|Win32'
Compiling...
zero.c
verify.c
verify-rdft2.c
verify-r2r.c
..\libbench2\verify-r2r.c(182) : warning C4244: '=' : conversion from 'double' to 'R', possible loss of data
..\libbench2\verify-r2r.c(327) : warning C4244: '=' : conversion from 'trigreal' to 'R', possible loss of data
..\libbench2\verify-r2r.c(412) : warning C4244: 'function' : conversion from 'trigreal' to 'R', possible loss of data
..\libbench2\verify-r2r.c(440) : warning C4244: '=' : conversion from 'double' to 'R', possible loss of data
..\libbench2\verify-r2r.c(441) : warning C4244: '=' : conversion from 'double' to 'R', possible loss of data
..\libbench2\verify-r2r.c(478) : warning C4244: '=' : conversion from 'double' to 'R', possible loss of data
..\libbench2\verify-r2r.c(650) : warning C4244: 'function' : conversion from 'double' to 'R', possible loss of data
verify-lib.c
..\libbench2\verify-lib.c(83) : warning C4244: '=' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\verify-lib.c(84) : warning C4244: '=' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\verify-lib.c(209) : warning C4244: '=' : conversion from 'trigreal' to 'bench_real', possible loss of data
..\libbench2\verify-lib.c(210) : warning C4244: '=' : conversion from 'trigreal' to 'bench_real', possible loss of data
..\libbench2\verify-lib.c(296) : warning C4244: 'initializing' : conversion from 'double' to 'R', possible loss of data
..\libbench2\verify-lib.c(312) : warning C4244: 'initializing' : conversion from 'double' to 'R', possible loss of data
..\libbench2\verify-lib.c(337) : warning C4244: '=' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\verify-lib.c(338) : warning C4244: '=' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\verify-lib.c(339) : warning C4244: '=' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\verify-lib.c(340) : warning C4244: '=' : conversion from 'double' to 'bench_real', possible loss of data
verify-dft.c
util.c
timer2.c
..\libbench2\timer2.c(30) : warning C4305: 'initializing' : truncation from 'double' to 'const float'
timer.c
tensor.c
speed.c
report.c
..\libbench2\report.c(97) : warning C4996: 'sprintf': This function or variable may be unsafe. Consider using sprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(366) : see declaration of 'sprintf'
..\libbench2\report.c(99) : warning C4996: 'sprintf': This function or variable may be unsafe. Consider using sprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(366) : see declaration of 'sprintf'
..\libbench2\report.c(101) : warning C4996: 'sprintf': This function or variable may be unsafe. Consider using sprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(366) : see declaration of 'sprintf'
..\libbench2\report.c(103) : warning C4996: 'sprintf': This function or variable may be unsafe. Consider using sprintf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(366) : see declaration of 'sprintf'
problem.c
..\libbench2\problem.c(254) : warning C4996: 'strcpy': This function or variable may be unsafe. Consider using strcpy_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\string.h(74) : see declaration of 'strcpy'
pow2.c
ovtpvt.c
my-getopt.c
mp.c
..\libbench2\mp.c(63) : warning C4244: '=' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\mp.c(271) : warning C4244: 'function' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\mp.c(358) : warning C4244: 'function' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\mp.c(359) : warning C4244: 'function' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\mp.c(368) : warning C4244: 'function' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\mp.c(369) : warning C4244: 'function' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\mp.c(409) : warning C4244: 'function' : conversion from 'int' to 'bench_real', possible loss of data
..\libbench2\mp.c(409) : warning C4244: 'function' : conversion from 'int' to 'bench_real', possible loss of data
..\libbench2\mp.c(410) : warning C4244: 'function' : conversion from 'int' to 'bench_real', possible loss of data
..\libbench2\mp.c(410) : warning C4244: 'function' : conversion from 'int' to 'bench_real', possible loss of data
..\libbench2\mp.c(502) : warning C4244: 'function' : conversion from 'double' to 'bench_real', possible loss of data
..\libbench2\mp.c(617) : warning C4244: 'function' : conversion from 'int' to 'bench_real', possible loss of data
mflops.c
main.c
info.c
Generating Code...
Compiling...
dotens2.c
caset.c
can-do.c
bench-main.c
aset.c
allocate.c
aligned-main.c
Generating Code...
Compiling...
hook.c
bench.c
..\tests\bench.c(59) : warning C4996: 'sscanf': This function or variable may be unsafe. Consider using sscanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(324) : see declaration of 'sscanf'
..\tests\bench.c(63) : warning C4996: 'sscanf': This function or variable may be unsafe. Consider using sscanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(324) : see declaration of 'sscanf'
..\tests\bench.c(64) : warning C4996: 'sscanf': This function or variable may be unsafe. Consider using sscanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(324) : see declaration of 'sscanf'
..\tests\bench.c(87) : warning C4996: 'fopen': This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(237) : see declaration of 'fopen'
..\tests\bench.c(114) : warning C4996: 'fopen': This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.
c:\I\VS9\VC\include\stdio.h(237) : see declaration of 'fopen'
Generating Code...
Linking...
Embedding manifest...
Build log was saved at "file://c:\I\SC\vs90\fftw-3.1.2\win32\bench___Win32_Release_float_SSE\BuildLog.htm"
bench - 0 error(s), 40 warning(s)
========== Rebuild All: 2 succeeded, 0 failed, 0 skipped ==========
all compiles fine and we found the bench.exe in the root of \fftw-3.1.2
howto run bench.exe ----> see previous post
yes, thats it... ;D
regards heinz
-
Okay that's great Heinz, I have many questions about the FFTW build attempts (both Orcas & 2005). I may have to build this under vs2005 (with or without ICC). I have had to stop my g++ build three times because it used up my whole machine for too long. How long did the 100+ .C files take to build, on what kind of machine? do you still have the build log?
Did you choose many options in config.h? Were they selected for DLL or static lib., single float, single threaded or was that in VS2005 settings or both? Are these the correct ones for seti? (been with Intel libraries until now) Under the MingW g++ build i was able to run the configure script so it chose those for me for the most part, there are still some I am not sure about...
And may have to try a build in VS2005 because ir's too heavy load for my poor little old machine :( ... strangely the vs2005+ICC seti builds were rather quickly complete and relativelly trouble free.
Jason
-
Hi Jason,
1. I“m using a P4 2.66 MHZ no SSE3 1GB RAM
2. I need to compile the bench+fftwf under 2 minutes with Orcas
3. The buildprotokoll are atteched file fftw_SSE_build_prot.7z
4. Configuration Type : Static Library (.lib)
Whole Program Optimization : Use Link Time Code Generation
5. bench
5.1 Preprocessor Definitions: WIN32;NDEBUG;_CONSOLE;FFTW_SINGLE;BENCHFFT_SINGLE;HAVE_SSE
5.2 Codegeneration ---> Runtime Library : Multi-threaded (/MT)
5.3 Don“t forget to add the necessary "Additional Library Directories" in the Linker Section of bench“
----------------------------------------------------------------------
heinz
-
sorry forgot to attach the file
[attachment deleted by admin]
-
woohoo thanks :), will look after work & school today.
Jason
-
the stack overflow in parse_wu_header a history
--------------------------------------
I set a break at seti_header.cpp line 251
251 buffer += buf;
after the break buffer shows
<workunit_header>
<name>01mr99ab.14893.2848.703400.3.151</name>
<group_info>
<tape_info>
<name>01mr99ab</name>
<start_time>2451239.5778227</start_time>
<last_block_time>2451239.5778227</last_block_time>
<last_block_done>2848</last_block_done>
<missed>0</missed>
<tape_quality>0</tape_quality>
<sb_id>0</sb_id>
</tape_info>
<name>01mr99ab.14893.2848.703400.3</name>
<data_desc>
<start_ra>8.3103311246938</start_ra>
<start_dec>27.91552777321</start_dec>
<end_ra>8.3542955650728</end_ra>
<end_dec>27.83540577987</end_dec>
<true_angle_range>0.60488405578199</true_angle_range>
<time_recorded>Tue Mar 2 01:52:05 1999</time_recorded>
<time_recorded_jd>2451239.5778356</time_recorded_jd>
<nsamples>1048576</nsamples>
<coords>
<coordinate_t>
<time>2451239.5778356</time>
<ra>8.3103311246938</ra>
<dec>27.91552777321</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5778934</time>
<ra>8.3125413024574</ra>
<dec>27.911197182893</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5779514</time>
<ra>8.3147416668476</ra>
<dec>27.90693256333</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5780093</time>
<ra>8.3169450560065</ra>
<dec>27.902621906048</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.578067</time>
<ra>8.3191452260533</ra>
<dec>27.898298175788</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.578125</time>
<ra>8.3213405864986</ra>
<dec>27.894014752898</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5781829</time>
<ra>8.3217405142933</ra>
<dec>27.899328820752</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5782407</time>
<ra>8.3236184661523</ra>
<dec>27.896734172274</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5782985</time>
<ra>8.325834215088</ra>
<dec>27.892305831529</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5783565</time>
<ra>8.3280041431626</ra>
<dec>27.888138576843</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5784144</time>
<ra>8.3302006840738</ra>
<dec>27.883798135736</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5784721</time>
<ra>8.332395258493</ra>
<dec>27.879438073973</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5785301</time>
<ra>8.3345999455565</ra>
<dec>27.875038063474</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5785878</time>
<ra>8.3367837326947</ra>
<dec>27.870706325634</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5786457</time>
<ra>8.3389835210763</ra>
<dec>27.866287225636</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5787037</time>
<ra>8.3411633518307</ra>
<dec>27.861977834223</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5787615</time>
<ra>8.3433656733927</ra>
<dec>27.857498886392</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5788193</time>
<ra>8.3455480635596</ra>
<dec>27.853130175559</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5788773</time>
<ra>8.3477402284459</ra>
<dec>27.848707725239</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5789352</time>
<ra>8.3499266964689</ra>
<dec>27.844286361793</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5789929</time>
<ra>8.3521124345577</ra>
<dec>27.839838544895</dec>
</coordinate_t>
<coordinate_t>
<time>2451239.5790508</time>
<ra>8.3542955650728</ra>
<dec>27.83540577987</dec>
</coordinate_t>
</coords>
</data_desc>
<receiver_cfg>
<s4_id>1</s4_id>
<name>ao1420</name>
<beam_width>0.0829999968</beam_width>
<center_freq>1420</center_freq>
<latitude>18.3538056</latitude>
<longitude>-66.7552222</longitude>
<elevation>497</elevation>
<diameter>168</diameter>
<az_orientation>0</az_orientation>
<az_corr_coeff length=49 encoding="x-csv">
7.4,5.4,-49.1,-1091,0,0,0,0,0,0,0,0,0
</az_corr_coeff>
<zen_corr_coeff length=53 encoding="x-csv">
-5146.7,66.1,14.3,321.7,0,0,0,0,0,0,0,0,0
</zen_corr_coeff>
</receiver_cfg>
<recorder_cfg>
<name>sah_ao1420</name>
<bits_per_sample>2</bits_per_sample>
<sample_rate>2500000</sample_rate>
<beams>1</beams>
<version>1.39999998</version>
</recorder_cfg>
<splitter_cfg>
<version>0.170000002</version>
<data_type>encoded</data_type>
<fft_len>2048</fft_len>
<ifft_len>8</ifft_len>
<filter>fft</filter>
<window>welsh</window>
</splitter_cfg>
<analysis_cfg>
<spike_thresh>24</spike_thresh>
<spikes_per_spectrum>1</spikes_per_spectrum>
<gauss_null_chi_sq_thresh>2.23918462</gauss_null_chi_sq_thresh>
<gauss_chi_sq_thresh>1.41999996</gauss_chi_sq_thresh>
<gauss_power_thresh>3</gauss_power_thresh>
<gauss_peak_power_thresh>3.20000005</gauss_peak_power_thresh>
<gauss_pot_length>64</gauss_pot_length>
<pulse_thresh>19.7613773</pulse_thresh>
<pulse_display_thresh>0.5</pulse_display_thresh>
<pulse_max>40960</pulse_max>
<pulse_min>16</pulse_min>
<pulse_fft_max>8192</pulse_fft_max>
<pulse_pot_length>256</pulse_pot_length>
<triplet_thresh>8.76140499</triplet_thresh>
<triplet_max>131072</triplet_max>
<triplet_min>16</triplet_min>
<triplet_pot_length>256</triplet_pot_length>
<pot_overlap_factor>0.5</pot_overlap_factor>
<pot_t_offset>1</pot_t_offset>
<pot_min_slew>0.00209999993</pot_min_slew>
<pot_max_slew>0.0104999999</pot_max_slew>
<chirp_resolution>0.333</chirp_resolution>
<analysis_fft_lengths>262136</analysis_fft_lengths>
<bsmooth_boxcar_length>8192</bsmooth_boxcar_length>
<bsmooth_chunk_size>32768</bsmooth_chunk_size>
<chirps>
<chirp_parameter_t>
<chirp_limit>1</chirp_limit>
<fft_len_flags>262136</fft_len_flags>
</chirp_parameter_t>
<chirp_parameter_t>
<chirp_limit>2.5</chirp_limit>
<fft_len_flags>65528</fft_len_flags>
</chirp_parameter_t>
</chirps>
<pulse_beams>1</pulse_beams>
<max_signals>30</max_signals>
<max_spikes>8</max_spikes>
<max_gaussians>0</max_gaussians>
<max_pulses>0</max_pulses>
<max_triplets>0</max_triplets>
<keyuniq>-12348</keyuniq>
</analysis_cfg>
<sb_id>0</sb_id>
</group_info>
<subband_desc>
<number>151</number>
<center>1418978879.8359</center>
<base>1418974607.375</base>
<sample_rate>9765.625</sample_rate>
</subband_desc>
<sb_id>0</sb_id>
</workunit_header>
------------------------------------------------------------------------
next statements are
252
253 if ( wu ) delete wu;
254 wu = new workunit( buffer ); //seti_britta:here I have a problem
if line 254 executed we come to dbgnew.cpp line 50
50{
51 /* _nh_malloc_dbg already calls _heap_alloc_dbg in a loop and calls _callnewh
52 if the allocation fails. If _callnewh returns (very likely because no
53 new handlers have been installed by the user), _nh_malloc_dbg returns NULL.
54 */
55 void *res = _nh_malloc_dbg( cb, 1, nBlockUse, szFileName, nLine );
RTCCALLBACK(_RTC_Allocate_hook, (res, cb, 0));
/* if the allocation fails, we throw std::bad_alloc */
if (res == 0)
{
static const std::bad_alloc nomem;
_RAISE(nomem);
}
return res;
}
---------------------------------------------------------------------------------------
if we execute line 55 we come to dbgheap.c line 294
294{
295 int errno_tmp = 0;
296 void * pvBlk = _nh_malloc_dbg_impl(nSize, nhFlag, nBlockUse, szFileName, nLine, &errno_tmp);
if ( pvBlk == NULL && errno_tmp != 0 && _errno())
{
errno = errno_tmp; // recall, #define errno *_errno()
}
return pvBlk;
}
-----------------------------------------------------
if we execute line 296 we goto dbgheap.c line 232
232{{
void * pvBlk;
for (;;)
{
/* do the allocation
*/
239 pvBlk = _heap_alloc_dbg_impl(nSize, nBlockUse, szFileName, nLine, errno_tmp);
we came back and run into dbgheao.c line 296
296 void * pvBlk = _nh_malloc_dbg_impl(nSize, nhFlag, nBlockUse, szFileName, nLine, &errno_tmp);
if we execute we come to dbgnew.cpp line 55
55 void *res = _nh_malloc_dbg( cb, 1, nBlockUse, szFileName, nLine );
if we execute we came back to seti_header.cpp line 254
254wu = new workunit( buffer ); //seti_britta:here I have a problem
if we execute with F10 it switches to sah_gfx.cpp line 287
286 ra_string( wu.start_ra, ra_buf );
287 dec_string( wu.start_dec, dec_buf ); <--- here it crashes
sprintf(
buf,
"From: %s, %s\nRecorded on: %s\nRecorded at: %s\nBase frequency: %.9f GHz",
ra_buf,
dec_buf,
short_jd_string( wu.time_recorded ),
locations[s4_id],
wu.subband_base / 1e9 );
}
-----------------------------------------------------------------------------------------------------------------
> seti_boinc.exe!SAH_GRAPHICS::get_data_info_string(char * buf=0x044360d8) Line 287 + 0x21 bytes C++
First-chance exception at 0x7c93a321 in seti_boinc.exe: 0xC00000FD: Stack overflow.
First-chance exception at 0x7c812a7b in seti_boinc.exe: Microsoft C++ exception: std::bad_alloc at memory location 0x000337e4..
First-chance exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
Unhandled exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
--------------------
dec_buf ---->looks like well prepared
sb_id>
</group_info>
<subband_desc>
<number>151</number>
<center>1418978879.8359</center>
<base>1418974607.375</base>
<sample_rate>9765.625</sample_rate>
</subband_desc>
<sb_id>0</sb_id>
</workunit_header>
------------------------------------------------------------------
but wu looks bad --->
- wu {data_type=??? data_class=??? splitter_version=??? ...} SETI_WU_INFO
track_mem<SETI_WU_INFO> {...} track_mem<SETI_WU_INFO>
data_type CXX0030: Error: expression cannot be evaluated
data_class CXX0030: Error: expression cannot be evaluated
splitter_version CXX0030: Error: expression cannot be evaluated
start_ra CXX0030: Error: expression cannot be evaluated
start_dec CXX0030: Error: expression cannot be evaluated
end_ra CXX0030: Error: expression cannot be evaluated
end_dec CXX0030: Error: expression cannot be evaluated
angle_range CXX0030: Error: expression cannot be evaluated
true_angle_range CXX0030: Error: expression cannot be evaluated
time_recorded CXX0030: Error: expression cannot be evaluated
subband_center CXX0030: Error: expression cannot be evaluated
subband_base CXX0030: Error: expression cannot be evaluated
subband_sample_rate CXX0030: Error: expression cannot be evaluated
fft_len CXX0030: Error: expression cannot be evaluated
ifft_len CXX0030: Error: expression cannot be evaluated
subband_number CXX0030: Error: expression cannot be evaluated
+ receiver_cfg {id=??? s4_id=??? name=0x2f3c2130 <Bad Ptr> ...} receiver_config
nsamples CXX0030: Error: expression cannot be evaluated
bits_per_sample CXX0030: Error: expression cannot be evaluated
+ position_history ... std::_Vector_const_iterator<coordinate_t,std::allocator<coordinate_t> >
num_positions CXX0030: Error: expression cannot be evaluated
+ tape_version 0x2f3c2290 <Bad Ptr> char [16]
+ analysis_cfg {id=??? spike_thresh=??? spikes_per_spectrum=??? ...} analysis_config
num_fft_lengths CXX0030: Error: expression cannot be evaluated
+ analysis_fft_lengths 0x2f3c2384 int [32]
beam_width CXX0030: Error: expression cannot be evaluated
+ chirp_fft_table 0x2f3c2410 {MaxChirpRate=??? DoFft=0x2f3c2418 <Bad Ptr> } ChirpFftTable_t [2]
wu CXX0030: Error: expression cannot be evaluated
----------------------------------------------------------------------------------------------------------------------------
I have no idea why wu is not allocated
your hints are welcome
heinz
-
Well that looks familiar ;)
First-chance exception at 0x7c91eddd in seti_boinc.exe: 0xC0000005: Access violation writing location 0x00030ffc.
There are a couple of weird things with WU_header property constructors (either the constructors themselves or when instantiating) I haven't had a proper look at yet. I kludged them to make them compile but I suspect possible memory leaks or corruption etc.
Jason
-
pulsefind.cpp ---> squeezed the code.
new FPU-optimized folding subroutines are short, very compact and hopefull quick
heinz ~seti_britta ;D
so far we measured the modified PFCASE speeds up ~13%
some further measuring is necessary to manifest it
regards ;D
-
Take your time... I broke my NET Framework today >:( seems to have damaged VS & ICC, gosh darnit. Guess that's what happens when you mix detail work and beer!.... I never use dotnet 'stuff' anyway....
-
Its angry, but be cool... can you restore the files before the installation in any way..with systemrestore.
If not install a tool like Norton Ghost. I have installed and configured it so that once a week it makes a full backup and every day a incremental backup of my system on a second disk. And all the time you can work....no problems.
Yesterday evening I restored a directory, after some mishappen changes on some config files of the pulstime project.
It works very well
regards heinz
-
yeah I keep images with TruImage. Had Ghost before but sometimes the disks didn't work for me when I went to grab some files off, so I changed.
Oh well NET seems to have reinstalled OK anyway and my build environment is back up. Still can't help feeling the whole thing is a big slow pig made of eggshells ;). Probably time to think about getting a lottery ticket for buying a MAC :-X
Jason
-
have now some modified code versions under measuring and tuning.
AKFCOMP Alex modified compact code
PFCASE modified case construct of pulsefind.cpp
PFLOOP compact loop construct of pulsefind.cpp
FPUCOMP compact construct of opt_FPU.cpp
heinz
-
A look at the asm code shows SIMD instructions are used and
how opt_v_GetPowerSpectrum performs as a part of FPUCOMP
3 MMX register (XMM0, XMM1, XMM2) are used to handle powerful MMX-Instructions
but keep in mind, all code must be measured..... ;)
heinz
---------------------------------------------------------------------------------------------------------------------------------------
PUBLIC ?opt_v_GetPowerSpectrum@@YAXPAY01MPAMHHH@Z ; opt_v_GetPowerSpectrum
EXTRN __fltused:DWORD
; Function compile flags: /Ogtpy
; File c:\i\sc\pultimb_5\optimizer\opt_fpu.cpp
; COMDAT ?opt_v_GetPowerSpectrum@@YAXPAY01MPAMHHH@Z
_TEXT SEGMENT
tv1161 = -8 ; size = 4
_i$ = -4 ; size = 4
_FreqData$ = 8 ; size = 4
_PowerSpectrum$ = 12 ; size = 4
_this_fft_len$ = 16 ; size = 4
_bin_off$ = 20 ; size = 4
_bin_len$ = 24 ; size = 4
?opt_v_GetPowerSpectrum@@YAXPAY01MPAMHHH@Z PROC ; opt_v_GetPowerSpectrum, COMDAT
; 36 : register int i, bin; //seti_britta: register
; 37 : float *workBuf = (float *)FreqData;
; 38 : // float psNum; //seti_britta: no longer necessary
; 39 :
; 40 : ALIGNED_YES( FreqData );
; 41 : ALIGNED_YES( PowerSpectrum );
; 42 : for ( i = 0, bin = 0; i < this_fft_len; i++, bin += bin_len)
mov eax, DWORD PTR _FreqData$[esp-4]
sub esp, 8
push ebx
push ebp
mov ebp, DWORD PTR _this_fft_len$[esp+12]
xor ecx, ecx
xor ebx, ebx
cmp ebp, 4
push esi
mov esi, DWORD PTR _bin_len$[esp+16]
jl $LC9@opt_v_GetP
mov edx, DWORD PTR _PowerSpectrum$[esp+16]
mov ecx, DWORD PTR _bin_off$[esp+16]
add ebp, -4 ; fffffffcH
shr ebp, 2
inc ebp
mov DWORD PTR tv1161[esp+20], ebp
lea ecx, DWORD PTR [edx+ecx*4]
add ebp, ebp
lea edx, DWORD PTR [eax+8]
add eax, 12 ; 0000000cH
add ebp, ebp
push edi
mov DWORD PTR _i$[esp+24], ebp
mov ebp, DWORD PTR tv1161[esp+24]
lea edi, DWORD PTR [esi*4]
npad 1
$LL10@opt_v_GetP:
; 43 : {
; 44 : // psNum = FreqData[0] * FreqData[0] + FreqData[1] * FreqData[1];
; 45 : // PowerSpectrum[bin_off + bin] = // Large cache miss here...can it be fixed?
; 46 : // workBuf = psNum;
; 47 : //seti_britta: new statement
; 48 : PowerSpectrum[bin_off + bin] = workBuf = (FreqData[0] * FreqData[0]) + (FreqData[1] * FreqData[1]);
movss xmm1, DWORD PTR [eax-8]
movss xmm0, DWORD PTR [eax-12]
mulss xmm0, xmm0
movaps xmm2, xmm1
mulss xmm2, xmm1
addss xmm0, xmm2
movss DWORD PTR [edx-8], xmm0
movss DWORD PTR [ecx], xmm0
movss xmm1, DWORD PTR [eax-4]
movss xmm0, DWORD PTR [eax]
mulss xmm0, xmm0
add ecx, edi
movaps xmm2, xmm1
mulss xmm2, xmm1
addss xmm0, xmm2
movss DWORD PTR [edx-4], xmm0
movss DWORD PTR [ecx], xmm0
movss xmm1, DWORD PTR [eax+4]
movss xmm0, DWORD PTR [eax+8]
mulss xmm0, xmm0
add ecx, edi
movaps xmm2, xmm1
mulss xmm2, xmm1
addss xmm0, xmm2
movss DWORD PTR [edx], xmm0
movss DWORD PTR [ecx], xmm0
movss xmm1, DWORD PTR [eax+12]
movss xmm0, DWORD PTR [eax+16]
add ebx, esi
add ebx, esi
add ecx, edi
movaps xmm2, xmm1
mulss xmm0, xmm0
mulss xmm2, xmm1
addss xmm0, xmm2
add ebx, esi
movss DWORD PTR [edx+4], xmm0
movss DWORD PTR [ecx], xmm0
add ebx, esi
add ecx, edi
add edx, 16 ; 00000010H
add eax, 32 ; 00000020H
sub ebp, 1
jne $LL10@opt_v_GetP
mov ebp, DWORD PTR _this_fft_len$[esp+20]
mov eax, DWORD PTR _FreqData$[esp+20]
mov ecx, DWORD PTR _i$[esp+24]
pop edi
$LC9@opt_v_GetP:
; 36 : register int i, bin; //seti_britta: register
; 37 : float *workBuf = (float *)FreqData;
; 38 : // float psNum; //seti_britta: no longer necessary
; 39 :
; 40 : ALIGNED_YES( FreqData );
; 41 : ALIGNED_YES( PowerSpectrum );
; 42 : for ( i = 0, bin = 0; i < this_fft_len; i++, bin += bin_len)
cmp ecx, ebp
jge SHORT $LN8@opt_v_GetP
mov edx, DWORD PTR _bin_off$[esp+16]
add esi, esi
add esi, esi
add ebx, edx
mov edx, DWORD PTR _PowerSpectrum$[esp+16]
lea edx, DWORD PTR [edx+ebx*4]
npad 9
$LC3@opt_v_GetP:
; 43 : {
; 44 : // psNum = FreqData[0] * FreqData[0] + FreqData[1] * FreqData[1];
; 45 : // PowerSpectrum[bin_off + bin] = // Large cache miss here...can it be fixed?
; 46 : // workBuf = psNum;
; 47 : //seti_britta: new statement
; 48 : PowerSpectrum[bin_off + bin] = workBuf = (FreqData[0] * FreqData[0]) + (FreqData[1] * FreqData[1]);
movss xmm1, DWORD PTR [eax+ecx*8+4]
movss xmm0, DWORD PTR [eax+ecx*8]
movaps xmm2, xmm1
mulss xmm0, xmm0
mulss xmm2, xmm1
addss xmm0, xmm2
movss DWORD PTR [eax+ecx*4], xmm0
movss DWORD PTR [edx], xmm0
inc ecx
add edx, esi
cmp ecx, ebp
jl SHORT $LC3@opt_v_GetP
$LN8@opt_v_GetP:
pop esi
pop ebp
pop ebx
; 49 :
; 50 : }
; 51 : }
add esp, 8
ret 0
?opt_v_GetPowerSpectrum@@YAXPAY01MPAMHHH@Z ENDP ; opt_v_GetPowerSpectrum
-
hmmm, time to get out the p4 optimisation reference. Some of the things in those SSE loops might be really good on a core/core2, don't know, but I'm a little bit wierded out by a few things :o. Some of the ordering of the instructions could be improved, (not entirely convinced out-of-order execution would fix that). I also think that where I think the core2 likes moderately tight loops, as would seem to be designed, the p4 might appreciate a further manual unroll.( or maybe the other way ! both worth a try due to different architecture generation. )
Did you use any optimisation yet ?(or is that the cleaned up version of what I did with QxN? nope different function. whew.) l'm a bit surprised at some of the code generated.
Jason
-
No hurry with all this...
all must be measured and running against the original-code version to see if there is a real progress. It is easy to destroy a well performed loop with some simple changes. As Joe mentioned, its not a good idea to use the pultime project to measure code by using the MS-compiler(Have not as my own the whole Intel Performance package, with Intel-Compiler, VTune and so on).
Using now the etimer-project to see any differences.
In this way we can better test short code-pieces.
And if we found any progress it is at least necessary to compile with Intel-compiler to see if it really rocks.
Do you like my sight of view to see equation systems looking at the code ?
Resolutions can be found by using mathematical methods.
Therefore some of my code-constructs are a little bit crazy.
But you know mathematicians are crazy people.
And I“m a mathematician. ;D
Regards heinz
-
No, No hurry, my holidays are coming in a few weeks, I still consider this "Orientation".
------------------------Detour------------
And I“m a mathematician.
I think the Mathematician's Anonymous meeting is three doors down ...
Mathematicians may be crazy or not, But I always wondered where my lecturers did 'stash their flagons' before class, and who knitted them the stylish brown vest that is two sizes too small :D (jokes).
If you have a formula to get crazy, I can examine its computational complexity well enough (comp sci) though a little out of practice, then build it in hardware to IPC class 3 military standards (Electronic Engineering).
It is a shame the algorithm for sanity is O(n^3) and requires too many connections to implement on an FPGA, so sorry I can't help you there :D [Though I can't offer any sanity, I do have a drawer full of high speed logic I can let you dig through ....]
-------------------------------------------------------------------------
My p4 selects PwrSpectrumOnly_ptt( sse_GetPSO_sc16_npr ) take a look it is nice, No Author's name is listed :(. Maybe it is Ben & Joe?
- It has care with the SSE pipelines (Even is laid out showing them :D)
- It Is using many more registers (Those aren't variable assignments really, no ;) )
- It looks to be unrolled to help the pipelines/cache/prefetch, very pretty :D.
I'm more impressed with that function, It may help you to compare to that so you can see how to use the hardware better.
Jason
-
It hasn't been mentioned lately that in 2004 Eric Korpela set up a setiboinc sourceforge project (http://setiboinc.sourceforge.net/) to encourage submission of optimized code. Ben Herndon participated in that, and his code in ../setiboinc/client/opt is where I got the original form of the GetPSO functions. I just made it into four separate versions to compare the prefetching. On some systems and some builds there have been clear differences particularly on my Pentium-M system and on Core 2 systems. On P4 or PD systems, OTOH, the differences have been small.
Francois Piednoel's PowerSpectrum code from the "Who? optimizations Part 2" NC thread may be even better. I hope he'll release source soon but that part would be fairly easy to fit into our codebase anyhow.
Joe
-
Thanks Joe,
Though I did run maybe a couple of workunits when sah classic first started (I remember the news release on tv here in Oz... Incidently, could never rember the email I used then....), I just came back around last November....
so really '2004' is indeed before my time... Thanks for the link, more reading is always handy.
Just opened the Pulse Timing project for the first time, Looks like I'll be occupied for the weekend trying to get a working build, Looks Extremely handy for testing some of the things been worked on behind the scenes.
Jason
-
Looking now to vectorize the most used functions of S@H.
Here I show you a modified FillTrigArray as it performs as part of chirpfft.cpp
Have fun ;D
Heinz
---------------------------------------------------------------------------
PUBLIC ?FillTrigArray@@YAXH@Z ; FillTrigArray
; Function compile flags: /Ogtpy
; COMDAT ?FillTrigArray@@YAXH@Z
_TEXT SEGMENT
_k$ = 8 ; size = 4
?FillTrigArray@@YAXH@Z PROC ; FillTrigArray, COMDAT
; 731 : CurrentTrig[k].Sin = ((CurrentTrig[k].Sin * TrigStep[k].Cos) + (CurrentTrig[k].Cos * TrigStep[k].Sin));
mov edx, DWORD PTR ?TrigStep@@3PAUSinCosArray@@A ; TrigStep
mov ecx, DWORD PTR ?CurrentTrig@@3PAUSinCosArray@@A ; CurrentTrig
mov eax, DWORD PTR _k$[esp-4]
shl eax, 4
movsd xmm1, QWORD PTR [eax+edx+8]
mulsd xmm1, QWORD PTR [eax+ecx]
movsd xmm0, QWORD PTR [eax+ecx+8]
mulsd xmm0, QWORD PTR [eax+edx]
addsd xmm0, xmm1
movsd QWORD PTR [eax+ecx], xmm0
; 732 : CurrentTrig[k].Cos = ((CurrentTrig[k].Cos * TrigStep[k].Cos) - (CurrentTrig[k].Sin * TrigStep[k].Sin));
mov edx, DWORD PTR ?TrigStep@@3PAUSinCosArray@@A ; TrigStep
movsd xmm0, QWORD PTR [eax+edx+8]
push esi
mov esi, DWORD PTR ?CurrentTrig@@3PAUSinCosArray@@A ; CurrentTrig
movsd xmm1, QWORD PTR [eax+esi]
mulsd xmm0, QWORD PTR [eax+esi+8]
mulsd xmm1, QWORD PTR [eax+edx]
lea ecx, DWORD PTR [eax+esi+8]
subsd xmm0, xmm1
movsd QWORD PTR [ecx], xmm0
pop esi
; 733 : }
ret 0
?FillTrigArray@@YAXH@Z ENDP ; FillTrigArray
_TEXT ENDS
-
I. Going parallel or how to cut the leek !
This morning I was in the kitchen to make a salad of leek. After washing the leafs I took one to cut it in fit parts.
But how big is a fit part ? 1mm, 10mm, 100mm ?
I have a relative big leaf of 24 cm so we choose 10mm= 1cm as a fit part. Now we know I must cut it into 24 parts.
How todo that ?
1. we take the knife and cut it into 24 pieces one after the other. Wee need 24-1 = 23 cuts
We have stiil one tree to cut. This means sequential works.
or we do following-->
2. we cut the leaf in two eaqual parts(1 cut), then lay both parts parallel to each other and cut it. We need 12-1 = 11 cuts +1 extra cut from the first. Summary 12 cuts.
This means parallel work. We have 2 parallel trees to cut.The one extra cut and lay both parts parallel is the overhead(organize parallel work).
3. we cut the leaf into 2 parts (1 cut), laying both parts parallel, cut now again into 2 parts(1 cut), laying again the 2 parts parallel(have now 4 parallel) and cut it. We need still 6-1 cuts plus the 2 extra cuts = summary 7 cuts.
This means much more parallel. We have 4 trees. The overhead is now grown to 2 cuts plus laying 4 parts parallel.
4. we cut the leaf into 2 parts(1cut) laying both parts parallel, cut now again into 2 parts(1 cut), laying again both parts parallel and cut it into 2 parts(1 cut), laying the two parallel(have now 8 parts parallel) and cut. We need 3-1=2 cuts plus 3 extra cuts summary 5 cuts. The overhead grows now to 3 cuts plus laying 3 times (2³ = 8parts) parallel.
Summary of all:
1. sequential = 23 cuts --> no overhead
2. parallel (2) = 11+1=12 cuts (1 cut overhead)
3. parallel (4) = 5+2=7 cuts (2 cuts overhead)
4. parallel ( 8 ) = 2+3=5 cuts (3 cuts overhead)
-----------------------------------------------------------------------
In this way (4.) we can do the same work with still 5 cuts against (1.) 23 cuts if we use sequential work.
But attention the overhead with 3 is bigger as the real work-cuts(2) and we run 8 trees parallel.
This method of organize parallel work is called blocking. The problem is to determine the length of the pieces(fit parts) and the choose of parallel trees to get maximal performance. I believe every max performance solution is for every given work (1000), (100 000), (1 000 000) and machine a other. Therefore this thema is relative complex and so difficult to handle.
Believe me, the parallel cutted salad has a fine taste. ;D
Have fun ;D ;D ;D
regards heinz
-
8)...Or the 'other' kind of coarse grained parallelism ... where you ask your mum to make you a sandwich instead, then you watch TV in parallel ;D [ 0 cuts + 1 small communication overhead]
Jason
-
Hi Jason,
great, your sample means start a task (ask mum to make a sandwich) parallel to the Main Program (TV program). You must still wait till the sandwich ( the task) is ready. ;)
We can enlarge this too:
Start a variable number of tasks parallel to the Main Program.
Later we can do so.
But at first we had to resolve some basics on the way to go parallel as "Load balanced parallel execution of a fixed number of independent loop iterations" and some others.
heinz
-
1. If the leaves you're cutting are always the same size and shape, an ideal tool would make the cuts all at once. If the leaves come in a few different sizes, either a tool for each size or an even more complex tool with suitable adjustments is needed.
2. The characteristics of the Validator need to be kept in mind when thinking about dividing the work differently. When it is comparing results it checks that each signal in result A has a matching signal in result B, then checks that each signal in result B has a matching signal in result A. For the ~95% of WUs which have less than 31 reportable signals the order signals are found wouldn't make a difference. But for the ~5% which overflow we need to be sure we'll report the same subset as the stock app does.
Joe
-
1. If the leaves you're cutting are always the same size and shape, an ideal tool would make the cuts all at once. If the leaves come in a few different sizes, either a tool for each size or an even more complex tool with suitable adjustments is needed.
Or perhaps a modular tool, with a set of adaptors designed to fit each possible variation [or groups of variations], with a different plan/tool adapter for each one of the finite set of possibilties. (A single complex tool is large and unwieldly, many different tools is more efficient but maybe even larger in total with redundancy (and requires selection), a modular tool seems an ideal compromise but also requires selection/adaptation overhead)... mmm all food for thought.
2. The characteristics of the Validator need to be kept in mind when thinking about dividing the work differently. When it is comparing results it checks that each signal in result A has a matching signal in result B, then checks that each signal in result B has a matching signal in result A. For the ~95% of WUs which have less than 31 reportable signals the order signals are found wouldn't make a difference. But for the ~5% which overflow we need to be sure we'll report the same subset as the stock app does.
Joe
:o, so even though a faster overflow detection mechanism may be possible, the positive overflow will still require the same processing order/results...[You seem to be saying the order of signals is important in those ~5% where overflow occurs] thinking about that a little I can probably live with the current speed, or even reduced speed, where it results in overflow. I wonder if there may be benefit to quickly disproving [or just detecting reduced likelihood of] overflow condition early on... (then we may perhaps tactically reorder detection)
Jason
-
..., so even though a faster overflow detection mechanism may be possible, the positive overflow will still require the same processing order/results...[You seem to be saying the order of signals is important in those ~5% where overflow occurs] thinking about that a little I can probably live with the current speed, or even reduced speed, where it results in overflow. I wonder if there may be benefit to quickly disproving [or just detecting reduced likelihood of] overflow condition early on... (then we may perhaps tactically reorder detection)
Jason
The order of the signals within the output result file never matters, but I can see no practical way to select the right subset of what may be a very large number of potential signals other than using the same sequence of searches as stock.
Prechecking for possible overflow is certainly an interesting concept. If someone came up with a really efficient way to do that, the project might consider putting that code in the splitter. In the science app, maybe the best opportunity is during baseline smoothing.
I'll also note that if we found a way of dividing the work much more effectively, the changes could be applied to the official sources prior to the next stock release. That release could be named setiathome_multibeam or something similar, and all participants would have to upgrade.
Joe
-
The order of the signals within the output result file never matters, but I can see no practical way to select the right subset of what may be a very large number of potential signals other than using the same sequence of searches as stock.
Ahh I see, a sticky problem. Just musing some more, getting a better picture, statistically might there be a strong subset of overflow cases where the dataset tends to white noise?(I realise probably all the good data probably does anyway ::)) And in such cases would the first 31 signals be definitely pulses?[or spikes rather]
Prechecking for possible overflow is certainly an interesting concept. If someone came up with a really efficient way to do that, the project might consider putting that code in the splitter. In the science app, maybe the best opportunity is during baseline smoothing.
Don't know about efficient ;D. I would, perhaps incorrectly, expect at least some types of obvious overflow signal [tasks] to be fairly 'white'. It's been a long time since I looked at an autocorrelation function, from vague memory they involve a single convolution. Something like that would be able to judge the whiteness of the signal against a decided threshold dirac figure/function. I've used them in signal processing many years ago for analysis of buried periodic signals. Subtracting the autocorrelation of white noise from that of the source [ had interesting results].... but that was on a 1k node torus so algorithmic complexity and other practical considerations weren't an issue under much consideration :P. [though they should've been]
I'll also note that if we found a way of dividing the work much more effectively, the changes could be applied to the official sources prior to the next stock release. That release could be named setiathome_multibeam or something similar, and all participants would have to upgrade.
Joe
That I'll leave for thought 'till next week when I'm on my holidays... yay... I haven't been following what Heinz is up to there, I was lost somewhere around 'Leeks' but you gave some food for thought and I'll figure it all out then.
'Till next week
Jason
-
...
I would, perhaps incorrectly, expect at least some types of obvious overflow signal [tasks] to be fairly 'white'. It's been a long time since I looked at an autocorrelation function, from vague memory they involve a single convolution. Something like that would be able to judge the whiteness of the signal against a decided threshold dirac figure/function. I've used them in signal processing many years ago for analysis of buried periodic signals. Subtracting the autocorrelation of white noise from that of the source [ had interesting results].... but that was on a 1k node torus so algorithmic complexity and other practical considerations weren't an issue under much consideration :P. [though they should've been]
...
Jason
I've always thought of the WUs as consisting of a lot of white noise out of which we try to extract what isn't. Although the ALFA receivers are recent state of the art with 300 MHz. bandwidth, what goes on the Multibeam recorder is 2 bit complex values representing only the signs of the real and imaginary complex data points of the 2.5 MHz. bandwidth we're examining. That digitization represents a lot of noise, no? Then after the recording is received at Berkeley, the Splitter expands the data into complex single floats, does forward FFTs at 2048 length and inverse FFTs at length 8 and repacks the output in 2 bit form to be placed in the WUs.
As a practical matter, most overflows have been on Spikes until the recent radar RFI problem caused a lot of Triplets. The record for my Willamette P4 shows 1682 Gaussians, 1807 Pulses, 11764 Spikes, and 10718 Triplets. 8162 of those Triplets are from one data set we crunched at SETI Beta before the radar RFI was understood. That's from 3524 results. The thresholds are nominally adjusted to give about an even chance of finding a signal or not if the noise level is normal, the Gaussian and Pulse counts match that but the excess Spike count probably reflects cases where random RFI caused overflows. Note that Spikes aren't exactly what the name implies, they are found by examining the power spectrum of a single FFT; if there's one frequency that's more than 24 times more powerful than the average it's counted as a Spike. A continuous narrow band interfering signal will cause a sequence of Spike reports as the FFTs are stepped through the duration of the data.
Joe
-
I've always thought of the WUs as consisting of a lot of white noise out of which we try to extract what isn't. Although the ALFA receivers are recent state of the art with 300 MHz. bandwidth, what goes on the Multibeam recorder is 2 bit complex values representing only the signs of the real and imaginary complex data points of the 2.5 MHz. bandwidth we're examining. That digitization represents a lot of noise, no? Then after the recording is received at Berkeley, the Splitter expands the data into complex single floats, does forward FFTs at 2048 length and inverse FFTs at length 8 and repacks the output in 2 bit form to be placed in the WUs.
Yes but no. Based on some obscure reading on the black art of antennae, If I interpret [crudely but] correctly [That's a pretty big if] I can think of two ways that method of complex representation can reduce noise in the digitisation process.
1) Dumping the magnitude data & relying instead on a temporal persistence summation- The magnitude data [if it ever existed] probably would amount to random noise like we've been discussing, I gather direct digitisation of magnitude in this realm would rely more heavily on the analog characteristics of the receiver. Also In the method that is used, from what I gather the signal polarity is very reliable in such a setup, and already digital, and the time characteristic inherently precise, so vector summation (If that's what the splitter process simplistically amounts to maybe) of those signals to form a single float signal, would be as precise time-wise. So the resynthesis should be a truer effective representation of the magnitude.
2) Complex representaion cheats Nyquist: As I understand it we now get 'n' overall bandwidth capability instead of 'n/2' before nyquist induced aliasing takes over. I think that's a pretty remarkable 'something for nothing'.
As a practical matter, most overflows have been on Spikes until the recent radar RFI problem caused a lot of Triplets. The record for my Willamette P4 shows 1682 Gaussians, 1807 Pulses, 11764 Spikes, and 10718 Triplets. 8162 of those Triplets are from one data set we crunched at SETI Beta before the radar RFI was understood. That's from 3524 results. The thresholds are nominally adjusted to give about an even chance of finding a signal or not if the noise level is normal, the Gaussian and Pulse counts match that but the excess Spike count probably reflects cases where random RFI caused overflows. Note that Spikes aren't exactly what the name implies, they are found by examining the power spectrum of a single FFT; if there's one frequency that's more than 24 times more powerful than the average it's counted as a Spike. A continuous narrow band interfering signal will cause a sequence of Spike reports as the FFTs are stepped through the duration of the data.
Joe
Thanks, that description of spikes helps greatly trying to get a clearer picture of the processing sequence, I'll try to mentally process the implications. Given the definition of a spike, and that it is the predominant indicator of noise, It may be that the only feasible method of determining a noisy workunit is indeed to process it to completion (Excepting, of course, known environmental influences, like we can make use of the radar blanking)... We are the 'precheckers'...
Jason
-
Hi all,
my evaluation installation of Orcas is now expired.
I installed the new VS2008 Express Edition yesterday. I can open and work with all projectfiles from Orcas without any problems, parallel to VS2005 Express Edition.
Thats a really good news.
have fun ;D
heinz
-
Hi all,
you can download VS2008 Express Edition from ---> http://www.microsoft.com/express/vc/
or --->http://www.microsoft.com/express/download/
a other good news is: students from several countries can download a free full version of Visual Studio VS2008 Professional Edition, Windows Server 2003 Standard Edition, Microsoft Expression Studio, and XNA Game Studio 2.0 from here:
---> https://downloads.channel8.msdn.com/
Happy Eastern ;D
Joyeuse Paques ;D
-
Hi,
You can download Visual Studio Express Edition 2008 (http://www.microsoft.com/express/download/#webInstall)
from a new website...
heinz