Friday, July 21, 2006
Visual Studio 2005 Solution Explorer Font Size, Or What do you mean "Icon?"
Large Monitor? Small Font? Solution explorer too hard to see in that tiny font. Looking for the visual studio setting to change the font size of solution explorer. Good Luck. In the "we don't really care" support department, "Aaron Brethorst" tells us that "by design" solution explorer uses the Desktop Icon font from your windows setting. At least you can change it. A compromise between added desktop waste and usability in the solution explorer.
https://connect.microsoft.com/feedback/ViewFeedback.aspx?FeedbackID=109160&SiteID=210
https://connect.microsoft.com/feedback/ViewFeedback.aspx?FeedbackID=109160&SiteID=210
Tuesday, July 11, 2006
Prime Numbers
Wikipedia Prime Numbers was also very useful recently. As was this page about reversing a singly linked list.
Fast Bit Counting Routines
This seems to have vanished from its stanford site. Thought I'd archive it here for my reference. Very interesting concepts.
Compiled from various sources by Gurmeet Singh Manku
Iterated Count runs in time
proportional to the total number of bits. It simply loops through
all the bits, terminating slightly earlier because of the while
condition. Useful if 1's are sparse and among the least significant
bits. Sparse Ones runs in time
proportional to the number of 1 bits. The line n &= (n - 1) simply
sets the rightmost 1 bit in n to 0. Dense
Ones runs in time proportional to the number of 0 bits.
It is the same as Sparse Ones, except that it first toggles all bits
(n ~= -1), and continually subtracts the number of 1 bits from
sizeof(int). Precompute_8bit
assumes an array bits_in_char such that bits_in_char[i] contains the
number of 1 bits in the binary representation for i. It repeatedly
updates count by masking out the last eight bits in
n, and indexing
into bits_in_char.
Precompute_16bit is a variant of
Precompute_8bit in that an array bits_in_16bits[] stores the number
of 1 bits in successive 16 bit numbers (shorts).
Parallel Count carries out bit
counting in a parallel fashion. Consider n after the first line has
finished executing. Imagine splitting n into pairs of bits. Each
pair contains the number of ones in those two bit positions
in the original n. After the second line has finished executing,
each nibble contains the number of ones in those four bits
positions in the original n. Continuing this for five iterations,
the 64 bits contain the number of ones among these sixty-four bit
positions in the original n. That is what we wanted to compute.
Nifty Parallel Count works the same
way as Parallel Count for the first three iterations. At the end of
the third line (just before the return), each byte of n contains the
number of ones in those eight bit positions in the original n. A
little thought then explains why the remainder modulo 255 works.
MIT Hackmem Count is funky.
Consider a 3 bit number as being 4a+2b+c. If we shift it right 1
bit, we have 2a+b. Subtracting this from the original gives 2a+b+c.
If we right-shift the original 3-bit number by two bits, we get a,
and so with another subtraction we have a+b+c, which is the number of
bits in the original number. How is this insight employed? The
first assignment statement in the routine computes tmp.
Consider the octal representation of tmp. Each digit in the
octal representation is simply the number of 1's in the corresponding
three bit positions in n. The last return statement sums
these octal digits to produce the final answer. The key idea is to
add adjacent pairs of octal digits together and then compute the
remainder modulus 63. This is accomplished by right-shifting
tmp by three bits, adding it to tmp itself and
ANDing with a suitable mask. This yields a number in which groups of
six adjacent bits (starting from the LSB) contain the number of 1's
among those six positions in n. This number modulo 63
yields the final answer. For 64-bit numbers, we would have to add
triples of octal digits and use modulus 1023. This is HACKMEM 169,
as used in X11 sources. Source: MIT AI Lab memo, late 1970's.
Which of the several bit counting routines is the fastest? Results
of speed trials on an i686 are summarized in the table on left. "No
Optimization" was compiled with plain gcc. "Some
Optimizations" was gcc -O3. "Heavy Optimizations"
corresponds to gcc -O3 -mcpu=i686 -march=i686 -fforce-addr
-funroll-loops -frerun-cse-after-loop -frerun-loop-opt
-malign-functions=4.
Thanks to Seth
Robertson who suggested performing speed trials by extending href="bitcount.c">bitcount.c. Seth also pointed me to
MIT_Hackmem routine. Thanks to href="mailto:dennyrolling@hotmail.com"> Denny Gursky who
suggested the idea of Precompute_11bit. That would require three
sums (11-bit, 11-bit and 10-bit precomputed counts). I then tried
Precompute_16bit which turned out to be even faster.
Gurmeet Singh Manku
Last update: 27 Jul 2002
Fast Bit Counting Routines
Compiled from various sources by Gurmeet Singh Manku
A common problem asked in job interviews is to count the number of
bits that are on in an unsigned integer. Here are
seven solutions to
this problem. Source code in C is available.
|
| ||||
|
|
Iterated Count runs in time
proportional to the total number of bits. It simply loops through
all the bits, terminating slightly earlier because of the while
condition. Useful if 1's are sparse and among the least significant
bits. Sparse Ones runs in time
proportional to the number of 1 bits. The line n &= (n - 1) simply
sets the rightmost 1 bit in n to 0. Dense
Ones runs in time proportional to the number of 0 bits.
It is the same as Sparse Ones, except that it first toggles all bits
(n ~= -1), and continually subtracts the number of 1 bits from
sizeof(int). Precompute_8bit
assumes an array bits_in_char such that bits_in_char[i] contains the
number of 1 bits in the binary representation for i. It repeatedly
updates count by masking out the last eight bits in
n, and indexing
into bits_in_char.
Precompute_16bit |
|
Precompute_16bit is a variant of
Precompute_8bit in that an array bits_in_16bits[] stores the number
of 1 bits in successive 16 bit numbers (shorts).
Parallel Count |
|
Parallel Count carries out bit
counting in a parallel fashion. Consider n after the first line has
finished executing. Imagine splitting n into pairs of bits. Each
pair contains the number of ones in those two bit positions
in the original n. After the second line has finished executing,
each nibble contains the number of ones in those four bits
positions in the original n. Continuing this for five iterations,
the 64 bits contain the number of ones among these sixty-four bit
positions in the original n. That is what we wanted to compute.
Nifty Parallel Count |
|
Nifty Parallel Count works the same
way as Parallel Count for the first three iterations. At the end of
the third line (just before the return), each byte of n contains the
number of ones in those eight bit positions in the original n. A
little thought then explains why the remainder modulo 255 works.
MIT HACKMEM Count |
|
MIT Hackmem Count is funky.
Consider a 3 bit number as being 4a+2b+c. If we shift it right 1
bit, we have 2a+b. Subtracting this from the original gives 2a+b+c.
If we right-shift the original 3-bit number by two bits, we get a,
and so with another subtraction we have a+b+c, which is the number of
bits in the original number. How is this insight employed? The
first assignment statement in the routine computes tmp.
Consider the octal representation of tmp. Each digit in the
octal representation is simply the number of 1's in the corresponding
three bit positions in n. The last return statement sums
these octal digits to produce the final answer. The key idea is to
add adjacent pairs of octal digits together and then compute the
remainder modulus 63. This is accomplished by right-shifting
tmp by three bits, adding it to tmp itself and
ANDing with a suitable mask. This yields a number in which groups of
six adjacent bits (starting from the LSB) contain the number of 1's
among those six positions in n. This number modulo 63
yields the final answer. For 64-bit numbers, we would have to add
triples of octal digits and use modulus 1023. This is HACKMEM 169,
as used in X11 sources. Source: MIT AI Lab memo, late 1970's.
No Optimization Some Optimization Heavy Optimization |
Which of the several bit counting routines is the fastest? Results
of speed trials on an i686 are summarized in the table on left. "No
Optimization" was compiled with plain gcc. "Some
Optimizations" was gcc -O3. "Heavy Optimizations"
corresponds to gcc -O3 -mcpu=i686 -march=i686 -fforce-addr
-funroll-loops -frerun-cse-after-loop -frerun-loop-opt
-malign-functions=4.
Thanks to Seth
Robertson who suggested performing speed trials by extending href="bitcount.c">bitcount.c. Seth also pointed me to
MIT_Hackmem routine. Thanks to href="mailto:dennyrolling@hotmail.com"> Denny Gursky who
suggested the idea of Precompute_11bit. That would require three
sums (11-bit, 11-bit and 10-bit precomputed counts). I then tried
Precompute_16bit which turned out to be even faster.
If you have niftier solutions up your sleeves, please href="mailto:manku@cs.stanford.edu">send me an e-mail
Gurmeet Singh Manku
Last update: 27 Jul 2002
Monday, July 03, 2006
Some thought-provoking algorithmic questions.
Some interesting questions I've been asked recently along with my responses. Try to determine a fast and efficient way to provide the result of each situation.
Middle element of a singly linked list
Suppose you have a singly linked list of objects. How would you determine the object in the middle of the list using a single pass? One way: create 2 pointers. The first pointer traverses the list using the next pointer for each element. Every other time through the list the 2nd pointer is moved to the next element. When the 1st pointer reaches the end, the 2nd pointer is the middle.
Considerations: What if the list changes during the search and elements are added or removed?
Nth element from end of a singly linked list
Suppose you have the same list. How would you determine the 5th object from the end of the list? One way: Similar to the above except the 2nd pointer doesn't begin traversing until the 1st pointer gets to the 5th element. Then both pointers move until the 1st pointer again reaches the end. The 2nd pointer will point at the 5th element from the end.
Considerations: Same.
Sorting a file of integers
Suppose you have a file of integers. The size of the file is unknown. Each integer is in the range of 0 to 1000. How would you print the integers in sorted order? One way: create a 1000-element array. As each integer is read, use it as an index into the array and increment that element by 1. The array will hold a count of occurrences of each integer. At EOF, iterate over the 1000-element array and print the index of each non-zero cell using the value of the cell to tell how many times to print the index.
Considerations: file access security, buffers size, integer values within range
Find the start of a list
Suppose you have a array of integers. The array is sorted into ascending order except the starting point of the element is unknown. Find the 0-based index of lowest valued element in the array. For example, (20,30,5,10,15) returns 2. The array is a fixed, unlimited size. One way: Split the list in half. Compare the value of the left most element to the value midpoint element and compare the value of the midpoint element to the right most element. This comparison yields which half of the list contains the point where the numbers recycle. Update the left or right pointer to the mid point, reset to the new middle point. Repeat until left and right are adjacent. Compare the 2 values and return the index of the lower.
Considerations: locking the list from change, assuming list is sorted per specification, duplicates
Find a duplicate value
Suppose you have an array of integers. The size of the array is unlimited. Each cell in the array contains a value between 1 and the number of elements in the array. Find the value of any element that occurs more than once in the list. For example, (1,2,3,2,3) returns 2 or 3 but not 1. The list must remain intact when the function completes. One way: iterate through the list. Using the value of each cell as an index, negate the element (vals[Math.abs(vals[index])]) *= -1. If the element is already negative, it is a duplicate. Save the value. Revert all negatives values to positive.
Considerations: write access to target from called routine, locking list from change whilst executing.
Add an index to a very large data base table
You have a very high availability data base with a very large table that has a high frequency of inserts (10 per second). There are >400M rows in the table. You need to create a new index on the table with little to no downtime on the table. You cannot use create index because locking would stall access until it was able to complete. One way: Create a new table with the new index. Copy over all rows from the base table. Upon completion of the copy, rename the tables. Copy any rows that appeared between the end of your copy operation and the rename operation. Only a slight number of rows would receive an error. The application would be smart enough to wait a few seconds and retry.
The fox, the hen and the bag of corn.
A farmer has to cross a stream in a canoe. He has a fox, a hen and a bag of corn. He can only carry one item at a time with him across the stream in the canoe. If he leaves the fox alone with the chicken, the fox will eat the chicken. If he leaves the chicken alone with the corn, the chicken will eat the corn. How can he get everything across the stream in the least number of trips?
One way: Take the chicken across. Go back and get the fox. Leave the fox and take the chicken back to the original side. Leave the chicken on the original side and take the corn across. Go back and get the chicken.
Middle element of a singly linked list
Suppose you have a singly linked list of objects. How would you determine the object in the middle of the list using a single pass? One way: create 2 pointers. The first pointer traverses the list using the next pointer for each element. Every other time through the list the 2nd pointer is moved to the next element. When the 1st pointer reaches the end, the 2nd pointer is the middle.
Considerations: What if the list changes during the search and elements are added or removed?
Nth element from end of a singly linked list
Suppose you have the same list. How would you determine the 5th object from the end of the list? One way: Similar to the above except the 2nd pointer doesn't begin traversing until the 1st pointer gets to the 5th element. Then both pointers move until the 1st pointer again reaches the end. The 2nd pointer will point at the 5th element from the end.
Considerations: Same.
Sorting a file of integers
Suppose you have a file of integers. The size of the file is unknown. Each integer is in the range of 0 to 1000. How would you print the integers in sorted order? One way: create a 1000-element array. As each integer is read, use it as an index into the array and increment that element by 1. The array will hold a count of occurrences of each integer. At EOF, iterate over the 1000-element array and print the index of each non-zero cell using the value of the cell to tell how many times to print the index.
Considerations: file access security, buffers size, integer values within range
Find the start of a list
Suppose you have a array of integers. The array is sorted into ascending order except the starting point of the element is unknown. Find the 0-based index of lowest valued element in the array. For example, (20,30,5,10,15) returns 2. The array is a fixed, unlimited size. One way: Split the list in half. Compare the value of the left most element to the value midpoint element and compare the value of the midpoint element to the right most element. This comparison yields which half of the list contains the point where the numbers recycle. Update the left or right pointer to the mid point, reset to the new middle point. Repeat until left and right are adjacent. Compare the 2 values and return the index of the lower.
Considerations: locking the list from change, assuming list is sorted per specification, duplicates
Find a duplicate value
Suppose you have an array of integers. The size of the array is unlimited. Each cell in the array contains a value between 1 and the number of elements in the array. Find the value of any element that occurs more than once in the list. For example, (1,2,3,2,3) returns 2 or 3 but not 1. The list must remain intact when the function completes. One way: iterate through the list. Using the value of each cell as an index, negate the element (vals[Math.abs(vals[index])]) *= -1. If the element is already negative, it is a duplicate. Save the value. Revert all negatives values to positive.
Considerations: write access to target from called routine, locking list from change whilst executing.
Add an index to a very large data base table
You have a very high availability data base with a very large table that has a high frequency of inserts (10 per second). There are >400M rows in the table. You need to create a new index on the table with little to no downtime on the table. You cannot use create index because locking would stall access until it was able to complete. One way: Create a new table with the new index. Copy over all rows from the base table. Upon completion of the copy, rename the tables. Copy any rows that appeared between the end of your copy operation and the rename operation. Only a slight number of rows would receive an error. The application would be smart enough to wait a few seconds and retry.
The fox, the hen and the bag of corn.
A farmer has to cross a stream in a canoe. He has a fox, a hen and a bag of corn. He can only carry one item at a time with him across the stream in the canoe. If he leaves the fox alone with the chicken, the fox will eat the chicken. If he leaves the chicken alone with the corn, the chicken will eat the corn. How can he get everything across the stream in the least number of trips?
One way: Take the chicken across. Go back and get the fox. Leave the fox and take the chicken back to the original side. Leave the chicken on the original side and take the corn across. Go back and get the chicken.
Integrating SQL Server 2005 Reporting Services into an ASP.Net application
I recently had a chance to work with SQL Server 2005 Reporting services. I must say I'm fairly impressed with the offering. You can pull data from just about anywhere into a single place and then serve up reports in almost any format you want. Data from office docs (xl, word), XML files, just about any data base, flat files can be mushed together and served up in HTML, back to xl, PDF, and/or email formats.
I am integrating reports in an ASP.NET 2.0 application. The reports appear as another page inside the app with all of our menus, navigation, security and such wrapped around it. VS2005 includes a new data control called Report Viewer. Just set some properties and it serves up your report.
My only problem I had was in the deployment. Of course, everything works fine during development while everything is running on my local machine. The problem comes into play when the production environment is used where reporting services runs on a different machine from the web server. I was continually getting "The request failed with HTTP status 401" failure. Nothing in the IIS or Reporting Services log was helpful.
I eventually stumbled on a property of ServerReport called ReportServerCredentials. This was the secret element that eventually solved my problem. I found a sample on MSDN that got me most of the way there and it reminded me of this joke (scroll down to lost in space). It seems you can create a custom object to implement the IReportServerCredentials interface. The sample shows using forms authentication and a cookie. It turns out I what I wanted to use was the network credentials option instead. Using the debugger and trial and error, it seems that when have your custom object, reporting services first tries to use WindowsIdentity, then NetworkCredentials then GetFormsCredentials. WindowsIdentity returns a null value which appears to be a signal to try something else. GetFormsCredentials needs to return false after setting all of the out parameters to null. NetworkCredentials actually returns a System.Net.ICredentials object. I just created some properties in my web.config for ID and password.
On the report server machine, I added a local user and removed all logon rights. It's not the best security because the ID and password are in plain text in the file but there are other ways to work around that. So after 6 hours of research, I now have a fully functional report viewer integrated into my application.
Problem #2 was that I was getting my report rendered (i.e. I could see the little animation showing "generating report") but upon render, it never showed up in the HTML for the page. I did a quick web search and found some entries showing that if you set width and height to 100% that could cause the problem. I tried setting both to actual values (e.g. 400px). However, this caused scroll bars when the reports were larger than this.
A better fix seemed to be to change width and height back to 100% and set the viewer property AsyncRendering to false. Now the page takes a few extra seconds to display while the report is being retrieved but it correctly shows in the output.
All in all, I'd say I'm very happy with reporting services. Just a few little tweaks and maybe some better documentation would make it a fine tool.
Tweaked Sample implementation of IReportServerCredentials
///
/// custom objec to supply credentials for report server.
/// this implementation asks the utility for the ID and password
/// and relies on NetworkCredentials to login to the report server.
/// the ID configured must exist on the report server and be granted
/// access to execute the specified reports.
///
/// The ID should be denied "logon locally" access to prevent
/// misuse.
///
///
private class MyReportServerCredentials : IReportServerCredentials
{
public MyReportServerCredentials()
{
}
public WindowsIdentity ImpersonationUser
{
get
{
return null;
}
}
public System.Net.ICredentials NetworkCredentials
{
get
{
NetworkCredential nc = new NetworkCredential();
nc.UserName = ReportUtilities.ReportUserID;
nc.Password = ReportUtilities.ReportPassword;
return nc; // Using NetworkCredentials to authenticate.
}
}
public bool GetFormsCredentials(out System.Net.Cookie authCookie, out string user, out string password, out string authority)
{
authCookie = null;
user = password = authority = null;
return false; // do not use forms credentials to authenticate.
}
}
Sample call from ASP.NET page. Call from Page_Load() or other UI event method. This is a business layer routine that causes the report to be rendered in the output. Security checks are omitted from this method.
public static void Render(System.Web.UI.Page report, ReportViewer viewer)
{
string reportID = ID(report); // lookup path from query string
// perform security validation here
viewer.ServerReport.ReportServerUrl = ReportServerUrl; // property from web.config
viewer.ServerReport.ReportPath = ReportPath(reportID); // util function
viewer.ServerReport.ReportServerCredentials = new MyReportServerCredentials();
}
Call from ASP.Net code behind
protected void Page_Load(object sender, EventArgs e)
{
// Security Access check is performed by Render utility.
ReportUtilities.Render(this, this.Report);
}
I am integrating reports in an ASP.NET 2.0 application. The reports appear as another page inside the app with all of our menus, navigation, security and such wrapped around it. VS2005 includes a new data control called Report Viewer. Just set some properties and it serves up your report.
My only problem I had was in the deployment. Of course, everything works fine during development while everything is running on my local machine. The problem comes into play when the production environment is used where reporting services runs on a different machine from the web server. I was continually getting "The request failed with HTTP status 401" failure. Nothing in the IIS or Reporting Services log was helpful.
I eventually stumbled on a property of ServerReport called ReportServerCredentials. This was the secret element that eventually solved my problem. I found a sample on MSDN that got me most of the way there and it reminded me of this joke (scroll down to lost in space). It seems you can create a custom object to implement the IReportServerCredentials interface. The sample shows using forms authentication and a cookie. It turns out I what I wanted to use was the network credentials option instead. Using the debugger and trial and error, it seems that when have your custom object, reporting services first tries to use WindowsIdentity, then NetworkCredentials then GetFormsCredentials. WindowsIdentity returns a null value which appears to be a signal to try something else. GetFormsCredentials needs to return false after setting all of the out parameters to null. NetworkCredentials actually returns a System.Net.ICredentials object. I just created some properties in my web.config for ID and password.
On the report server machine, I added a local user and removed all logon rights. It's not the best security because the ID and password are in plain text in the file but there are other ways to work around that. So after 6 hours of research, I now have a fully functional report viewer integrated into my application.
Problem #2 was that I was getting my report rendered (i.e. I could see the little animation showing "generating report") but upon render, it never showed up in the HTML for the page. I did a quick web search and found some entries showing that if you set width and height to 100% that could cause the problem. I tried setting both to actual values (e.g. 400px). However, this caused scroll bars when the reports were larger than this.
A better fix seemed to be to change width and height back to 100% and set the viewer property AsyncRendering to false. Now the page takes a few extra seconds to display while the report is being retrieved but it correctly shows in the output.
All in all, I'd say I'm very happy with reporting services. Just a few little tweaks and maybe some better documentation would make it a fine tool.
Tweaked Sample implementation of IReportServerCredentials
///
/// custom objec to supply credentials for report server.
/// this implementation asks the utility for the ID and password
/// and relies on NetworkCredentials to login to the report server.
/// the ID configured must exist on the report server and be granted
/// access to execute the specified reports.
///
/// The ID should be denied "logon locally" access to prevent
/// misuse.
///
///
private class MyReportServerCredentials : IReportServerCredentials
{
public MyReportServerCredentials()
{
}
public WindowsIdentity ImpersonationUser
{
get
{
return null;
}
}
public System.Net.ICredentials NetworkCredentials
{
get
{
NetworkCredential nc = new NetworkCredential();
nc.UserName = ReportUtilities.ReportUserID;
nc.Password = ReportUtilities.ReportPassword;
return nc; // Using NetworkCredentials to authenticate.
}
}
public bool GetFormsCredentials(out System.Net.Cookie authCookie, out string user, out string password, out string authority)
{
authCookie = null;
user = password = authority = null;
return false; // do not use forms credentials to authenticate.
}
}
Sample call from ASP.NET page. Call from Page_Load() or other UI event method. This is a business layer routine that causes the report to be rendered in the output. Security checks are omitted from this method.
public static void Render(System.Web.UI.Page report, ReportViewer viewer)
{
string reportID = ID(report); // lookup path from query string
// perform security validation here
viewer.ServerReport.ReportServerUrl = ReportServerUrl; // property from web.config
viewer.ServerReport.ReportPath = ReportPath(reportID); // util function
viewer.ServerReport.ReportServerCredentials = new MyReportServerCredentials();
}
Call from ASP.Net code behind
protected void Page_Load(object sender, EventArgs e)
{
// Security Access check is performed by Render utility.
ReportUtilities.Render(this, this.Report);
}