Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8113811
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 6, 20262026-06-06T02:57:03+00:00 2026-06-06T02:57:03+00:00

I have a vector where I keep an incrementing data. Normally each element of

  • 0

I have a vector where I keep an incrementing data. Normally each element of the vector is a 64 bit long variable. However, it is quite possible that difference between two successive elements is quite small, so for example we can have a sequence as follows.

1, 34, 37, 42, 45, 1098, 1200, 1211, 1938

What is the best way of compressing this data. Would it be ideal to just keep the differences, and have a header byte which defines how big is the difference, whether it is only a byte, word, double word etc, or are there even better ways of compressing such incremental data?

EDIT

I need to compress online, that is while putting data in the vector. You may assume a dynamically expanding vector.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-06T02:57:05+00:00Added an answer on June 6, 2026 at 2:57 am

    Here’s a very simple strategy for when the increments are typically small:

    1. If the increment is <2**7, emit it as a single byte with the highest bit set to zero:

      0xxxxxxx
      
    2. Else, if the increment is <2**14, emit it as two bytes with highest bits one and zero, respectively:

      1xxxxxxx 0xxxxxxx
      
    3. Extend this to larger increments in the obvious way. An eighth bit set to one means “wait, there’s more coming”. Zero means “end of integer”.

    I remember seeing this coding scheme being suggested for bigints in some RFC or maybe an internet-draft, but I seem unable to retrieve it right now. Alternatively, you can reuse the UTF-8 encoding scheme for some improved error detection at the expense of less efficient encoding (and you may have to extend it if you want to go beyond 64-bit integers).

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have written a bit of code to match two vector of objects that
So I have a list, each element of which is a numeric vector. Each
For simplicity lets assume that I have a vector of N matrices each of
I have a vector of beans that holds information I want to display in
I have a Vector that holds a number of objects. My code uses a
I have a vector<set<char> > data structure (transactions database) and I want to know
I have a small 3D vector class in C# 3.0 based on struct that
First I want to say that, I have a vector which has thousand of
I have a vector of data, which contains integers in the range -20 20.
I have a function in a struct that sorts a vector in the struct.

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.