Skip to content

Commit

Permalink
docs: es-hangul의 빠름을 보여줄 수 있는 벤치마크 페이지를 만듭니다. (#286)
Browse files Browse the repository at this point in the history
* benchmark page

* Remove hangul-js
  • Loading branch information
okinawaa authored Nov 20, 2024
1 parent cd09392 commit 7d3f4b1
Show file tree
Hide file tree
Showing 8 changed files with 192 additions and 23 deletions.
4 changes: 1 addition & 3 deletions benchmarks/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,9 @@
"es-hangul": "workspace:^",
"esbuild": "0.23.0",
"josa": "^3.0.1",
"k-popo": "^2.0.5",
"vitest": "^2.1.2"
},
"devDependencies": {
"@types/josa": "^3"
},
"version": null
}
}
12 changes: 0 additions & 12 deletions benchmarks/performance/josa.bench.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ import { fakerKO as faker } from '@faker-js/faker';
import { josa as autoJosa } from 'auto-josa';
import { josa as esHangulJosa } from 'es-hangul';
import { josa } from 'josa';
import { ko } from 'k-popo';
import { bench, describe } from 'vitest';

const name = faker.person.firstName();
Expand All @@ -20,10 +19,6 @@ describe('하나의 조사', () => {
bench('josa', () => {
josa(`${name}#{이}`);
});

bench('k-popo', () => {
ko`${name}(이)가`;
});
});

const city = faker.location.city();
Expand Down Expand Up @@ -51,11 +46,4 @@ describe(`네개의 조사 ${name}이/가 ${noun}을/를 ${city}은/는 ${street
josa(`${city}#{은}`);
josa(`${street}#{와}`);
});

bench('k-popo', () => {
ko`${noun}(이)가`;
ko`${name}(을)를`;
ko`${city}(은)는`;
ko`${street}(와)과`;
});
});
7 changes: 7 additions & 0 deletions docs/src/pages/docs/introduction.en.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,13 @@ const sentence2 = josa(word2, '이/가') + ' 맛있습니다.';
console.log(sentence2); // '바나나가 맛있습니다.'
```

### Fast


es-hangul boasts **top-notch performance**, efficiently handling complex tasks such as Korean character composition and decomposition with incredible speed.
[Benchmark tests]('./technical/benchmark') against other libraries have shown that es-hangul delivers **overwhelmingly superior performance**.


<Callout type="info">

If you have a good idea for handling Hangul well, please let us know. [Suggest a feature via GitHub Issue](https://github.com/toss/es-hangul/issues/new?assignees=&labels=feature&projects=&template=feature_request.yml&title=%5BFeature%5D%3A)
Expand Down
8 changes: 8 additions & 0 deletions docs/src/pages/docs/introduction.ko.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,14 @@ const sentence2 = josa(word2, '이/가') + ' 맛있습니다.';
console.log(sentence2); // '바나나가 맛있습니다.'
```


### 매우 빠릅니다

`es-hangul`**한글 조합****분해** 같은 복잡한 작업을 놀라운 속도로 수행하는 **최고의 성능**을 자랑합니다.<br/>
다른 라이브러리와의 [벤치마크](./technical/benchmark) 테스트 결과, `es-hangul`**압도적으로 빠른 성능**을 보여주었습니다



<Callout type="info">

한글을 잘 다루기 위한 좋은 아이디어가 있다면 알려주세요. [GitHub Issue로 기능 제안하기](https://github.com/toss/es-hangul/issues/new?assignees=&labels=feature&projects=&template=feature_request.yml&title=%5BFeature%5D%3A)
Expand Down
143 changes: 143 additions & 0 deletions docs/src/pages/docs/technical/benchmark-bar-chart.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
import { useEffect, useRef, useState } from 'react';

const ANIMATION_THRESHOLD = 0.3;

interface BenchmarkBarChart {
locale: 'ko' | 'en';
}

export const BenchmarkBarChart = ({ locale }: BenchmarkBarChart) => {
const [filledPercentages, setFilledPercentages] = useState<number[]>(benchmarkData.map(() => 0));
const [isVisible, setIsVisible] = useState(false);
const chartRef = useRef<HTMLDivElement>(null);

useEffect(() => {
const observer = new IntersectionObserver(
([entry]) => {
if (entry.intersectionRatio >= ANIMATION_THRESHOLD) {
setIsVisible(true);
}
},
{ threshold: ANIMATION_THRESHOLD }
);

if (chartRef.current) {
observer.observe(chartRef.current);
}

return () => {
if (chartRef.current) {
observer.unobserve(chartRef.current);
}
};
}, []);

useEffect(() => {
const maximum = Math.max(...benchmarkData.map(data => data.operationsPerSecond));

if (isVisible) {
setFilledPercentages(benchmarkData.map(data => (data.operationsPerSecond / maximum) * 100));
}
}, [isVisible]);

const isKorean = locale === 'ko';

return (
<div
ref={chartRef}
className="flex flex-col items-center w-full p-6 bg-gray-100 dark:bg-gray-800 rounded-lg shadow-md"
>
<h1 className="text-3xl font-bold mb-8 text-center text-gray-900 dark:text-gray-100">
<span className="text-blue-600 dark:text-blue-400">Lightning Fast</span>
</h1>

<div className="space-y-3 w-full max-w-xl">
{benchmarkData.map((data, index) => (
<div key={data.name} className="flex flex-col">
<div className="flex justify-between items-center mb-1">
<span
className={`text-lg font-medium ${
data.status === 'fastest' ? 'text-blue-600 dark:text-blue-400' : 'text-gray-800 dark:text-gray-300'
}`}
>
{data.name}
</span>

{data.name === 'es-hangul' && (
<span className="text-sm text-green-500">fastest</span> // status는 es-hangul에만 표시
)}
</div>
<div className="relative h-4 bg-gray-300 dark:bg-gray-700 rounded-full overflow-hidden">
<div
className={`absolute top-0 left-0 h-full rounded-full ${
data.name === 'es-hangul'
? 'bg-gradient-to-r from-blue-500 via-purple-500 to-pink-500'
: 'bg-blue-200'
}`}
style={{
width: `${filledPercentages[index]}%`,
transition: 'width 1.5s ease-in-out',
}}
></div>
</div>
<div className="flex justify-between mt-2 text-sm text-gray-600 dark:text-gray-400">
{isKorean ? (
<>
<span>작업 처리량: {data.operationsPerSecond.toLocaleString()} ops/sec</span>
<span>1000만 건 처리 시간: {data.timeToProcess}</span>
</>
) : (
<>
<span>Throughput: {data.operationsPerSecond.toLocaleString()} ops/sec</span>
<span>Processing time for 10 million records: {data.timeToProcess} seconds</span>
</>
)}
</div>
</div>
))}
</div>
<p className="text-sm text-gray-600 dark:text-gray-400 mt-4 mb-4 italic">
{isKorean ? '* josa 함수를 기준으로 측정하였습니다.' : '* Measurements were based on the `josa` function.'}
</p>

<a
href="https://github.com/toss/es-hangul/tree/main/benchmarks"
target="_blank"
rel="noopener noreferrer"
className="relative mt-8 px-6 py-3 rounded-full text-white text-lg font-semibold shadow-md transition-all duration-200 group"
>
<span
className="absolute inset-2 rounded-full bg-gradient-to-r from-blue-500 via-purple-500 to-pink-500
opacity-75 blur-sm group-hover:blur-md group-hover:opacity-100 transition-all duration-300"
aria-hidden="true"
></span>
<span
className="relative block px-8 py-3 bg-gray-800 rounded-full text-white dark:bg-gray-700
group-hover:bg-gradient-to-r group-hover:from-blue-600 group-hover:via-purple-600 group-hover:to-pink-600 transition-all duration-300"
>
{isKorean ? '더 자세한 벤치마크 결과 보기' : 'See more detailed benchmark results'}
</span>
</a>
</div>
);
};

const 천만 = 10000000;
const benchmarkData = [
{
name: 'es-hangul',
operationsPerSecond: 11199038,
timeToProcess: (천만 / 11199038).toFixed(2),
status: 'fastest',
},
{
name: 'auto-josa',
operationsPerSecond: 8512551,
timeToProcess: (천만 / 8512551).toFixed(2),
},
{
name: 'josa',
operationsPerSecond: 3334947,
timeToProcess: (천만 / 3334947).toFixed(2),
},
];
17 changes: 17 additions & 0 deletions docs/src/pages/docs/technical/benchmark.en.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
---
title: benchamark
---

import { BenchmarkBarChart } from './benchmark-bar-chart.tsx';


# ⚡ Fast Korean Text Processing Library


es-hangul boasts **top-notch performance**, efficiently handling complex tasks such as Korean character composition and decomposition with incredible speed.
Benchmark tests against other libraries have shown that es-hangul delivers **overwhelmingly superior performance**.

<br />
<br />

<BenchmarkBarChart locale='en'/>
16 changes: 16 additions & 0 deletions docs/src/pages/docs/technical/benchmark.ko.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
---
title: benchamark
---

import { BenchmarkBarChart } from './benchmark-bar-chart.tsx';


# ⚡ 빠른 한글 처리 라이브러리

`es-hangul`**한글 조합****분해** 같은 복잡한 작업을 놀라운 속도로 수행하는 **최고의 성능**을 자랑합니다.<br/>
다른 라이브러리와의 벤치마크 테스트 결과, `es-hangul`**압도적으로 빠른 성능**을 보여주었습니다

<br />
<br />

<BenchmarkBarChart locale="ko"/>
8 changes: 0 additions & 8 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -3650,7 +3650,6 @@ __metadata:
es-hangul: "workspace:^"
esbuild: "npm:0.23.0"
josa: "npm:^3.0.1"
k-popo: "npm:^2.0.5"
vitest: "npm:^2.1.2"
languageName: unknown
linkType: soft
Expand Down Expand Up @@ -8326,13 +8325,6 @@ __metadata:
languageName: node
linkType: hard

"k-popo@npm:^2.0.5":
version: 2.0.5
resolution: "k-popo@npm:2.0.5"
checksum: 10c0/00e0e84bf04edf5cd61859891c210ed82b5cacc4546dc7302bb708a7409d648b38814ec3b791c2994ccf3f23285e1c88622af0d21614d39b4667a3d49640ba62
languageName: node
linkType: hard

"katex@npm:^0.16.0, katex@npm:^0.16.9":
version: 0.16.10
resolution: "katex@npm:0.16.10"
Expand Down

0 comments on commit 7d3f4b1

Please sign in to comment.