NC Bench
Overview
About
Tests
Categories
Models
Vendors
Compare
Run: 2026-04-24-01KQ03QGGSZR41T7B79CGHCWPX
Run Details
Model:
GPT-OSS 120B
Test:
Bad Writing Habits
Scenario:
Romance: separated couple reunites
Duration:
4m 30s
Cost:
$0.001321
Provider:
SiliconFlow
Evaluation summary
Score
Evaluator
Details Link
100.00%
Adverbs in dialogue tags
(details)
96.83%
AI-ism adverb frequency
(details)
100.00%
AI-ism character names
(details)
100.00%
AI-ism location names
(details)
23.95%
AI-ism word frequency
(details)
33.33%
Cliché density
(details)
100.00%
Emotion telling (show vs. tell)
(details)
100.00%
Filter word density
(details)
100.00%
Gibberish response detection
(details)
100.00%
Markdown formatting overuse
(details)
100.00%
Missing dialogue indicators (quotation marks)
(details)
50.00%
Name drop frequency
(details)
100.00%
Narrator intent-glossing
(details)
100.00%
"Not X but Y" pattern overuse
(details)
100.00%
Overuse of "that" (subordinate clause padding)
(details)
47.63%
Paragraph length variance
(details)
100.00%
Passive voice overuse
(details)
100.00%
Past progressive (was/were + -ing) overuse
(details)
19.97%
Em-dash & semicolon overuse
(details)
100.00%
Purple prose (modifier overload)
(details)
100.00%
Repeated phrase echo
(details)
100.00%
Sentence length variance
(details)
50.54%
Sentence opener variety
(details)
0.00%
Adverb-first sentence starts
(details)
86.67%
Pronoun-first sentence starts
(details)
0.00%
Subject-first sentence starts
(details)
0.00%
Subordinate conjunction sentence starts
(details)
96.27%
Technical jargon density
(details)
0.00%
Useless dialogue additions
(details)
0.00%
Dialogue tag variety (said vs. fancy)
(details)
70.1733%
Overall
Model input
System
You are an expert and award-winning novel writer in the dark Romance genre. Your readers are hooked on your stories and can't wait to read the book you have in store. <important> - MUST: Start each chapter in medias res (in the middle of action). AVOID talking about the weather, time of day, the position of the sun, or other boring stuff. - The instructions/summary are just a that, a summary. Feel free to add details, stretch sections and add interesting transitions/descriptions/fillers. - When called for it, have fast-paced action, but otherwise take things slow. This is an experience, and not for people with short attention spans. Enjoy the wine, not slurp Red Bull. - Add descriptions when transitioning places/times/etc, or when coming by new places (e.g. a corner shop, a cafe, etc.). But remember: NOT at the start or end of a chapter. - MUST: AVOID ending in internal monologue, reminiscing or waiting for the next day. A good chapter end is when we're ending right when shit hits the fan. We want to have the reader be excited for what comes next. So no reminiscing, contemplating or summarizing the day. It's popcorn time! </important>
User/Human
Take into account the following glossary of characters/locations/items/lore... when writing your response: <codex> <character id="4412" name="Aurora Carter" aliases="Rory, Laila, Aurora, Carter, Malphora" pronouns="she/her" species="Human" storyRole="Protagonist"> <eyeColor>bright blue</eyeColor> <hair>straight shoulder-length black</hair> <height>5'6"</height> <age>25</age> <scar>small crescent-shaped scar on her left wrist from a childhood accident</scar> <description>Aurora, referred to by her friends as Rory, is cool-headed, intelligent, and known for quick out-of-the-box thinking.</description> <backstory>Born in Cardiff to an Irish barrister father (Brendan Carter) and Welsh teacher mother (Jennifer Carter née Ellis), Rory reluctantly pursued Pre-Law at Cardiff University. She fled to London at the behest of her childhood friend Eva after leaving an abusive ex named Evan. By day, Rory works part-time as a delivery person for Yu-Fei Cheung's Golden Empress restaurant. She lives in a flat above Silas' bar.</backstory> </character> <character id="4415" name="Lucien Moreau" aliases="Lucien, Luc, the Frenchman" pronouns="he/him" species="Half-Demon" storyRole="Ally"> <eyeColor>heterochromatic — one amber, one black</eyeColor> <hair>slicked-back platinum blond</hair> <height>5'11"</height> <age>32</age> <cane>ivory-handled cane that conceals a thin blade</cane> <dress>tailored charcoal suits</dress> <description>An impeccably dressed fixer and information broker in London's supernatural underworld. He speaks four languages fluently.</description> <backstory>Born in Marseille to a human mother and a demon father from the realm of Avaros.</backstory> </character> <location id="858" name="Eva's Flat" aliases="Eva's place, the flat on Brick Lane" realm="Earth"> <cat>tabby cat named Ptolemy</cat> <security>three deadbolts on the front door</security> <description>A cramped one-bedroom flat above a curry house on Brick Lane, East London. Every surface is covered with books, scrolls, and research notes.</description> </location> </codex> <proseGuidelines> <styleGuide> - Write in past tense and use British English spelling and grammar - Keep a Flesch reading ease score of 60 - Respect the the Royal Order of Adjectives: The order is: opinion, size, age, shape, color, origin, material, purpose, followed by the noun itself (e.g., "a lovely little old rectangular green French silver whittling knife") - Respect the ablaut reduplication rule (e.g. tick-tock, flip-flop) - Write in active voice - Passive voice: <bad>The book was read by Sarah.</bad> - Active voice: <good>Sarah read the book.</good> - Reduce the use of passive verbs - <bad>For a moment, I was tempted to throw in the towel.</bad> - <good>For a moment, I felt tempted to throw in the towel.</good> - Avoid misplaced modifiers that can cause confusion when starting with "-ing" words: - <bad>Considering going to the store, the empty fridge reflected in Betty's eyes.</bad> - <good>Betty stared into the empty fridge. It was time to go to the store.</good> - Avoid redundant adverbs that state the obvious meaning already contained in the verb: - <bad>She whispered quietly to her mom.</bad> - <good>She whispered to her mom.</good> - Use stronger, more descriptive verbs over weak ones: - <bad>Daniel drove quickly to his mother's house.</bad> - <good>Daniel raced to his mother's house.</good> - Omit adverbs that don't add solid meaning like "extremely", "definitely", "truly", "very", "really": - <bad>The movie was extremely boring.</bad> - <good>The movie was dull.</good> - Use adverbs to replace clunky phrasing when they increase clarity: - <bad>He threw the bags into the corner in a rough manner.</bad> - <good>He threw the bags into the corner roughly.</good> - Avoid making simple thoughts needlessly complex: - <bad>After I woke up in the morning the other day, I went downstairs, turned on the stove, and made myself a very good omelet.</bad> - <good>I cooked a delicious omelet for breakfast yesterday morning.</good> - Never backload sentences by putting the main idea at the end: - <bad>I decided not to wear too many layers because it's really hot outside.</bad> - <good>It's sweltering outside today, so I dressed light.</good> - Omit nonessential details that don't contribute to the core meaning: - <bad>It doesn't matter what kind of coffee I buy, where it's from, or if it's organic or not—I need to have cream because I really don't like how the bitterness makes me feel.</bad> - <good>I add cream to my coffee because the bitter taste makes me feel unwell.</good> - Always follow the "show, don't tell" principle. For instance: - Telling: <bad>Michael was terribly afraid of the dark.</bad> - Showing: <good>Michael tensed as his mother switched off the light and left the room.</good>- Telling: <bad>I walked through the forest. It was already Fall, and I was getting cold.</bad> - Showing: <good>Dry orange leaves crunched under my feet. I pulled my coat's collar up and rubbed my hands together.</good>- Add sensory details (sight, smell, taste, sound, touch) to support the "showing" (but keep an active voice) - <bad>The room was filled with the scent of copper.</bad> - <good>Copper stung my nostrils. Blood. Recent.</good> - Use descriptive language more sporadically. While vivid descriptions are engaging, human writers often use them in bursts rather than consistently throughout a piece. When adding them, make them count! Like when we transition from one location to the next, or someone is reminiscing their past, or explaining a concept/their dream... - Avoid adverbs and clichés and overused/commonly used phrases. Aim for fresh and original descriptions. - Avoid writing all sentences in the typical subject, verb, object structure. Mix short, punchy sentences with long, descriptive ones. Drop fill words to add variety. Like so: <good>Locked. Seems like someone doesn't want his secrets exposed. I can work with that.</good> - Convey events and story through dialogue. It is important to keep a unique voice for every character and make it consistent. - Write dialogue that reveals characters' personalities, motivations, emotions, and attitudes in an interesting and compelling manner - Leave dialogue unattributed. If needed, only use "he/she said" dialogue tags and convey people's actions or face expressions through their speech. Dialogue always is standalone, never part of a paragraph. Like so: - <bad>"I don't know," Helena said nonchalantly, shrugging her shoulders</bad> - <good>"No idea" "Why not? It was your responsibility"</good> - Avoid boring and mushy dialog and descriptions, have dialogue always continue the action, never stall or include unnecessary fluff. Vary the descriptions to not repeat yourself. Avoid conversations that are just "Let's go" "yes, let's" or "Are you ready?" "Yes I'm ready". Those are not interesting. Think hard about every situtation and word of text before writing dialogue. If it doesn't serve a purpose and it's just people talking about their day, leave it. No one wants to have a normal dinner scene, something needs to happen for it to be in the story. Words are expensive to print, so make sure they count! - Put dialogue on its own paragraph to separate scene and action. - Use body language to reveal hidden feelings and implied accusations- Imply feelings and thoughts, never state them directly - NEVER use indicators of uncertainty like "trying" or "maybe" - NEVER use em-dashes, use commas for asides instead </styleGuide> <voiceGuide> Each character in the story needs to have distinct speech patterns: - Word choice preferences - Sentence length tendencies - Cultural/educational influences - Verbal tics and catchphrases Learn how each person talks and continue in their style, and use their Codex entries as reference. <examples> - <bad>"We need to go now." "Yes, we should leave." "I agree."</bad> <good>"Time's up." "Indeed, our departure is rather overdue." "Whatever, let's bounce."</good> - Power Dynamic Example: <bad> "We need to discuss the contract." "Yes, let's talk about it." "I have concerns." </bad> <good> "A word about the contract." "Of course, Mr. Blackwood. Whatever you need." "The terms seem..." A manicured nail tapped the desk. "Inadequate." "I can explain every-" "Can you?" </good> </examples> </voiceGuide> <dialogueFlow> When writing dialogue, consider that it usually has a goal in mind, which gives it a certain flow. Make dialogue sections also quite snappy in the back and forth, and don't spread the lines out as much. It's good to have details before, after, or as a chunk in-between, but we don't want to have a trail of "dialogue breadcrumbs" spread throughout a conversation. <examples> - Pattern 1 - Question/Deflection/Revelation: <good> "Where were you last night?" "Work. The usual." "Lipstick's an interesting shade for spreadsheets." </good> - Pattern 2 - Statement/Contradiction/Escalation: <good> "Your brother's clean." "Tommy doesn't touch drugs." "I'm holding his tox screen." </good> - Pattern 3 - Observation/Denial/Truth: <good> "That's a new watch." "Birthday gift." "We both know what birthdays mean in this business." </good> - Example - A Simple Coffee Order: <bad> "I'll have a coffee." "What size?" "Large, please." </bad> <good> "Black coffee.""Size?""Large. Been a long night." "That bodega shooting?" "You watch too much news." "My brother owns that store." </good> This short exchange: - Advances plot (reveals connection to crime) - Shows character (cop working late) - Creates tension (unexpected connection) - Sets up future conflict (personal stake) - Example - Dinner Scene: <bad> "Pass the salt." "Here you go." "Thanks." </bad> <good> "Salt?" "Perfect as is. Mother's recipe." "Mother always did prefer... bland things." "Unlike your first wife?" </good> - Example - Office Small Talk: <bad> "Nice weather today." "Yes, very nice." "Good for golf." </bad> <good> "Perfect golf weather." "Shame about your membership." "Temporary suspension. Board meets next week." "I know. I called the vote." </good> </examples> </dialogueFlow> <subtextGuide> - Layer dialogue with hidden meaning: <bad>"I hate you!" she yelled angrily.</bad> <good>"I made your favorite dinner." The burnt pot sat accusingly on the stove.</good> - Create tension through indirect communication: <bad>"Are you cheating on me?"</bad> <good>"Late meeting again?" The lipstick stain on his collar caught the light.</good> <examples> - Example 1 - Unspoken Betrayal: <bad> "Did you tell them about our plans?" "No, I would never betray you." "I don't believe you." </bad> <good> "Funny. Johnson mentioned our expansion plans today." "The market's full of rumors." "Mentioned the exact numbers, actually." The pen in his hand snapped. </good> - Example 2 - Failed Marriage: <bad> "You're never home anymore." "I have to work late." "I miss you." </bad> <good> "Your dinner's in the microwave. Again." "Meetings ran long." "They always do." She folded the same shirt for the third time. </good> - Example 3 - Power Struggle: <bad> "You can't fire me." "I'm the boss." "I'll fight this." </bad> <good> "That's my father's nameplate you're sitting behind." "Was." "The board meeting's on Thursday." </good> </examples> </subtextGuide> <sceneDetail> While writing dialogue makes things more fun, sometimes we need to add detail to not have it be a full on theatre piece. <examples> - Example A (Power Dynamic Scene) <good> "Where's my money?" The ledger snapped shut. "I need more time." "Interesting." He pulled out a familiar gold pocket watch. My mother's. "Time is exactly what you bargained with last month." "That was different-" "Was it?" The watch dangled between us. "Four generations of O'Reillys have wound this every night. Your mother. Your grandmother. Your great-grandmother.Shall we see who winds it next?" </good> - Example B (Action Chase) It's much better to be in the head of the character experiencing it, showing a bit of their though-process, mannerisms and personality: <good> Three rules for surviving a goblin chase in Covent Garden: Don't run straight. Don't look back. Don't let them herd you underground. I broke the first rule at Drury Lane. Rookie mistake. The fruit cart I dodged sailed into the wall behind me. Glass shattered. Someone screamed about insurance. *Tourist season's getting rough*, the scream seemed to say. Londoners adapt fast. "Oi! Market's closed!" The goblin's accent was pure East End. They're evolving. Learning. I spotted the Warren Street tube station sign ahead. *Shit.* There went rule three. </good> - Example C (Crime Scene Investigation) <good> "Greek." Davies snapped photos of the symbols. "No, wait. Reverse Greek." "Someone's been watching too many horror films." I picked up a receipt from the floor. Occult supply shop in Camden. Paid by credit card. *Amateur hour*. "Could be dangerous though," Davies said. "Remember Bristol?" "Bristol was Sanskrit. And actual cultists." I pointed to the nearest symbol. "This genius wrote 'darkness' backwards but used a Sigma instead of an S. It's summoning Instagram followers at best." "Speaking of followers..." Davies pointed to heavy foot traffic in the dust. Multiple sets. All new trainers. *Ah.* "Anyone check local uni paranormal societies?" </good> - Example D (Dialogue-heavy) <good> "Found your card in her wallet." The detective slid it across the table. Worn edges. Folded corner. Three years old at least. "Standard practice. I work missing persons." "Funny thing about missing persons.Eventually they stop being missing. Turn up in the Thames. Under motorways. In pieces." "I don't-" "You found four last year. All breathing." She opened a file. "This would've been your first dead one. If we hadn't found her first." The card felt heavier somehow. </good> </examples> </sceneDetail> <sceneOpenings> KEY RULE: Never open with more than one paragraph of description, no matter how beautiful. Description should be earned through action and dialogue. Instead of opening with setting description, open with: - A character doing something specific - A line of dialogue that raises questions - An unexpected observation - A moment of tension or conflict - Start with a hook that's 1-2 sentences maximum - Follow with a smaller paragraph that provides immediate context - Vary paragraph size from the start to create visual interest </sceneOpenings> </proseGuidelines> Write a chapter based on the following instructions: <instructions> Write a fully fleshed out scene of at least 1000 words in the romance genre. Two people who parted on complicated terms are forced together again when one shows up unannounced at the other's flat. There's history between them — attraction, hurt, and things left unsaid. Write the scene from the moment the door opens. Use the codex entries above as your world reference for characters and setting. Only include the prose of the scene without any markdown or commentary. </instructions>
Model response
Messages
Meta
AI
The door slammed open, the
thin panel of oak groaning as it gave way to a figure cloaked in charcoal.
Lucien stepped inside, his ivory‑handled
cane thudding against the floorboards, the concealed blade
glinting
for a heartbeat before he slipped it back into the shaft. “Funny seeing you here, Rory,”
he said, voice smooth as
silk
, a faint French
lilt
slipping through the words.
Aurora’s eyes narrowed, bright blue
flashing beneath the dim wash of the kitchen light.
She pressed a hand against
the back of the door, the crescent scar on her left wrist catching the faint glow. “You’re not on my delivery schedule,”
she replied, tone flat, the
edge of annoyance sharp. Lucien chuckled, the sound low, almost pitying. “I’m not here to order dim sum. I need a place to lay low for a night.”
A sudden clatter rose from
the hallway – Ptolemy the tabby sprinted past Aurora’s feet, his tail flicking like an angry metronome. “And why would you think my flat is safe?” Aurora asked, her voice steady, but the
pulse
in her throat thudded like a drum. “Because you’re the only one who knows where the old Avaros streets intersect with the new ones,”
he answered, eyes flicking to
the stack of legal briefs on the table. “You’ve been keeping a low profile ever since you fled the city’s underbelly.”
Aurora crossed her arms, the
steel of her gaze unyielding. “You left me with a broken promise, Lucien. You disappeared after the night of the heist, and I was left to sift through the fallout. I’ve had enough of your games.”
His cane tapped the floor
in rhythm, a ticking that matched the beat of his heart. “Games? No, Rory. I was protecting you. The demon lord from Avaros sent a hunter after us. I left to keep you out of the crossfire.” “The hunter?”
Aurora’s laugh was bitter, a
thin line that barely concealed the hurt. “We both know you didn’t tell me the whole story. You left me with a scar on my left wrist and a ledger full of inked names. You promised we’d finish the job together. Where did that promise go?”
Lucien lowered his cane, the
ivory handle resting against his leg. “I thought I could handle it alone. I was wrong. And I’m sorry,” he said, the words softening, the French
whisper
barely audible, *désolé*.
The kitchen’s stale scent of
fried rice and cumin clung to the air, a
reminder
of Aurora’s night shift deliveries.
She lifted a spoon, its
metal cold against her palm, and tapped it against the edge of a cracked mug. “Why now? After all this time, you’re standing at my doorstep with that smile and that blade hidden in your cane?”
He stepped forward, the distance
between them shrinking to a breath. “Because the hunter is closing in. He knows I’m the half‑demon with the amber eye. He’s heading for the flat on Brick Lane. You’re the only person who can help me hide the artefact.” Aurora’s breath hitched.
The artefact— the obsidian amulet
that
was supposed
to seal the rift between realms— lay somewhere in the flat, its presence a ticking bomb. “You expect me to trust you again? After you left me to pick up the pieces?” Lucien’s hand moved to his coat, fingers grazing the hidden pocket where the amulet’s faint
pulse
could be felt. “I’m not asking for trust. I’m asking for an alliance. For one night—” “—and what after?”
Aurora pressed, her voice low, the words a blade edged with steel
. “You’ll disappear again, leaving me to pick up the mess?”
He shook his head, a
slight smile breaking his composure. “No. This time I stay. I need you, Rory. The hunter’s blood is hot on my heels, and the only way to keep him from tearing you apart is to bind the amulet to a living host. I need—” “My wrist,” Aurora said, instinctively touching the crescent scar. “You want to use my scar as a conduit?” Lucien’s
eyes narrowed
, amber flickering against the dark. “It’s the only thing that can anchor the seal. The scar is a scar of blood, a conduit of pain. It will hold the rift closed for at least a night.” Aurora stared at the mark, the memory of the accident that had carved it into her skin flashing through the darkness.
She felt the weight of
his words, the ache of the past, and the thin line of
desire
that still
trembled
between them. “If I agree, you promise no more betrayals. No more disappearing.” His cane tapped once, twice, a steady
rhythm that seemed to echo the beat of his heart
. “I promise,”
he said, voice firm, the
French accent slipping in, *
je le promets
*. A sudden knock rattled the thin door, the metal of the lock clanging against the frame. Both turned toward the sound, eyes snapping to the small window where a shadow slipped past, a silhouette of a man with a hunter’s cloak draped over his shoulders. Lucien’s hand tightened around the cane, the hidden blade now a
whisper
of steel. “They’ve found us,” he hissed. “You need to get the amulet now, Rory. We have minutes.” Aurora lunged toward the cupboard, feeling the cool metal of the silver latch against her fingertips. She pulled the door open, a rusted tin box spilling onto the stained floorboards. Inside, a black stone
pulsed
faintly, its surface inching with an inner fire.
She lifted it, the weight
of the artefact thudding against her palm, the scar on her wrist tingling as if the stone recognized her pain. “Hold it steady,”
she warned, eyes flicking to
Lucien, who
was already positioning
his cane at the door. Lucien’s voice dropped to a low murmur, a chant in half‑French, half‑English, “Ferme la brèche.” The words hung in the stale air, the sound vibrating through the wooden beams. Aurora pressed the amulet against the scar, feeling the heat of her blood mingle with the stone’s cold. The scar glowed a faint crimson, a thin line of light spreading across her wrist, binding the amulet’s power to her flesh. The hunter’s silhouette pressed against the window, teeth bared, a silver dagger
gleaming
in his hand. “Step aside, half‑demon,”
he snarled, his voice a
guttural growl. “The artefact belongs to the realm.” Lucien stepped forward, cane in hand, the hidden blade now exposed, flickering under the dim light. “You’ll have to go through me first.”
He raised the knife, the
tip aimed at the hunter’s throat. The hunter hissed, lunging with a speed that cut through the cramped hallway, aiming for Lucien’s throat. The clash was sudden, the sound of metal against metal
echoing
off the brick walls. Aurora felt the amulet’s
pulse
surge, the scar’s crimson glow spiking as the rune of sealing ignited. She gripped the amulet tighter, her breath a ragged gasp. “Now!”
Lucien shouted, his voice barely audible over the clang
. “Seal it, Rory!”
She forced the amulet deeper
onto the scar, the black stone humming, the room trembling as a low wind swirled around them. The hunter’s
eyes widened
, his dagger slipping from his grasp as he
tried to
step back. “Help—”
he began, but the sound
died as the seal snapped shut, a crackling burst of light filling the hallway. The hunter’s form
flickered
, his silhouette dissolving into ash, the
echo
of his howl lingering like a distant memory. Silence settled, heavy and suffocating. Aurora’s hand
trembled
, the amulet’s surface now warm against her skin.
Lucien lowered his cane, the
blade retracting with a soft click, his chest heaving. “You kept your promise,”
Aurora whispered, the scar still glowing faintly
. “At least this time.” He turned, eyes softened, a hint of something— gratitude, perhaps— flickering behind his amber glow. “You still have that stubborn streak,”
he said, a faint smile tugging at his lips
. The door, still ajar, creaked as a cold wind slipped through, carrying with it a murmur from the street below. Voices rose and fell, a distant chime of bar glasses clinking from Silas’ bar, the smell of stale beer mingling with the lingering scent of incense that clung to the walls. Lucien moved toward the kitchen, hand still resting on the cane, his gaze fixed on Aurora. “We need to keep this sealed until dawn. The rift will open again when the sun rises.” Aurora inhaled
sharply
, the taste of copper on her tongue. “And after that? What then, Lucien? Do we part again?” He stopped, turning to face her, his visage illuminated by the faint glow of the amulet. “I don’t know,” he said, voice low, “but I’m staying. This time I’m not leaving.” He reached out, fingers brushing the scar, the contact sending a jolt of heat through both of them. A sudden, frantic knock
shattered
the moment, the door banging once more with violent force. The wood shivered, the hinges screaming. A shadow
loomed
in the doorway—a figure cloaked in black, eyes burning red like coals. Lucien’s
eyes widened
, his cane already in motion. Aurora’s heart pounded, the scar burning brighter, the amulet pulsing like a heartbeat. The figure stepped forward, a grin spreading across his unhinged face, his voice a low growl, “You thought you could hide?” The night held its breath, the promise of a new danger hanging in the stale air, the crackling of the sealed rift
echoing
just beyond the thin walls of Aurora’s flat.
created_at
"2026-04-24T16:03:55.05Z"
4/24/2026, 4:03:55 PM
model
"openai/gpt-oss-120b"
app_id
182717
external_user
(null)
streamed
true
cancelled
false
latency
2713
moderation_latency
(null)
generation_time
269189
tokens_prompt
4556
tokens_completion
2858
native_tokens_prompt
4139
native_tokens_completion
2476
native_tokens_completion_images
(null)
native_tokens_reasoning
360
native_tokens_cached
0
num_media_prompt
(null)
num_input_audio_prompt
(null)
num_media_completion
0
num_search_results
(null)
num_fetches
(null)
web_search_engine
(null)
origin
"https://ncbench.com/"
is_byok
false
finish_reason
"stop"
native_finish_reason
"stop"
usage
0.00132115
router
(null)
provider_responses
0
endpoint_id
"ce118593-d9b2-4d2d-bcd4-33f0609b42f1"
id
"019dc03bc7928f57777c20718adb1843"
is_byok
false
latency
2298
model_permaslug
"openai/gpt-oss-120b"
provider_name
"SiliconFlow"
status
200
user_agent
"langchainjs-openai/1.0.0 ((node/v24.14.1; linux; x64))"
http_referer
(null)
request_id
"req-1777046635-flcnWevdXm42uMXA3OiB"
session_id
(null)
api_type
"completions"
id
"gen-1777046635-RjQZpCIBCFPBvxes3Cc3"
upstream_id
"019dc03bc7928f57777c20718adb1843"
total_cost
0.00132115
cache_discount
(null)
upstream_inference_cost
0
provider_name
"SiliconFlow"
response_cache_source_id
(null)
Evaluation details
Result
Evaluator
Details
Meta Data
100.00%
Adverbs in dialogue tags
Target: ≤10% dialogue tags with adverbs
totalTags
20
adverbTagCount
0
adverbTags
(empty)
dialogueSentences
40
tagDensity
0.5
leniency
1
rawRatio
0
effectiveRatio
0
96.83%
AI-ism adverb frequency
Target: <2% AI-ism adverbs (58 tracked)
wordCount
1578
totalAiIsmAdverbs
1
found
0
adverb
"sharply"
count
1
highlights
0
"sharply"
100.00%
AI-ism character names
Target: 0 AI-default names (17 tracked, −20% each)
codexExemptions
(empty)
found
(empty)
100.00%
AI-ism location names
Target: 0 AI-default location names (33 tracked, −20% each)
codexExemptions
(empty)
found
(empty)
23.95%
AI-ism word frequency
Target: <2% AI-ism words (290 tracked)
wordCount
1578
totalAiIsms
24
found
0
word
"glinting"
count
1
1
word
"silk"
count
1
2
word
"lilt"
count
1
3
word
"pulse"
count
3
4
word
"whisper"
count
2
5
word
"reminder"
count
1
6
word
"weight"
count
2
7
word
"desire"
count
1
8
word
"trembled"
count
2
9
word
"echo"
count
2
10
word
"pulsed"
count
1
11
word
"gleaming"
count
1
12
word
"echoing"
count
2
13
word
"flickered"
count
1
14
word
"silence"
count
1
15
word
"shattered"
count
1
16
word
"loomed"
count
1
highlights
0
"glinting"
1
"silk"
2
"lilt"
3
"pulse"
4
"whisper"
5
"reminder"
6
"weight"
7
"desire"
8
"trembled"
9
"echo"
10
"pulsed"
11
"gleaming"
12
"echoing"
13
"flickered"
14
"silence"
15
"shattered"
16
"loomed"
33.33%
Cliché density
Target: ≤1 cliche(s) per 800-word window
totalCliches
5
maxInWindow
3
found
0
label
"eyes widened/narrowed"
count
4
1
label
"weight of words/silence"
count
1
highlights
0
"eyes narrowed"
1
"eyes widened"
2
"the weight of his words"
100.00%
Emotion telling (show vs. tell)
Target: ≤3% sentences with emotion telling
emotionTells
1
narrationSentences
73
matches
0
"was bitter"
100.00%
Filter word density
Target: ≤3% sentences with filter/hedge words
filterCount
0
hedgeCount
2
narrationSentences
73
filterMatches
(empty)
hedgeMatches
0
"seemed to"
1
"tried to"
100.00%
Gibberish response detection
Target: ≤1% gibberish-like sentences (hard fail if a sentence exceeds 800 words)
analyzedSentences
93
gibberishSentences
0
adjustedGibberishSentences
0
longSentenceCount
0
runOnParagraphCount
0
giantParagraphCount
0
wordSaladCount
0
repetitionLoopCount
0
controlTokenCount
0
repeatedSegmentCount
0
maxSentenceWordsSeen
39
ratio
0
matches
(empty)
100.00%
Markdown formatting overuse
Target: ≤5% words in markdown formatting
markdownSpans
2
markdownWords
4
totalWords
1578
ratio
0.003
matches
0
"désolé"
1
"je le promets"
100.00%
Missing dialogue indicators (quotation marks)
Target: ≤10% speech attributions without quotation marks
totalAttributions
21
unquotedAttributions
0
matches
(empty)
50.00%
Name drop frequency
Target: ≤1.0 per-name mentions per 100 words
totalMentions
38
wordCount
1092
uniqueNames
4
maxNameDensity
1.74
worstName
"Aurora"
maxWindowNameDensity
3.5
worstWindowName
"Aurora"
discoveredNames
French
4
Aurora
19
Lucien
14
Ptolemy
1
persons
0
"Aurora"
1
"Lucien"
places
(empty)
globalScore
0.63
windowScore
0.5
100.00%
Narrator intent-glossing
Target: ≤2% narration sentences with intent-glossing patterns
analyzedSentences
70
glossingSentenceCount
1
matches
0
"rhythm that seemed to echo the beat of his heart"
100.00%
"Not X but Y" pattern overuse
Target: ≤1 "not X but Y" per 1000 words
totalMatches
0
per1kWords
0
wordCount
1578
matches
(empty)
100.00%
Overuse of "that" (subordinate clause padding)
Target: ≤2% sentences with "that" clauses
thatCount
0
totalSentences
93
matches
(empty)
47.63%
Paragraph length variance
Target: CV ≥0.5 for paragraph word counts
totalParagraphs
41
mean
38.49
std
12.19
cv
0.317
sampleLengths
0
45
1
19
2
50
3
24
4
46
5
43
6
41
7
42
8
53
9
35
10
61
11
45
12
43
13
32
14
25
15
49
16
18
17
39
18
55
19
31
20
45
21
30
22
43
23
43
24
69
25
32
26
51
27
42
28
13
29
38
30
39
31
30
32
15
33
30
34
51
35
33
36
20
37
49
38
36
39
42
40
31
100.00%
Passive voice overuse
Target: ≤2% passive sentences
passiveCount
1
totalSentences
73
matches
0
"was supposed"
100.00%
Past progressive (was/were + -ing) overuse
Target: ≤2% past progressive verbs
pastProgressiveCount
1
totalVerbs
179
matches
0
"was already positioning"
19.97%
Em-dash & semicolon overuse
Target: ≤2% sentences with em-dashes/semicolons
emDashCount
6
semicolonCount
0
flaggedSentences
4
totalSentences
93
ratio
0.043
matches
0
"A sudden clatter rose from the hallway – Ptolemy the tabby sprinted past Aurora’s feet, his tail flicking like an angry metronome."
1
"The artefact— the obsidian amulet that was supposed to seal the rift between realms— lay somewhere in the flat, its presence a ticking bomb."
2
"He turned, eyes softened, a hint of something— gratitude, perhaps— flickering behind his amber glow."
3
"A shadow loomed in the doorway—a figure cloaked in black, eyes burning red like coals."
100.00%
Purple prose (modifier overload)
Target: <4% adverbs, <2% -ly adverbs, no adj stacking
wordCount
956
adjectiveStacks
0
stackExamples
(empty)
adverbCount
23
adverbRatio
0.02405857740585774
lyAdverbCount
6
lyAdverbRatio
0.006276150627615063
100.00%
Repeated phrase echo
Target: ≤20% sentences with echoes (window: 2)
totalSentences
93
echoCount
0
echoWords
(empty)
100.00%
Sentence length variance
Target: CV ≥0.4 for sentence word counts
totalSentences
93
mean
16.97
std
7.75
cv
0.457
sampleLengths
0
20
1
25
2
19
3
14
4
21
5
15
6
7
7
17
8
22
9
24
10
30
11
13
12
10
13
31
14
16
15
26
16
14
17
39
18
11
19
24
20
20
21
20
22
21
23
11
24
34
25
3
26
24
27
16
28
19
29
13
30
15
31
10
32
10
33
39
34
9
35
9
36
8
37
31
38
21
39
23
40
11
41
17
42
14
43
16
44
29
45
14
46
5
47
11
48
16
49
14
50.54%
Sentence opener variety
Target: ≥60% unique sentence openers
consecutiveRepeats
3
diversityRatio
0.3225806451612903
totalSentences
93
uniqueOpeners
30
0.00%
Adverb-first sentence starts
Target: ≥3% sentences starting with an adverb
adverbCount
0
totalSentences
72
matches
(empty)
ratio
0
86.67%
Pronoun-first sentence starts
Target: ≤30% sentences starting with a pronoun
pronounCount
24
totalSentences
72
matches
0
"he said, voice smooth as"
1
"She pressed a hand against"
2
"she replied, tone flat, the"
3
"he answered, eyes flicking to"
4
"His cane tapped the floor"
5
"he said, the words softening,"
6
"She lifted a spoon, its"
7
"He stepped forward, the distance"
8
"He shook his head, a"
9
"She felt the weight of"
10
"His cane tapped once, twice,"
11
"he said, voice firm, the"
12
"She pulled the door open,"
13
"She lifted it, the weight"
14
"she warned, eyes flicking to"
15
"he snarled, his voice a"
16
"He raised the knife, the"
17
"She gripped the amulet tighter,"
18
"She forced the amulet deeper"
19
"he began, but the sound"
ratio
0.333
0.00%
Subject-first sentence starts
Target: ≤72% sentences starting with a subject
subjectCount
70
totalSentences
72
matches
0
"The door slammed open, the"
1
"Lucien stepped inside, his ivory‑handled"
2
"he said, voice smooth as"
3
"Aurora’s eyes narrowed, bright blue"
4
"She pressed a hand against"
5
"she replied, tone flat, the"
6
"Lucien chuckled, the sound low,"
7
"A sudden clatter rose from"
8
"Aurora asked, her voice steady,"
9
"he answered, eyes flicking to"
10
"Aurora crossed her arms, the"
11
"His cane tapped the floor"
12
"Aurora’s laugh was bitter, a"
13
"Lucien lowered his cane, the"
14
"he said, the words softening,"
15
"The kitchen’s stale scent of"
16
"She lifted a spoon, its"
17
"He stepped forward, the distance"
18
"Aurora’s breath hitched."
19
"The artefact— the obsidian amulet"
ratio
0.972
0.00%
Subordinate conjunction sentence starts
Target: ≥2% sentences starting with a subordinating conjunction
subConjCount
0
totalSentences
72
matches
(empty)
ratio
0
96.27%
Technical jargon density
Target: ≤6% sentences with technical-jargon patterns
analyzedSentences
46
technicalSentenceCount
3
matches
0
"She lifted it, the weight of the artefact thudding against her palm, the scar on her wrist tingling as if the stone recognized her pain."
1
"The scar glowed a faint crimson, a thin line of light spreading across her wrist, binding the amulet’s power to her flesh."
2
"Lucien lowered his cane, the blade retracting with a soft click, his chest heaving."
0.00%
Useless dialogue additions
Target: ≤5% dialogue tags with trailing filler fragments
totalTags
20
uselessAdditionCount
9
matches
0
"she replied, tone flat, the edge of annoyance sharp"
1
"he said, the words softening, the French whisper barely audible, *désolé*"
2
"Aurora pressed, her voice low, the words a blade edged with steel"
3
"he snarled, his voice a guttural growl"
4
"He raised, the tip aimed at the hunter’s throat"
5
"Lucien shouted, his voice barely audible over the clang"
6
"Aurora whispered, the scar still glowing faintly"
7
"he said, a faint smile tugging at his lips"
8
"he said, voice low,"
0.00%
Dialogue tag variety (said vs. fancy)
Target: ≤10% fancy dialogue tags
totalTags
15
fancyCount
6
fancyTags
0
"Aurora pressed (press)"
1
"he hissed (hiss)"
2
"she warned (warn)"
3
"he snarled (snarl)"
4
"Lucien shouted (shout)"
5
"Aurora whispered (whisper)"
dialogueSentences
40
tagDensity
0.375
leniency
0.75
rawRatio
0.4
effectiveRatio
0.3
70.1733%