Changeset 16897 for trunk/Mars/mcore


Ignore:
Timestamp:
06/24/13 15:57:53 (12 years ago)
Author:
lyard
Message:
Removed bytes swapping for RAWSUM
Location:
trunk/Mars/mcore
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/Mars/mcore/checksum.h

    r16670 r16897  
    4747
    4848
    49     bool add(const char *buf, size_t len)
     49    bool add(const char *buf, size_t len, bool big_endian = true)
    5050    {
    5151        // Avoid overflows in carry bits
     
    7373        uint32_t *hilo  = reinterpret_cast<uint32_t*>(&buffer);
    7474
     75
     76        const uint16_t *end = sbuf + len/2;
     77
     78        if (big_endian)
     79            addLoopSwapping(sbuf, end, hilo);
     80        else
     81            addLoop(sbuf, end, hilo);
     82        /*const uint16_t *end = sbuf + len/2;
     83        while (1)
     84        {
     85            if (sbuf==end)
     86                break;
     87
     88            hilo[0] += ntohs(*sbuf++);
     89
     90            if (sbuf==end)
     91                break;
     92
     93            hilo[1] += ntohs(*sbuf++);
     94        }*/
     95
     96        HandleCarryBits();
     97
     98        return true;
     99    }
     100
     101    void addLoopSwapping(const uint16_t *sbuf, const uint16_t *end, uint32_t* hilo)
     102    {
    75103        /*
    76104        for (size_t i = 0; i < len/2; i++)
     
    83111        // This is about as twice as fast as the loop above
    84112        // ntohs is CPU optimized, i%2 doesn't need to be computed
    85         const uint16_t *end = sbuf + len/2;
    86113        while (1)
    87114        {
     
    96123            hilo[1] += ntohs(*sbuf++);
    97124        }
    98 
    99         HandleCarryBits();
    100 
    101         return true;
    102     }
    103 
    104     bool add(const vector<char> &v)
    105     {
    106         return add(v.data(), v.size());
     125    }
     126
     127    void addLoop(const uint16_t *sbuf, const uint16_t *end, uint32_t* hilo)
     128    {
     129        while (1)
     130        {
     131            if (sbuf==end)
     132                break;
     133
     134            hilo[0] += ntohs(*sbuf++);
     135
     136            if (sbuf==end)
     137                break;
     138
     139            hilo[1] += ntohs(*sbuf++);
     140        }
     141    }
     142
     143    bool add(const vector<char> &v, bool big_endian = true)
     144    {
     145        return add(v.data(), v.size(), big_endian);
    107146    }
    108147
  • trunk/Mars/mcore/zfits.h

    r16890 r16897  
    7070    }
    7171
     72    virtual bool IsFileOk() const
     73    {
     74        bool rawsum = true;
     75
     76        if (HasKey("RAWSUM"))
     77        {
     78                ostringstream str;
     79                str << fRawsum.val();
     80                rawsum = (GetStr("RAWSUM") == str.str());
     81        }
     82
     83        return fits::IsFileOk() && rawsum;
     84    };
     85
    7286protected:
    7387
     
    130144
    131145        if (fTable.is_compressed)
    132         {
    133             for (auto it=fTable.sorted_cols.begin(); it!= fTable.sorted_cols.end(); it++)
     146        for (auto it=fTable.sorted_cols.begin(); it!= fTable.sorted_cols.end(); it++)
     147            if (it->comp != kCompFACT)
    134148            {
    135149                if (it->comp == kCompFACT)
     
    190204    vector<size_t>                         fTileSize; ///< size in bytes of each compressed tile
    191205    vector<vector<size_t>>                 fTileOffsets; ///< offset from start of tile of a given compressed column
     206
     207    Checksum fRawsum;   ///< Checksum of the uncompressed, raw data
    192208
    193209    // Get buffer space
     
    270286    //overrides fits.h method with empty one
    271287    //work is done in ReadBinaryRow because it requires volatile data from ReadBinaryRow
    272     virtual void WriteRowToCopyFile(size_t )
    273     {
    274 
     288    virtual void WriteRowToCopyFile(size_t row)
     289    {
     290        if (row == fRow+1)
     291            fRawsum.add(fBufferRow, false);
    275292    }
    276293
Note: See TracChangeset for help on using the changeset viewer.