{"id":289,"date":"2011-01-03T21:52:25","date_gmt":"2011-01-04T02:52:25","guid":{"rendered":"http:\/\/hstore.cs.brown.edu\/?p=289"},"modified":"2011-09-06T14:28:18","modified_gmt":"2011-09-06T18:28:18","slug":"student-research-projects","status":"publish","type":"post","link":"https:\/\/hstore.cs.brown.edu\/2011\/01\/student-research-projects\/","title":{"rendered":"Student Research Projects"},"content":{"rendered":"
The H-Store project is looking for capable undergraduate and graduate students to assist with the development of the database and its supporting environment. The following are list of open research projects that are available. Interested students need not be at Brown, MIT, or Yale, but we ask if are not at one of those schools then to please coordinate with us first before proceeding.<\/p>\n<\/a><\/p>\n Estimated Time:<\/strong> 20-30 hours. <\/a><\/p>\n <\/a><\/p>\n <\/a><\/p>\n The H-Store project is looking for capable undergraduate and graduate students to assist with the development of the database and its supporting environment. The following are list of open research projects that are available. Interested students need not be at Brown, MIT, or Yale, but we ask if are not at one of those schools […]<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[4],"tags":[],"_links":{"self":[{"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/posts\/289"}],"collection":[{"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/comments?post=289"}],"version-history":[{"count":35,"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/posts\/289\/revisions"}],"predecessor-version":[{"id":523,"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/posts\/289\/revisions\/523"}],"wp:attachment":[{"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/media?parent=289"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/categories?post=289"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/hstore.cs.brown.edu\/wp-json\/wp\/v2\/tags?post=289"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}TPC-E Benchmark Port<\/h3>\n
\nWe currently have a partial implementation of the TPC-E Benchmark<\/a> written for H-Store. We are looking for a student to complete the port and get the benchmark fully running on the H-Store system (or as close to the official specification as possible). There are two tasks in this project: (1) integrate the official TPC-E C++ workload generator into H-Store’s Java-based benchmark framework and (2) refactor any complex queries that contain SQL features that are currently not supported by H-Store into equivalent multiple queries and Java code. For the former task, we have already integrated the TPC-E EGenLoader into an H-Store benchmark data loader<\/a>, but we still need to add JNI hooks into the EGenClient driver in order to generate the transactional workload (e.g., store procedure invocations with input parameters). Once this is done, the next step is go through the TPC-E stored procedures written for H-Store and refactor them as needed in order to produce the correct results. For example, the H-Store distributed planner has trouble with the seven table join query in the BrokerVolume<\/a> transaction; the student will need to break the single large query up into multiple queries and combine the results in the Java-portion of the stored procedure. Students will need some previous C++ and Java development experience.<\/p>\nAirline Booking OLTP Benchmark<\/s><\/h3>\nEstimated Time:<\/strong> 30-40 hours.<\/s>
\nMuch like TPC-E, we also have a half-completed implementation of a new OLTP benchmark that is based on airline ticket booking systems. This work is an enhancement of a ticketing system benchmark designed by Mike Stonebraker<\/a> in 2008. We are looking to add non-deterministic transactions that are more complex than the original benchmark specification. Specifically we are interested in adding affinity-based skew in the data based real world information (e.g., flights out of Madison, WI are more likely to fly to Chicago, IL than any other destination). This project consists of (1) writing a synthetic data loader that is based on publicly available air travel information<\/a> from the FAA, (2) creating stored procedures that model an airline ticketing system, and (3) writing documentation on the data loader and workload generator. All code will be written in Java using the H-Store benchmark framework.<\/p>\nSystem Development & Optimization<\/s><\/h3>\nEstimated Time:<\/strong> 10-40 hours.<\/s>
\nThe original VoltDB transaction coordination system was completely removed and rewritten in H-Store in order to support more complex transaction workloads in our research projects. As such, it is obviously not as optimized as VoltDB. We are looking for a resourceful student to profile the Java-based frontend code in order to identify performance bottlenecks and then work with one of the H-Store developers to optimize the code. The complexity and scope of this project can vary based on the student’s skill set. Some issues may be as simple as correcting bad coding practices, while others could involve integrating a shared memory message passing subsystem. Familiarity with Java-based profiling tools (e.g., JProfiler) is preferred but not required.<\/s><\/p>\nUniversal OLTP Benchmark Framework<\/s><\/h3>\nEstimated Time:<\/strong> 30-50 hours.<\/s>
\nWe are working in conjunction with the RelationalCloud<\/a> project to develop a general benchmark framework for comparing parallel OLTP systems. This project is similar to the Yahoo! Cloud Serving Benchmark<\/a> platform. Possible responsibilities could include (1) integrating a harness for benchmarks written using the H-Store benchmark framework, (2) writing plug-ins for other DBMSs (e.g., Oracle, DB2), and (3) collecting workload samples and analyzing performance results. This project is more research-focused than the other ones listed above.<\/p>\n","protected":false},"excerpt":{"rendered":"