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

  • Home
  • SEARCH
  • 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 4097692
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 20, 20262026-05-20T20:12:22+00:00 2026-05-20T20:12:22+00:00

I tried out writing a pipelined version of Bitonic Sort using with File Read,

  • 0

I tried out writing a pipelined version of Bitonic Sort using with File Read, Sort, File Write stages using Intel TBB as shown below. The code freezes at the spinlock at while(!outQueue.try_pop(line)); in the FileWriter Filter. Can someone explain why this might be?

update:
I did some further testing and discovered that internal_try_pop that is called by try_pop from the header file _concurrent_queue_internal.h has a compare_and_swap operation that fails forever for this particular try_pop. The following are values i extracted from the internal_try_pop

head counter(k)15
tail counter1605177747
item ticket(tk)15
k after head CAS 15
(k=tk)15,15---break!!

I think the tail counter value is garbage. The only reason i can think of for this situation is that the value added to the queue by the sorter may be implicitly modified by it thus making it unavailable.

Any ideas?

Thanks 🙂

#include <iostream>
#include <sstream>
#include <string>
#include <algorithm>
#include <fstream>
#include "tbb\parallel_for.h"
#include "tbb\blocked_range.h"
#include "tbb\pipeline.h"
#include "tbb\concurrent_queue.h"

using namespace tbb;
using namespace std;

// Filter that writes lines to the output file.
class FileWriterFilter: public tbb::filter {
string outPath;
public:
FileWriterFilter(string outPath );
/*override*/void* operator()( void* item );
};

FileWriterFilter::FileWriterFilter( string outPath ) :
tbb::filter(/*is_serial=*/true),
outPath(outPath)
{
}

void* FileWriterFilter::operator()( void* item ) {

concurrent_queue<string>& outQueue = *static_cast<concurrent_queue<string>*>(item);
string line;
while(!outQueue.try_pop(line));

ofstream myfile(outPath);
if (myfile.is_open())
{
    myfile <<line<<endl;
}
//myfile.close();
return NULL;

 }

 class FileReaderFilter: public tbb::filter {
public:

FileReaderFilter(string inPath);

private:
ifstream ifs;
tbb::concurrent_queue<string> queue;
/*override*/ void* operator()(void*);

 };

 FileReaderFilter::FileReaderFilter(string inPath ) :
filter(/*is_serial=*/true),
ifs(inPath)
{
}

 void* FileReaderFilter::operator()(void*) {

string temp;

if( getline( ifs, temp ))
{

    queue.push(temp);
}

return &queue;
 }

class BitonicSort: public tbb::filter{

public:
    BitonicSort();
/*override*/void* operator()( void* item );

size_t *a;

private : static const  bool ASCENDING=true, DESCENDING=false;

public :void sort(size_t *b,int n)
{
    a=b;
    bitonicSort(0,n,ASCENDING);

}

private: void bitonicSort(int lo,int n,bool dir)
{
    if(n>1)
    {
        int m=n/2;
        bitonicSort(lo,m,ASCENDING);

        bitonicSort(lo+m,m,DESCENDING);
        bitonicMerge(lo,n,dir);


    }

}

private : void bitonicMerge(int lo,int n,bool dir)
     {
         if(n>1)
         {
             int m=n/2;
             for(int i=lo;i<lo+m;i++)
             {
                 compare(i,i+m,dir);

             }
             bitonicMerge(lo,m,dir);
             bitonicMerge(lo+m,m,dir);
         }
     }

private : void compare(int i,int j, bool dir)
          {
              if(dir==a[i]>a[j])
              {
                  exchange(i,j);

              }

          }

private : void exchange(int i,int j)
          {
            /*  cout<<a[i]<<" "<<a[j]<<endl;*/
              int t=a[i];
              a[i]=a[j];
              a[j]=t;
              /*cout<<a[i]<<" "<<a[j]<<endl<<endl;*/
          }

   private :string convertInt(int number)
   {
   stringstream ss;//create a stringstream
   ss << number;//add number to the stream
   return ss.str();//return a string with the contents of the stream
}
 };


 BitonicSort::BitonicSort() :
tbb::filter(/*serial=*/false)
 {}

 /*override*/void* BitonicSort::operator()( void* item ) {

int num_elem=2048;
size_t *max = new size_t[num_elem];
concurrent_queue<string>& queue = *static_cast<concurrent_queue<string>*>(item);
concurrent_queue<string> outQueue;
string line;
while(!queue.try_pop(line));  
istringstream iss(line);
int i=0;
do
{
    string sub;
    iss >> sub;
    max[i]=atoi(sub.c_str());;
    i++;
} while (iss);

sort(max,num_elem);

string out;

for(int i=0;i<num_elem;i++)
{
    out.append(convertInt(max[i]).append(" "));
}

outQueue.push(out);

return &outQueue;
 }


 int main() {

tbb::pipeline pipeline;

FileReaderFilter reader("sample.txt");
pipeline.add_filter(reader);

BitonicSort sorter;
pipeline.add_filter(sorter);

FileWriterFilter writer("test.txt");
pipeline.add_filter(writer);

pipeline.run(3);


pipeline.clear();

system("PAUSE");
 }
  • 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-05-20T20:12:23+00:00Added an answer on May 20, 2026 at 8:12 pm

    I found it! It was quite a trivial error. I have declared the 2nd concurrent_queue as a method variable in the operator method of the sorter filter of the pipeline. Thus every time the operator method executes the queue is reinitialized invalidating the pointer sent to the writer filter. the queue has to be a class variable of the sorter filter and everything works fine. There was another bug with the file writer which has been changed in the following. `

       #include <string>
       #include <algorithm>
       #include <fstream>
       #include "tbb\parallel_for.h"
       #include "tbb\blocked_range.h"
       #include "tbb\pipeline.h"
       #include "tbb\concurrent_queue.h"
       #include "tbb\task_scheduler_init.h"
       #include "tbb\tbb_thread.h"
       #include "tbb\task.h"
       #include <iostream>
       #include <sstream>
    
      using namespace tbb;
      using namespace std;
    
    
     // Filter that writes lines to the output file.
     class FileWriterFilter: public tbb::filter {
    
    public:
    int count;
    FileWriterFilter(FILE* outFile);
    
    private:
        FILE* outFile;
    
    /*override*/void* operator()( void* item );
    };
    
    FileWriterFilter::FileWriterFilter(FILE* outFile) :
    tbb::filter(/*is_serial=*/true),
    outFile(outFile),count(0)
    {
    }
    
    /*override*/void* FileWriterFilter::operator()( void* item ) {
    
    tbb::concurrent_queue<string> &outQueue = *static_cast<tbb::concurrent_queue<string>*>   (item);
    string outLine;
    
    while(!outQueue.try_pop(outLine))
        this_tbb_thread::yield();
    
    fprintf(outFile,outLine.append("\n").c_str());
    
    count++;
    if(count==10000){
        cout<<"over"<<endl;
    
    }
    return NULL;
    
     }
    
    
    class FileReaderFilter: public tbb::filter {
    public:
        FileReaderFilter(char* inPath);
    
    private:
    int count;
    ifstream ifs;
    tbb::concurrent_queue<string> queue;
    /*override*/ void* operator()(void*);
    
     };
    
    FileReaderFilter::FileReaderFilter(char* inPath ) :
    filter(/*is_serial=*/true),
    ifs(inPath),count(0)
    {
    }
    
    /*override*/void* FileReaderFilter::operator()(void*) {
    
    string temp;
    count++;
    if(count<=10000){
        if( getline( ifs, temp ))
        {
    
               queue.push(temp);
    
        }
        return &queue;
     }
    else{
        return NULL;
    }
    }
    
    
    class bitonicMerger : public tbb::task{
    int lo;
    int n;
    bool dir;
    size_t* a;
    private : static const  bool ASCENDING=true, DESCENDING=false;
    
    public:
        bitonicMerger(int lo_,int n_,bool dir_,size_t* a_): lo(lo_), n(n_),dir(dir_), a(a_) {}
    
    
        task* execute() {
        if(n>1)
        {                   
            int m=n/2;
            for(int i=lo;i<lo+m;i++)
            {
             compare(i,i+m,dir);
            }       
    
            int count = 1;
            tbb::task_list list;
            ++count;
            list.push_back( *new( allocate_child() ) bitonicMerger(lo,m,dir,a) );
            ++count;
            list.push_back( *new( allocate_child() ) bitonicMerger(lo+m,m,dir,a) );
            set_ref_count(count);
            spawn_and_wait_for_all(list);
        }
        return NULL;
    }
    
       private : void compare(int i,int j, bool dir)
              {
                  if(dir==a[i]>a[j])
                  {
                      exchange(i,j);
    
                  }
    
              }
    
    private : void exchange(int i,int j)
              {
    
                  int t=a[i];
                  a[i]=a[j];
                  a[j]=t;
    
              }
    
       };
    
    
     class bitonicSorter : public tbb::task{
    int lo;
    int n;
    bool dir;
    size_t* a;
    
    private : static const  bool ASCENDING=true, DESCENDING=false;
    
    public:
        bitonicSorter(int lo_,int n_,bool dir_,size_t* a_): lo(lo_), n(n_),dir(dir_), a(a_) {}
    
    task* execute() {
        if(n>1)
        {                   
            int m=n/2;
            int count = 1;
            tbb::task_list list;
            ++count;
            list.push_back( *new( allocate_child() ) bitonicSorter(lo,m,ASCENDING,a) );
            ++count;
            list.push_back( *new( allocate_child() ) bitonicSorter(lo+m,m,DESCENDING,a) );
            set_ref_count(count);
            spawn_and_wait_for_all(list);
    
    
    
            count = 1;
            tbb::task_list list1;
            ++count;
            list1.push_back( *new( allocate_child() ) bitonicMerger(lo,n,dir,a) );
            set_ref_count(count);
            spawn_and_wait_for_all(list1);
    
        }
        return NULL;
    }
    
     };
    
    
    
    
     class TBitonicSort : public tbb::filter{
    
    
    public:
        TBitonicSort();
    /*override*/void* operator()( void* item );
    
    
    size_t *a;
    
    private : static const  bool ASCENDING=true, DESCENDING=false;
    private : tbb::concurrent_queue<string> outQueue;
    
    public :void sort(size_t *b,int n)
    {
        a=b;        
        bitonicSorter& tt = *new(tbb::task::allocate_root())   bitonicSorter(0,n,ASCENDING,a);
        tbb::task::spawn_root_and_wait(tt); 
    }
    
    
    
    
    };
    
    string convertInt(int number)
    {
       stringstream ss;//create a stringstream
       ss << number;//add number to the stream
       return ss.str();//return a string with the contents of the stream
    }
    
    
    
    
    TBitonicSort::TBitonicSort() :
    filter(/*is_serial=*/true) 
    {}
    
    /*override*/void* TBitonicSort::operator()( void* item ) {
    
    int num_elem=2048;
    size_t *max = new size_t[num_elem];
    tbb::concurrent_queue<string>& queue = *static_cast<tbb::concurrent_queue<string>*>(item);
    
    string line;
    
    while(!queue.try_pop(line))
        this_tbb_thread::yield();   
    
    istringstream iss(line);
    int i=0;
    do
    {
        string sub;
        iss >> sub;
        max[i]=atoi(sub.c_str());;
        i++;
    } while (iss);
    
    sort(max,num_elem);
    
    string out;
    
    
    for(int i=0;i<num_elem;i++)
    {
        out.append(convertInt(max[i]).append(" "));
    }
    
    
    outQueue.push(out);
    
    return &outQueue;
    }
    
    int run_pipe(int threads)
    {
        FILE* output_file = fopen("test.txt","w");
        if( !output_file ) {
            perror( "test.txt" );
            return 0;
        }
        char* input_file="sample.txt";
    
    
        tbb::pipeline pipeline;
    
        FileReaderFilter reader(input_file);
        pipeline.add_filter(reader);
    
        TBitonicSort sorter;
        pipeline.add_filter(sorter);
    
        FileWriterFilter writer(output_file);
        pipeline.add_filter(writer);
    
        tbb::tick_count t0 = tbb::tick_count::now();
        pipeline.run(threads);
        tbb::tick_count t1 = tbb::tick_count::now();
    
        fclose( output_file );
        pipeline.clear();
    
        if(threads==1){
             printf("serial run   time = %g\n", (t1-t0).seconds());
        }
        else{
            printf("parallel run time = %g\n", (t1-t0).seconds());
        }
    
        return 0;
     }
    
    int main() {
    
    int threads[2]={1,3};
    
    
    for(int i=0;i<2;i++)
    {
        run_pipe(threads[i]);
    }
    system("PAUSE");
    }
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I'm writing out an XML file using VB.net. When I try to create another
I just read Emacs :TODO indicator at left side , and tried it out.
I have two different-sized monitors, connected together using (I believe) TwinView. I tried System.out.println(Toolkit.getDefaultToolkit().getScreenSize());
We're using the following approach to writing out text files: public void WriteFile(string filePath,
I'm writing out some xml from C# using the .net framework's XmlTextWriter. This works
Long ago I tried to sort out my system between local, web server and
I got tired of writing the following code: /* Commenting out irrelevant parts public
Have someone tried out DeCAL in Delphi 2009? I'm thinking about upgrading from 2007,
Has anyone tried out working with the Delete and update command of SPDataSource used
I downloaded today Subsonic 3 and tried out the examples. I am having a

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.