Seti@Home optimized science apps and information

Optimized Seti@Home apps => Windows => Topic started by: _heinz on 22 Jun 2007, 07:30:56 pm

Title: sources with Orcas
Post 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]
Title: Re: sources with Orcas
Post by: _heinz on 26 Jun 2007, 02:42:46 pm
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
Title: Re: sources with Orcas
Post by: Crunch3r on 26 Jun 2007, 02:58:41 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 26 Jun 2007, 05:36:40 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 02 Jul 2007, 07:24:57 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 03 Jul 2007, 06:08:52 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 12 Jul 2007, 06:06:31 pm
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 ---->
&#135;      _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 ---->
&#135;      _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
Title: Re: sources with Orcas
Post by: Urs Echternacht on 12 Jul 2007, 06:35:16 pm
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.
Title: Re: sources with Orcas
Post by: _heinz on 13 Jul 2007, 08:15:57 am
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
Title: Re: sources with Orcas
Post by: _heinz on 16 Jul 2007, 08:34:55 am
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 ==========
Title: Re: sources with Orcas
Post by: Simon on 16 Jul 2007, 01:20:12 pm
Hallo Heinz,

have you managed to run some WUs successfully with the apps you compiled on VS Orcas/2008?

Regards,
Simon.
Title: Re: sources with Orcas
Post by: _heinz on 17 Jul 2007, 08:16:20 am
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





Title: Re: sources with Orcas
Post by: _heinz on 30 Jul 2007, 05:05:21 pm
Hi all,
At the moment I“m testing the mmx client.
be patient, work is going on.

regards heinz
Title: Re: sources with Orcas
Post by: Gecko_R7 on 30 Jul 2007, 08:08:26 pm
Hi all,
At the moment I╢m testing the mmx client.
be patient, work is going on.

regards heinz

Very cool Heinz! Good luck!
Title: Re: sources with Orcas
Post by: _heinz on 22 Sep 2007, 04:49:47 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 23 Sep 2007, 07:19:47 pm
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
Title: Re: sources with Orcas
Post by: Raistmer on 06 Oct 2007, 12:58:35 pm
Did you compile whole client under Orcas already?
Any performance comparision?
Title: Re: sources with Orcas
Post by: _heinz on 06 Oct 2007, 04:32:07 pm
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.
Title: Re: sources with Orcas
Post by: _heinz on 22 Oct 2007, 10:17:41 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 28 Oct 2007, 06:14:39 pm
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 


Title: Re: sources with Orcas
Post by: Jason G on 30 Oct 2007, 03:18:52 am
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
Title: Re: sources with Orcas
Post by: _heinz on 31 Oct 2007, 02:42:29 pm
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   
Title: Re: sources with Orcas
Post by: _heinz on 31 Oct 2007, 02:47:41 pm
sorry forgot to attach the file

[attachment deleted by admin]
Title: Re: sources with Orcas
Post by: Jason G on 31 Oct 2007, 03:50:42 pm
woohoo thanks  :), will look after work & school today.

Jason
Title: Re: sources with Orcas
Post by: _heinz on 01 Nov 2007, 05:00:28 pm
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
 
Title: Re: sources with Orcas
Post by: Jason G on 01 Nov 2007, 06:18:37 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 09 Nov 2007, 04:10:11 am
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
Title: Re: sources with Orcas
Post by: Jason G on 09 Nov 2007, 07:44:01 am
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....
Title: Re: sources with Orcas
Post by: _heinz on 09 Nov 2007, 08:38:49 am
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
Title: Re: sources with Orcas
Post by: Jason G on 09 Nov 2007, 10:41:03 am
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
Title: Re: sources with Orcas
Post by: _heinz on 20 Nov 2007, 07:30:01 am
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

Title: Re: sources with Orcas
Post by: _heinz on 20 Nov 2007, 09:50:50 pm
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

Title: Re: sources with Orcas
Post by: Jason G on 21 Nov 2007, 03:30:09 am
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
Title: Re: sources with Orcas
Post by: _heinz on 21 Nov 2007, 08:58:46 am
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 

 
 
Title: Re: sources with Orcas
Post by: Jason G on 21 Nov 2007, 10:32:30 am
No, No hurry, my holidays are coming in a few weeks, I still consider this "Orientation". 

------------------------Detour------------
Quote
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





Title: Re: sources with Orcas
Post by: Josef W. Segur on 22 Nov 2007, 11:04:31 am
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
Title: Re: sources with Orcas
Post by: Jason G on 22 Nov 2007, 01:13:35 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 01 Dec 2007, 05:21:27 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 07 Dec 2007, 11:41:38 am
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


Title: Re: sources with Orcas
Post by: Jason G on 08 Dec 2007, 03:02:25 am
 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
Title: Re: sources with Orcas
Post by: _heinz on 08 Dec 2007, 11:42:10 am
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
Title: Re: sources with Orcas
Post by: Josef W. Segur on 08 Dec 2007, 02:08:10 pm
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
Title: Re: sources with Orcas
Post by: Jason G on 10 Dec 2007, 04:23:46 am
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.
Quote
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
Title: Re: sources with Orcas
Post by: Josef W. Segur on 10 Dec 2007, 12:28:04 pm
..., 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
Title: Re: sources with Orcas
Post by: Jason G on 10 Dec 2007, 02:16:35 pm
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]

Quote
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]

Quote
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
Title: Re: sources with Orcas
Post by: Josef W. Segur on 11 Dec 2007, 02:53:39 pm
...
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
Title: Re: sources with Orcas
Post by: Jason G on 16 Dec 2007, 10:01:01 am
Quote
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'.

Quote
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
Title: Re: sources with Orcas
Post by: _heinz on 19 Mar 2008, 03:46:19 pm
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
Title: Re: sources with Orcas
Post by: _heinz on 22 Mar 2008, 07:26:58 am
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
Title: Re: sources with Orcas
Post by: _heinz on 30 Apr 2008, 09:34:07 am
Hi,
You can download Visual Studio Express Edition 2008 (http://www.microsoft.com/express/download/#webInstall)
from a new website...

heinz