나누기 1000을 효과적으로 하는 방법?

wputer의 이미지

maintick이 매 1ms마다 1씩증가합니다.

이를 이용하여 매 초를 체크하고싶은데

1000을 나누어 나누어 떨어질 때를 1초로 체크하고싶습니다.

'%'나 '/'를 사용하자니 비용이 클꺼같아서

1000의 hex값인 0x3E8를 비트연산하여
체크하려는데 더 좋은방법이나 이 방식에 문제점이 있을까요?

u16 check1Sec(void) {
	return !(main_tick&0x3E8);
}

bushi의 이미지

$ printf "%x\n" 1000
3e8
$ printf "%x\n" 2000
7d0

결정적으로

$ printf "%03x\n" 1
001
wputer의 이미지

고치고 있습니다 ㅎㅎ 제 생각이 짧았네요 ;;

wputer의 이미지

그냥 머리아파서

u16 check1Sec(void) {
	return !(main_tick%1000);
}

해버렸어요 ㅎㅎ
klenui의 이미지

1000 = 125 * 8이니까.. 끝에 3비트가 0인지 체크만 해도 좀 빨라지지 않을까요..?
끝 3비트가 0이 아니면 1000의 배수가 아닌게 확실하니까요..

만약 이런 식이라면....

if ( t & 0x7 ) return false; ------------------ (1)
return (t % 1000) == 0; ------- (2)

7/8의 확률로 1번에서 걸러지고.. 1/8의 확률로 2번을 거칠겁니다.(유니폼 확률로 인자가 주어진다고 할때.. 아니라면 입력 확률에 맞도록 알고리즘을 짜야죠..)
(1)의 비용이 1, (2)의 비용이 n이라고 하면 총 비용의 평균은 7/8 + (n+1)/8이네요..

원래 방식(그냥 1000으로 나눠보는 방식)과 비교하면..

원래방식 > 비트 비교 방식
n > 7/8 + (n+1)/8
n > 8/7

1000 나누기 연산보다 비트 연산이 12.5%이상 빠르기만 하면 위 방식이 더 낫다고 할 수 있겠네요..
맥주한잔하고 쓰는 내용이라 맞는지는 모르겠습니다.

gilgil의 이미지

오오, 흥미롭네요. ^^

익명 사용자의 이미지

8/7=1.14...

익명 사용자의 이미지

=>1000모드연산시간이 &연산시간보다 8/7배이상 오래 걸리면 두번째 방법이 더 빠름.
==>&연산시간이 1000모드연산시간보다 1/(8/7)*100=12.5(%)빠르면 두번째 방법이 더 빠름.

익명 사용자의 이미지

감사합니다

익명 사용자의 이미지

정확히 1초일 필요가 없다면
1024틱마다 재는 수도 있습니다.

근데 /나 %연산이 아까워서 저렇게까지 할 필요가 있을까요?

gilgil의 이미지


http://www.gilgil.net/31635

결론 : 대충 알아서 코딩을 해도 C++ 컴파일러가 알아서 최적화를 해 준다.

wputer의 이미지

와 감사합니다!!! 정말 많은 도움이 되었습니다.
컴파일러가 생각보다 많이! 똑똑하네요 ㅎㅎ

익명 사용자의 이미지

저도 가끔 어셈코드를 보는지라 컴파일러가 결과만 맞다면 무슨짓이든 한다..라는걸 알고 있었습니다만, 이정도인지는 몰랐네요..
좋은 정보 감사합니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.