@wentorai/research-plugins 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +204 -0
- package/curated/analysis/README.md +64 -0
- package/curated/domains/README.md +104 -0
- package/curated/literature/README.md +53 -0
- package/curated/research/README.md +62 -0
- package/curated/tools/README.md +87 -0
- package/curated/writing/README.md +61 -0
- package/index.ts +39 -0
- package/mcp-configs/academic-db/ChatSpatial.json +17 -0
- package/mcp-configs/academic-db/academia-mcp.json +17 -0
- package/mcp-configs/academic-db/academic-paper-explorer.json +17 -0
- package/mcp-configs/academic-db/academic-search-mcp-server.json +17 -0
- package/mcp-configs/academic-db/agentinterviews-mcp.json +17 -0
- package/mcp-configs/academic-db/all-in-mcp.json +17 -0
- package/mcp-configs/academic-db/apple-health-mcp.json +17 -0
- package/mcp-configs/academic-db/arxiv-latex-mcp.json +17 -0
- package/mcp-configs/academic-db/arxiv-mcp-server.json +17 -0
- package/mcp-configs/academic-db/bgpt-mcp.json +17 -0
- package/mcp-configs/academic-db/biomcp.json +17 -0
- package/mcp-configs/academic-db/biothings-mcp.json +17 -0
- package/mcp-configs/academic-db/catalysishub-mcp-server.json +17 -0
- package/mcp-configs/academic-db/clinicaltrialsgov-mcp-server.json +17 -0
- package/mcp-configs/academic-db/deep-research-mcp.json +17 -0
- package/mcp-configs/academic-db/dicom-mcp.json +17 -0
- package/mcp-configs/academic-db/enrichr-mcp-server.json +17 -0
- package/mcp-configs/academic-db/fec-mcp-server.json +17 -0
- package/mcp-configs/academic-db/fhir-mcp-server-themomentum.json +17 -0
- package/mcp-configs/academic-db/fhir-mcp.json +19 -0
- package/mcp-configs/academic-db/gget-mcp.json +17 -0
- package/mcp-configs/academic-db/google-researcher-mcp.json +17 -0
- package/mcp-configs/academic-db/idea-reality-mcp.json +17 -0
- package/mcp-configs/academic-db/legiscan-mcp.json +19 -0
- package/mcp-configs/academic-db/lex.json +17 -0
- package/mcp-configs/ai-platform/Adaptive-Graph-of-Thoughts-MCP-server.json +17 -0
- package/mcp-configs/ai-platform/ai-counsel.json +17 -0
- package/mcp-configs/ai-platform/atlas-mcp-server.json +17 -0
- package/mcp-configs/ai-platform/counsel-mcp.json +17 -0
- package/mcp-configs/ai-platform/cross-llm-mcp.json +17 -0
- package/mcp-configs/ai-platform/gptr-mcp.json +17 -0
- package/mcp-configs/browser/decipher-research-agent.json +17 -0
- package/mcp-configs/browser/deep-research.json +17 -0
- package/mcp-configs/browser/everything-claude-code.json +17 -0
- package/mcp-configs/browser/gpt-researcher.json +17 -0
- package/mcp-configs/browser/heurist-agent-framework.json +17 -0
- package/mcp-configs/data-platform/4everland-hosting-mcp.json +17 -0
- package/mcp-configs/data-platform/context-keeper.json +17 -0
- package/mcp-configs/data-platform/context7.json +19 -0
- package/mcp-configs/data-platform/contextstream-mcp.json +17 -0
- package/mcp-configs/data-platform/email-mcp.json +17 -0
- package/mcp-configs/note-knowledge/ApeRAG.json +17 -0
- package/mcp-configs/note-knowledge/In-Memoria.json +17 -0
- package/mcp-configs/note-knowledge/agent-memory.json +17 -0
- package/mcp-configs/note-knowledge/aimemo.json +17 -0
- package/mcp-configs/note-knowledge/biel-mcp.json +19 -0
- package/mcp-configs/note-knowledge/cognee.json +17 -0
- package/mcp-configs/note-knowledge/context-awesome.json +17 -0
- package/mcp-configs/note-knowledge/context-mcp.json +17 -0
- package/mcp-configs/note-knowledge/conversation-handoff-mcp.json +17 -0
- package/mcp-configs/note-knowledge/cortex.json +17 -0
- package/mcp-configs/note-knowledge/devrag.json +17 -0
- package/mcp-configs/note-knowledge/easy-obsidian-mcp.json +17 -0
- package/mcp-configs/note-knowledge/engram.json +17 -0
- package/mcp-configs/note-knowledge/gnosis-mcp.json +17 -0
- package/mcp-configs/note-knowledge/graphlit-mcp-server.json +19 -0
- package/mcp-configs/reference-mgr/arxiv-cli.json +17 -0
- package/mcp-configs/reference-mgr/arxiv-search-mcp.json +17 -0
- package/mcp-configs/reference-mgr/chiken.json +17 -0
- package/mcp-configs/reference-mgr/claude-scholar.json +17 -0
- package/mcp-configs/reference-mgr/devonthink-mcp.json +17 -0
- package/mcp-configs/registry.json +447 -0
- package/openclaw.plugin.json +21 -0
- package/package.json +61 -0
- package/skills/analysis/dataviz/color-accessibility-guide/SKILL.md +230 -0
- package/skills/analysis/dataviz/geospatial-viz-guide/SKILL.md +218 -0
- package/skills/analysis/dataviz/interactive-viz-guide/SKILL.md +287 -0
- package/skills/analysis/dataviz/network-visualization-guide/SKILL.md +195 -0
- package/skills/analysis/dataviz/publication-figures-guide/SKILL.md +238 -0
- package/skills/analysis/dataviz/python-dataviz-guide/SKILL.md +195 -0
- package/skills/analysis/econometrics/causal-inference-guide/SKILL.md +197 -0
- package/skills/analysis/econometrics/iv-regression-guide/SKILL.md +198 -0
- package/skills/analysis/econometrics/panel-data-guide/SKILL.md +274 -0
- package/skills/analysis/econometrics/robustness-checks/SKILL.md +250 -0
- package/skills/analysis/econometrics/stata-regression/SKILL.md +117 -0
- package/skills/analysis/econometrics/time-series-guide/SKILL.md +235 -0
- package/skills/analysis/statistics/bayesian-statistics-guide/SKILL.md +221 -0
- package/skills/analysis/statistics/hypothesis-testing-guide/SKILL.md +210 -0
- package/skills/analysis/statistics/meta-analysis-guide/SKILL.md +206 -0
- package/skills/analysis/statistics/nonparametric-tests-guide/SKILL.md +221 -0
- package/skills/analysis/statistics/power-analysis-guide/SKILL.md +240 -0
- package/skills/analysis/statistics/sem-guide/SKILL.md +231 -0
- package/skills/analysis/statistics/survival-analysis-guide/SKILL.md +195 -0
- package/skills/analysis/wrangling/missing-data-handling/SKILL.md +224 -0
- package/skills/analysis/wrangling/pandas-data-wrangling/SKILL.md +242 -0
- package/skills/analysis/wrangling/questionnaire-design-guide/SKILL.md +234 -0
- package/skills/analysis/wrangling/text-mining-guide/SKILL.md +225 -0
- package/skills/domains/ai-ml/computer-vision-guide/SKILL.md +213 -0
- package/skills/domains/ai-ml/deep-learning-papers-guide/SKILL.md +200 -0
- package/skills/domains/ai-ml/llm-evaluation-guide/SKILL.md +194 -0
- package/skills/domains/ai-ml/prompt-engineering-research/SKILL.md +233 -0
- package/skills/domains/ai-ml/reinforcement-learning-guide/SKILL.md +254 -0
- package/skills/domains/ai-ml/transformer-architecture-guide/SKILL.md +233 -0
- package/skills/domains/biomedical/clinical-research-guide/SKILL.md +232 -0
- package/skills/domains/biomedical/clinicaltrials-api/SKILL.md +177 -0
- package/skills/domains/biomedical/epidemiology-guide/SKILL.md +200 -0
- package/skills/domains/biomedical/genomics-analysis-guide/SKILL.md +270 -0
- package/skills/domains/business/market-analysis-guide/SKILL.md +112 -0
- package/skills/domains/business/strategic-management-guide/SKILL.md +154 -0
- package/skills/domains/chemistry/computational-chemistry-guide/SKILL.md +266 -0
- package/skills/domains/chemistry/retrosynthesis-guide/SKILL.md +215 -0
- package/skills/domains/cs/algorithms-complexity-guide/SKILL.md +194 -0
- package/skills/domains/cs/dblp-api/SKILL.md +129 -0
- package/skills/domains/cs/software-engineering-research/SKILL.md +218 -0
- package/skills/domains/ecology/biodiversity-data-guide/SKILL.md +296 -0
- package/skills/domains/ecology/conservation-biology-guide/SKILL.md +198 -0
- package/skills/domains/ecology/gbif-api/SKILL.md +158 -0
- package/skills/domains/ecology/inaturalist-api/SKILL.md +173 -0
- package/skills/domains/economics/behavioral-economics-guide/SKILL.md +239 -0
- package/skills/domains/economics/development-economics-guide/SKILL.md +181 -0
- package/skills/domains/economics/fred-api/SKILL.md +189 -0
- package/skills/domains/education/curriculum-design-guide/SKILL.md +144 -0
- package/skills/domains/education/learning-science-guide/SKILL.md +150 -0
- package/skills/domains/finance/financial-data-analysis/SKILL.md +152 -0
- package/skills/domains/finance/quantitative-finance-guide/SKILL.md +151 -0
- package/skills/domains/geoscience/climate-science-guide/SKILL.md +158 -0
- package/skills/domains/geoscience/gis-remote-sensing-guide/SKILL.md +129 -0
- package/skills/domains/humanities/digital-humanities-guide/SKILL.md +181 -0
- package/skills/domains/humanities/philosophy-research-guide/SKILL.md +148 -0
- package/skills/domains/law/courtlistener-api/SKILL.md +213 -0
- package/skills/domains/law/legal-research-guide/SKILL.md +250 -0
- package/skills/domains/math/linear-algebra-applications/SKILL.md +227 -0
- package/skills/domains/math/numerical-methods-guide/SKILL.md +236 -0
- package/skills/domains/math/oeis-api/SKILL.md +158 -0
- package/skills/domains/pharma/clinical-pharmacology-guide/SKILL.md +165 -0
- package/skills/domains/pharma/drug-development-guide/SKILL.md +177 -0
- package/skills/domains/physics/computational-physics-guide/SKILL.md +300 -0
- package/skills/domains/physics/nasa-ads-api/SKILL.md +150 -0
- package/skills/domains/physics/quantum-computing-guide/SKILL.md +234 -0
- package/skills/domains/social-science/social-research-methods/SKILL.md +194 -0
- package/skills/domains/social-science/survey-research-guide/SKILL.md +182 -0
- package/skills/literature/discovery/citation-alert-guide/SKILL.md +154 -0
- package/skills/literature/discovery/conference-proceedings-guide/SKILL.md +142 -0
- package/skills/literature/discovery/literature-mapping-guide/SKILL.md +175 -0
- package/skills/literature/discovery/paper-tracking-guide/SKILL.md +211 -0
- package/skills/literature/discovery/rss-paper-feeds/SKILL.md +214 -0
- package/skills/literature/discovery/semantic-scholar-recs-guide/SKILL.md +164 -0
- package/skills/literature/fulltext/doaj-api/SKILL.md +120 -0
- package/skills/literature/fulltext/interlibrary-loan-guide/SKILL.md +163 -0
- package/skills/literature/fulltext/open-access-guide/SKILL.md +183 -0
- package/skills/literature/fulltext/pmc-oai-api/SKILL.md +184 -0
- package/skills/literature/fulltext/preprint-servers-guide/SKILL.md +128 -0
- package/skills/literature/fulltext/repository-harvesting-guide/SKILL.md +207 -0
- package/skills/literature/fulltext/unpaywall-api/SKILL.md +113 -0
- package/skills/literature/metadata/altmetrics-guide/SKILL.md +132 -0
- package/skills/literature/metadata/citation-network-guide/SKILL.md +236 -0
- package/skills/literature/metadata/crossref-api/SKILL.md +133 -0
- package/skills/literature/metadata/datacite-api/SKILL.md +126 -0
- package/skills/literature/metadata/doi-resolution-guide/SKILL.md +168 -0
- package/skills/literature/metadata/h-index-guide/SKILL.md +183 -0
- package/skills/literature/metadata/journal-metrics-guide/SKILL.md +188 -0
- package/skills/literature/metadata/opencitations-api/SKILL.md +128 -0
- package/skills/literature/metadata/orcid-api/SKILL.md +136 -0
- package/skills/literature/metadata/orcid-integration-guide/SKILL.md +178 -0
- package/skills/literature/search/arxiv-api/SKILL.md +95 -0
- package/skills/literature/search/biorxiv-api/SKILL.md +123 -0
- package/skills/literature/search/boolean-search-guide/SKILL.md +199 -0
- package/skills/literature/search/citation-chaining-guide/SKILL.md +148 -0
- package/skills/literature/search/database-comparison-guide/SKILL.md +100 -0
- package/skills/literature/search/europe-pmc-api/SKILL.md +120 -0
- package/skills/literature/search/google-scholar-guide/SKILL.md +182 -0
- package/skills/literature/search/mesh-terms-guide/SKILL.md +164 -0
- package/skills/literature/search/openalex-api/SKILL.md +134 -0
- package/skills/literature/search/pubmed-api/SKILL.md +130 -0
- package/skills/literature/search/scientify-literature-survey/SKILL.md +203 -0
- package/skills/literature/search/semantic-scholar-api/SKILL.md +134 -0
- package/skills/literature/search/systematic-search-strategy/SKILL.md +214 -0
- package/skills/research/automation/ai-scientist-guide/SKILL.md +228 -0
- package/skills/research/automation/data-collection-automation/SKILL.md +248 -0
- package/skills/research/automation/research-workflow-automation/SKILL.md +266 -0
- package/skills/research/deep-research/meta-synthesis-guide/SKILL.md +174 -0
- package/skills/research/deep-research/research-cog/SKILL.md +153 -0
- package/skills/research/deep-research/scoping-review-guide/SKILL.md +217 -0
- package/skills/research/deep-research/systematic-review-guide/SKILL.md +250 -0
- package/skills/research/funding/figshare-api/SKILL.md +163 -0
- package/skills/research/funding/grant-writing-guide/SKILL.md +233 -0
- package/skills/research/funding/nsf-grant-guide/SKILL.md +206 -0
- package/skills/research/funding/open-science-guide/SKILL.md +255 -0
- package/skills/research/funding/zenodo-api/SKILL.md +174 -0
- package/skills/research/methodology/action-research-guide/SKILL.md +201 -0
- package/skills/research/methodology/experimental-design-guide/SKILL.md +236 -0
- package/skills/research/methodology/grad-school-guide/SKILL.md +182 -0
- package/skills/research/methodology/grounded-theory-guide/SKILL.md +171 -0
- package/skills/research/methodology/mixed-methods-guide/SKILL.md +208 -0
- package/skills/research/methodology/qualitative-research-guide/SKILL.md +234 -0
- package/skills/research/methodology/scientify-idea-generation/SKILL.md +222 -0
- package/skills/research/paper-review/paper-reading-assistant/SKILL.md +266 -0
- package/skills/research/paper-review/peer-review-guide/SKILL.md +227 -0
- package/skills/research/paper-review/rebuttal-writing-guide/SKILL.md +185 -0
- package/skills/research/paper-review/scientify-write-review-paper/SKILL.md +209 -0
- package/skills/tools/code-exec/jupyter-notebook-guide/SKILL.md +178 -0
- package/skills/tools/code-exec/python-reproducibility-guide/SKILL.md +341 -0
- package/skills/tools/code-exec/r-reproducibility-guide/SKILL.md +236 -0
- package/skills/tools/code-exec/sandbox-execution-guide/SKILL.md +221 -0
- package/skills/tools/diagram/mermaid-diagram-guide/SKILL.md +269 -0
- package/skills/tools/diagram/plantuml-guide/SKILL.md +397 -0
- package/skills/tools/diagram/scientific-illustration-guide/SKILL.md +225 -0
- package/skills/tools/document/anystyle-api/SKILL.md +199 -0
- package/skills/tools/document/grobid-pdf-parsing/SKILL.md +294 -0
- package/skills/tools/document/markdown-academic-guide/SKILL.md +217 -0
- package/skills/tools/document/pdf-extraction-guide/SKILL.md +321 -0
- package/skills/tools/knowledge-graph/knowledge-graph-construction/SKILL.md +306 -0
- package/skills/tools/knowledge-graph/ontology-design-guide/SKILL.md +214 -0
- package/skills/tools/knowledge-graph/rag-methodology-guide/SKILL.md +325 -0
- package/skills/tools/ocr-translate/formula-recognition-guide/SKILL.md +367 -0
- package/skills/tools/ocr-translate/handwriting-recognition-guide/SKILL.md +211 -0
- package/skills/tools/ocr-translate/latex-ocr-guide/SKILL.md +204 -0
- package/skills/tools/ocr-translate/multilingual-research-guide/SKILL.md +234 -0
- package/skills/tools/scraping/academic-web-scraping/SKILL.md +326 -0
- package/skills/tools/scraping/api-data-collection-guide/SKILL.md +301 -0
- package/skills/tools/scraping/web-scraping-ethics-guide/SKILL.md +250 -0
- package/skills/writing/citation/bibtex-management-guide/SKILL.md +246 -0
- package/skills/writing/citation/citation-style-guide/SKILL.md +248 -0
- package/skills/writing/citation/reference-manager-comparison/SKILL.md +208 -0
- package/skills/writing/citation/zotero-api/SKILL.md +188 -0
- package/skills/writing/composition/abstract-writing-guide/SKILL.md +188 -0
- package/skills/writing/composition/discussion-writing-guide/SKILL.md +194 -0
- package/skills/writing/composition/introduction-writing-guide/SKILL.md +194 -0
- package/skills/writing/composition/literature-review-writing/SKILL.md +196 -0
- package/skills/writing/composition/methods-section-guide/SKILL.md +185 -0
- package/skills/writing/composition/response-to-reviewers/SKILL.md +215 -0
- package/skills/writing/composition/scientific-writing-guide/SKILL.md +152 -0
- package/skills/writing/latex/bibliography-management-guide/SKILL.md +206 -0
- package/skills/writing/latex/latex-drawing-guide/SKILL.md +234 -0
- package/skills/writing/latex/latex-ecosystem-guide/SKILL.md +240 -0
- package/skills/writing/latex/math-typesetting-guide/SKILL.md +231 -0
- package/skills/writing/latex/overleaf-collaboration-guide/SKILL.md +211 -0
- package/skills/writing/latex/tikz-diagrams-guide/SKILL.md +211 -0
- package/skills/writing/polish/academic-translation-guide/SKILL.md +175 -0
- package/skills/writing/polish/academic-writing-refiner/SKILL.md +143 -0
- package/skills/writing/polish/ai-writing-humanizer/SKILL.md +178 -0
- package/skills/writing/polish/grammar-checker-guide/SKILL.md +184 -0
- package/skills/writing/polish/plagiarism-detection-guide/SKILL.md +167 -0
- package/skills/writing/templates/beamer-presentation-guide/SKILL.md +263 -0
- package/skills/writing/templates/conference-paper-template/SKILL.md +219 -0
- package/skills/writing/templates/thesis-template-guide/SKILL.md +200 -0
- package/skills/writing/templates/thesis-writing-guide/SKILL.md +220 -0
- package/src/tools/arxiv.ts +131 -0
- package/src/tools/crossref.ts +112 -0
- package/src/tools/openalex.ts +174 -0
- package/src/tools/pubmed.ts +166 -0
- package/src/tools/semantic-scholar.ts +108 -0
- package/src/tools/unpaywall.ts +58 -0
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: paper-reading-assistant
|
|
3
|
+
description: "AI-assisted paper reading, PDF Q&A, and summarization workflows"
|
|
4
|
+
metadata:
|
|
5
|
+
openclaw:
|
|
6
|
+
emoji: "reader"
|
|
7
|
+
category: "research"
|
|
8
|
+
subcategory: "paper-review"
|
|
9
|
+
keywords: ["paper reading assistant", "PDF Q&A", "document understanding", "paper summarization"]
|
|
10
|
+
source: "wentor-research-plugins"
|
|
11
|
+
---
|
|
12
|
+
|
|
13
|
+
# Paper Reading Assistant
|
|
14
|
+
|
|
15
|
+
Systematic workflows for reading, annotating, and extracting insights from academic papers, including AI-assisted summarization and critical analysis techniques.
|
|
16
|
+
|
|
17
|
+
## The Three-Pass Reading Method
|
|
18
|
+
|
|
19
|
+
Srinivasan Keshav's three-pass approach provides a structured way to read papers at increasing depth:
|
|
20
|
+
|
|
21
|
+
### Pass 1: Survey (5-10 minutes)
|
|
22
|
+
|
|
23
|
+
Read only:
|
|
24
|
+
1. Title, abstract, and keywords
|
|
25
|
+
2. Introduction (first and last paragraph only)
|
|
26
|
+
3. Section headings (all of them)
|
|
27
|
+
4. Conclusion
|
|
28
|
+
5. Glance at figures and tables (read captions)
|
|
29
|
+
6. Check the reference list for familiar papers
|
|
30
|
+
|
|
31
|
+
After Pass 1, you should know:
|
|
32
|
+
- **Category**: Is this an empirical study, theoretical contribution, system paper, survey?
|
|
33
|
+
- **Context**: What related work does it build on?
|
|
34
|
+
- **Correctness**: Do the assumptions and claims seem reasonable?
|
|
35
|
+
- **Contributions**: What are the main claimed contributions?
|
|
36
|
+
- **Clarity**: Is the paper well-written?
|
|
37
|
+
|
|
38
|
+
**Decision**: Stop here if the paper is not relevant, or continue to Pass 2.
|
|
39
|
+
|
|
40
|
+
### Pass 2: Comprehension (30-60 minutes)
|
|
41
|
+
|
|
42
|
+
Read the full paper, but skip proofs and complex derivations:
|
|
43
|
+
1. Examine figures and tables carefully
|
|
44
|
+
2. Mark unread references for later
|
|
45
|
+
3. Annotate key claims, methods, and results
|
|
46
|
+
4. Try to summarize each section in one sentence
|
|
47
|
+
|
|
48
|
+
After Pass 2, you should be able to:
|
|
49
|
+
- Summarize the paper's main contribution to someone else
|
|
50
|
+
- Identify the key evidence supporting the claims
|
|
51
|
+
- List the paper's strengths and weaknesses
|
|
52
|
+
|
|
53
|
+
### Pass 3: Recreation (1-4 hours)
|
|
54
|
+
|
|
55
|
+
For papers you need to deeply understand:
|
|
56
|
+
1. Try to mentally re-derive the key results
|
|
57
|
+
2. Challenge every assumption
|
|
58
|
+
3. Identify implicit assumptions not stated
|
|
59
|
+
4. Think about how you would improve the work
|
|
60
|
+
5. Compare the approach to alternatives
|
|
61
|
+
|
|
62
|
+
## Structured Note-Taking Template
|
|
63
|
+
|
|
64
|
+
Use a consistent template for every paper you read:
|
|
65
|
+
|
|
66
|
+
```markdown
|
|
67
|
+
# Paper Notes: [Short Title]
|
|
68
|
+
|
|
69
|
+
## Metadata
|
|
70
|
+
- **Title**: Full title
|
|
71
|
+
- **Authors**: First Author et al. (Year)
|
|
72
|
+
- **Venue**: Conference/Journal
|
|
73
|
+
- **DOI/URL**: link
|
|
74
|
+
- **Date read**: YYYY-MM-DD
|
|
75
|
+
|
|
76
|
+
## Summary (2-3 sentences)
|
|
77
|
+
What does this paper do, and what are the main findings?
|
|
78
|
+
|
|
79
|
+
## Problem
|
|
80
|
+
What problem does this paper address? Why is it important?
|
|
81
|
+
|
|
82
|
+
## Method
|
|
83
|
+
How do they approach the problem? Key technical details.
|
|
84
|
+
|
|
85
|
+
## Key Results
|
|
86
|
+
- Result 1: ...
|
|
87
|
+
- Result 2: ...
|
|
88
|
+
- Result 3: ...
|
|
89
|
+
|
|
90
|
+
## Strengths
|
|
91
|
+
- Strength 1: ...
|
|
92
|
+
- Strength 2: ...
|
|
93
|
+
|
|
94
|
+
## Weaknesses / Limitations
|
|
95
|
+
- Weakness 1: ...
|
|
96
|
+
- Weakness 2: ...
|
|
97
|
+
|
|
98
|
+
## Questions / Things I Don't Understand
|
|
99
|
+
- Question 1: ...
|
|
100
|
+
|
|
101
|
+
## Relevance to My Work
|
|
102
|
+
How does this connect to my research? What can I use?
|
|
103
|
+
|
|
104
|
+
## Key References to Follow Up
|
|
105
|
+
- [Author, Year] - Why it seems relevant
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
## AI-Assisted Paper Analysis
|
|
109
|
+
|
|
110
|
+
### Summarization Prompts
|
|
111
|
+
|
|
112
|
+
Use structured prompts to extract specific information from papers:
|
|
113
|
+
|
|
114
|
+
```python
|
|
115
|
+
# Prompt template for paper summarization
|
|
116
|
+
summarize_prompt = """Read the following academic paper and provide:
|
|
117
|
+
|
|
118
|
+
1. ONE-SENTENCE SUMMARY: The core contribution in a single sentence.
|
|
119
|
+
|
|
120
|
+
2. KEY FINDINGS (3-5 bullet points):
|
|
121
|
+
- Finding 1 with specific numbers/results
|
|
122
|
+
- Finding 2 ...
|
|
123
|
+
|
|
124
|
+
3. METHODOLOGY: Describe the approach in 2-3 sentences.
|
|
125
|
+
|
|
126
|
+
4. LIMITATIONS: List 2-3 limitations acknowledged or unacknowledged.
|
|
127
|
+
|
|
128
|
+
5. RELEVANCE: How does this relate to [your research topic]?
|
|
129
|
+
|
|
130
|
+
Paper text:
|
|
131
|
+
{paper_text}
|
|
132
|
+
"""
|
|
133
|
+
|
|
134
|
+
# Prompt for critical analysis
|
|
135
|
+
critique_prompt = """Analyze the following paper critically:
|
|
136
|
+
|
|
137
|
+
1. VALIDITY: Are the experimental design and statistical analyses sound?
|
|
138
|
+
Identify any threats to internal/external validity.
|
|
139
|
+
|
|
140
|
+
2. NOVELTY: What is genuinely new? What is incremental?
|
|
141
|
+
|
|
142
|
+
3. REPRODUCIBILITY: Could you replicate this study from the description given?
|
|
143
|
+
What information is missing?
|
|
144
|
+
|
|
145
|
+
4. ALTERNATIVE EXPLANATIONS: Are there alternative interpretations
|
|
146
|
+
of the results that the authors do not consider?
|
|
147
|
+
|
|
148
|
+
5. FOLLOW-UP QUESTIONS: What would you want to investigate next?
|
|
149
|
+
|
|
150
|
+
Paper text:
|
|
151
|
+
{paper_text}
|
|
152
|
+
"""
|
|
153
|
+
```
|
|
154
|
+
|
|
155
|
+
### PDF Processing Pipeline
|
|
156
|
+
|
|
157
|
+
```python
|
|
158
|
+
import fitz # PyMuPDF
|
|
159
|
+
|
|
160
|
+
def extract_paper_text(pdf_path):
|
|
161
|
+
"""Extract structured text from an academic paper PDF."""
|
|
162
|
+
doc = fitz.open(pdf_path)
|
|
163
|
+
sections = []
|
|
164
|
+
current_section = {"heading": "Preamble", "text": ""}
|
|
165
|
+
|
|
166
|
+
for page_num, page in enumerate(doc):
|
|
167
|
+
blocks = page.get_text("dict")["blocks"]
|
|
168
|
+
for block in blocks:
|
|
169
|
+
if "lines" not in block:
|
|
170
|
+
continue
|
|
171
|
+
for line in block["lines"]:
|
|
172
|
+
text = "".join(span["text"] for span in line["spans"])
|
|
173
|
+
font_size = max(span["size"] for span in line["spans"])
|
|
174
|
+
is_bold = any("Bold" in span.get("font", "") for span in line["spans"])
|
|
175
|
+
|
|
176
|
+
# Heuristic: detect section headings
|
|
177
|
+
if is_bold and font_size > 11 and len(text.strip()) < 80:
|
|
178
|
+
if current_section["text"].strip():
|
|
179
|
+
sections.append(current_section)
|
|
180
|
+
current_section = {"heading": text.strip(), "text": ""}
|
|
181
|
+
else:
|
|
182
|
+
current_section["text"] += text + " "
|
|
183
|
+
|
|
184
|
+
if current_section["text"].strip():
|
|
185
|
+
sections.append(current_section)
|
|
186
|
+
|
|
187
|
+
doc.close()
|
|
188
|
+
return sections
|
|
189
|
+
|
|
190
|
+
# Extract and display
|
|
191
|
+
sections = extract_paper_text("paper.pdf")
|
|
192
|
+
for s in sections:
|
|
193
|
+
print(f"\n## {s['heading']}")
|
|
194
|
+
print(s['text'][:200] + "...")
|
|
195
|
+
```
|
|
196
|
+
|
|
197
|
+
### Batch Paper Processing
|
|
198
|
+
|
|
199
|
+
```python
|
|
200
|
+
import os
|
|
201
|
+
import json
|
|
202
|
+
|
|
203
|
+
def process_paper_batch(pdf_dir, output_file):
|
|
204
|
+
"""Process a batch of papers and save structured notes."""
|
|
205
|
+
results = []
|
|
206
|
+
|
|
207
|
+
for filename in os.listdir(pdf_dir):
|
|
208
|
+
if not filename.endswith(".pdf"):
|
|
209
|
+
continue
|
|
210
|
+
|
|
211
|
+
pdf_path = os.path.join(pdf_dir, filename)
|
|
212
|
+
sections = extract_paper_text(pdf_path)
|
|
213
|
+
|
|
214
|
+
# Find title (usually first bold text or first line)
|
|
215
|
+
title = sections[0]["heading"] if sections else filename
|
|
216
|
+
|
|
217
|
+
# Find abstract
|
|
218
|
+
abstract = ""
|
|
219
|
+
for s in sections:
|
|
220
|
+
if "abstract" in s["heading"].lower():
|
|
221
|
+
abstract = s["text"].strip()
|
|
222
|
+
break
|
|
223
|
+
|
|
224
|
+
results.append({
|
|
225
|
+
"filename": filename,
|
|
226
|
+
"title": title,
|
|
227
|
+
"abstract": abstract,
|
|
228
|
+
"num_sections": len(sections),
|
|
229
|
+
"total_chars": sum(len(s["text"]) for s in sections)
|
|
230
|
+
})
|
|
231
|
+
|
|
232
|
+
with open(output_file, "w") as f:
|
|
233
|
+
json.dump(results, f, indent=2)
|
|
234
|
+
|
|
235
|
+
return results
|
|
236
|
+
```
|
|
237
|
+
|
|
238
|
+
## Annotation Tools Comparison
|
|
239
|
+
|
|
240
|
+
| Tool | Platform | Highlights | PDF Annotation | AI Features | Collaboration |
|
|
241
|
+
|------|----------|-----------|---------------|-------------|---------------|
|
|
242
|
+
| Zotero + ZotFile | All | Reference management + PDF | Yes | No (plugins available) | Group libraries |
|
|
243
|
+
| Paperpile | Web/Chrome | Google Docs integration | Yes | No | Shared folders |
|
|
244
|
+
| ReadCube Papers | All | Smart citations | Yes | Recommendations | Shared libraries |
|
|
245
|
+
| Semantic Reader | Web | AI-augmented reading | Yes | Inline explanations, TLDRs | No |
|
|
246
|
+
| Elicit | Web | AI paper search | No | Automated extraction | Tables |
|
|
247
|
+
| Scholarcy | Web | Flashcard summaries | Yes | Auto-summarization | No |
|
|
248
|
+
|
|
249
|
+
## Reading Strategies by Paper Type
|
|
250
|
+
|
|
251
|
+
| Paper Type | Focus On | Time Budget |
|
|
252
|
+
|-----------|----------|-------------|
|
|
253
|
+
| **Seminal paper** | Full three-pass reading, understand every detail | 3-4 hours |
|
|
254
|
+
| **Survey/review** | Section headings, taxonomy, open questions | 1-2 hours |
|
|
255
|
+
| **Methods paper** | Algorithm/procedure sections, pseudocode, evaluation | 1-2 hours |
|
|
256
|
+
| **Results paper** | Figures, tables, statistical tests, effect sizes | 30-60 min |
|
|
257
|
+
| **Position paper** | Arguments, assumptions, counterarguments | 30-60 min |
|
|
258
|
+
| **Related work (peripheral)** | Abstract + conclusion only (Pass 1) | 5-10 min |
|
|
259
|
+
|
|
260
|
+
## Building a Paper Reading Habit
|
|
261
|
+
|
|
262
|
+
1. **Set a regular schedule**: Read 2-3 papers per week during dedicated time blocks.
|
|
263
|
+
2. **Maintain a reading log**: Track papers read with dates, ratings, and one-line takeaways.
|
|
264
|
+
3. **Use a reference manager**: Add papers to your library as you read them, with tags and notes.
|
|
265
|
+
4. **Discuss papers**: Join or start a reading group; explaining papers to others deepens understanding.
|
|
266
|
+
5. **Connect to your research**: End every reading session by writing one sentence about how the paper relates to your own work.
|
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: peer-review-guide
|
|
3
|
+
description: "Conduct thorough, constructive peer reviews and evaluate research papers crit..."
|
|
4
|
+
metadata:
|
|
5
|
+
openclaw:
|
|
6
|
+
emoji: "detective"
|
|
7
|
+
category: "research"
|
|
8
|
+
subcategory: "paper-review"
|
|
9
|
+
keywords: ["peer review", "reviewer comments", "paper evaluation", "paper reading assistant", "manuscript assessment"]
|
|
10
|
+
source: "wentor"
|
|
11
|
+
---
|
|
12
|
+
|
|
13
|
+
# Peer Review Guide
|
|
14
|
+
|
|
15
|
+
A skill for conducting thorough, fair, and constructive peer reviews of academic manuscripts. Covers systematic evaluation frameworks, writing effective reviewer reports, and common evaluation criteria across disciplines.
|
|
16
|
+
|
|
17
|
+
## Review Process Overview
|
|
18
|
+
|
|
19
|
+
### Systematic Reading Strategy
|
|
20
|
+
|
|
21
|
+
```
|
|
22
|
+
First Pass (30 min): Skim for overall assessment
|
|
23
|
+
- Read title, abstract, introduction, conclusion
|
|
24
|
+
- Scan figures and tables
|
|
25
|
+
- Assess: Is this paper in scope? Is the question important?
|
|
26
|
+
|
|
27
|
+
Second Pass (60-90 min): Detailed critical reading
|
|
28
|
+
- Read the full paper carefully
|
|
29
|
+
- Annotate unclear points, potential errors, missing references
|
|
30
|
+
- Check methodology, statistical analyses, interpretation
|
|
31
|
+
|
|
32
|
+
Third Pass (30-60 min): Constructive feedback
|
|
33
|
+
- Formulate your major and minor comments
|
|
34
|
+
- Identify strengths to highlight
|
|
35
|
+
- Draft your review report
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
## Evaluation Framework
|
|
39
|
+
|
|
40
|
+
### Core Assessment Dimensions
|
|
41
|
+
|
|
42
|
+
```python
|
|
43
|
+
def evaluate_manuscript(assessments: dict) -> dict:
|
|
44
|
+
"""
|
|
45
|
+
Structured manuscript evaluation across key dimensions.
|
|
46
|
+
|
|
47
|
+
Args:
|
|
48
|
+
assessments: Dict mapping dimension to score (1-5) and comments
|
|
49
|
+
"""
|
|
50
|
+
dimensions = {
|
|
51
|
+
'novelty': {
|
|
52
|
+
'weight': 0.20,
|
|
53
|
+
'questions': [
|
|
54
|
+
'Does this paper present new findings, methods, or perspectives?',
|
|
55
|
+
'How does it advance beyond existing work?',
|
|
56
|
+
'Is the contribution incremental or substantial?'
|
|
57
|
+
]
|
|
58
|
+
},
|
|
59
|
+
'significance': {
|
|
60
|
+
'weight': 0.20,
|
|
61
|
+
'questions': [
|
|
62
|
+
'Is the research question important to the field?',
|
|
63
|
+
'Will this work influence future research or practice?',
|
|
64
|
+
'Is the scope appropriate for this journal?'
|
|
65
|
+
]
|
|
66
|
+
},
|
|
67
|
+
'methodology': {
|
|
68
|
+
'weight': 0.25,
|
|
69
|
+
'questions': [
|
|
70
|
+
'Is the study design appropriate for the research question?',
|
|
71
|
+
'Are methods described in sufficient detail to reproduce?',
|
|
72
|
+
'Are statistical analyses appropriate and correctly applied?',
|
|
73
|
+
'Are there threats to validity that are not addressed?'
|
|
74
|
+
]
|
|
75
|
+
},
|
|
76
|
+
'presentation': {
|
|
77
|
+
'weight': 0.15,
|
|
78
|
+
'questions': [
|
|
79
|
+
'Is the paper clearly written and well organized?',
|
|
80
|
+
'Are figures and tables informative and properly labeled?',
|
|
81
|
+
'Is the paper an appropriate length?'
|
|
82
|
+
]
|
|
83
|
+
},
|
|
84
|
+
'literature': {
|
|
85
|
+
'weight': 0.10,
|
|
86
|
+
'questions': [
|
|
87
|
+
'Is the related work section comprehensive?',
|
|
88
|
+
'Are key prior studies cited and discussed?',
|
|
89
|
+
'Is the paper properly positioned within the literature?'
|
|
90
|
+
]
|
|
91
|
+
},
|
|
92
|
+
'reproducibility': {
|
|
93
|
+
'weight': 0.10,
|
|
94
|
+
'questions': [
|
|
95
|
+
'Are data and code available or described sufficiently?',
|
|
96
|
+
'Could another researcher replicate this study?',
|
|
97
|
+
'Are all materials, procedures, and analyses documented?'
|
|
98
|
+
]
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
overall_score = 0
|
|
103
|
+
evaluation = {}
|
|
104
|
+
for dim, info in dimensions.items():
|
|
105
|
+
score = assessments.get(dim, {}).get('score', 3)
|
|
106
|
+
comment = assessments.get(dim, {}).get('comment', '')
|
|
107
|
+
overall_score += score * info['weight']
|
|
108
|
+
evaluation[dim] = {
|
|
109
|
+
'score': score,
|
|
110
|
+
'weight': info['weight'],
|
|
111
|
+
'weighted_score': score * info['weight'],
|
|
112
|
+
'comment': comment
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
evaluation['overall_score'] = round(overall_score, 2)
|
|
116
|
+
evaluation['recommendation'] = (
|
|
117
|
+
'Accept' if overall_score >= 4.0
|
|
118
|
+
else 'Minor Revision' if overall_score >= 3.5
|
|
119
|
+
else 'Major Revision' if overall_score >= 2.5
|
|
120
|
+
else 'Reject'
|
|
121
|
+
)
|
|
122
|
+
|
|
123
|
+
return evaluation
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
## Writing the Review Report
|
|
127
|
+
|
|
128
|
+
### Structure Template
|
|
129
|
+
|
|
130
|
+
```
|
|
131
|
+
SUMMARY (2-3 sentences)
|
|
132
|
+
Briefly describe what the paper does and its main contribution.
|
|
133
|
+
This shows the authors you read and understood their work.
|
|
134
|
+
|
|
135
|
+
STRENGTHS (3-5 bullet points)
|
|
136
|
+
- Specific positive aspects
|
|
137
|
+
- "The experimental design is rigorous, with appropriate controls..."
|
|
138
|
+
- "The visualization in Figure 3 effectively communicates..."
|
|
139
|
+
|
|
140
|
+
MAJOR COMMENTS (numbered, typically 2-5)
|
|
141
|
+
Issues that must be addressed before the paper can be accepted.
|
|
142
|
+
These concern correctness, validity, or significant gaps.
|
|
143
|
+
|
|
144
|
+
1. [Specific concern with reference to section/page]
|
|
145
|
+
"In Section 3.2, the assumption that X holds is questionable
|
|
146
|
+
because [reason]. The authors should either provide evidence
|
|
147
|
+
for this assumption or discuss what happens if it is relaxed."
|
|
148
|
+
|
|
149
|
+
2. [Another major concern]
|
|
150
|
+
|
|
151
|
+
MINOR COMMENTS (numbered, typically 3-10)
|
|
152
|
+
Suggestions for improvement that are not critical but would
|
|
153
|
+
strengthen the paper.
|
|
154
|
+
|
|
155
|
+
1. "On page 5, line 23: consider citing Smith et al. (2023)
|
|
156
|
+
who address a similar phenomenon."
|
|
157
|
+
|
|
158
|
+
TYPOS AND FORMATTING (optional, brief list)
|
|
159
|
+
- Page 3, line 14: "effect" should be "affect"
|
|
160
|
+
- Table 2: column headers are cut off
|
|
161
|
+
|
|
162
|
+
CONFIDENTIAL COMMENTS TO THE EDITOR (separate section)
|
|
163
|
+
Overall assessment, conflicts of interest, ethical concerns.
|
|
164
|
+
This is NOT shared with the authors.
|
|
165
|
+
```
|
|
166
|
+
|
|
167
|
+
### Writing Effective Comments
|
|
168
|
+
|
|
169
|
+
```python
|
|
170
|
+
def format_review_comment(comment_type: str, section: str,
|
|
171
|
+
issue: str, suggestion: str) -> str:
|
|
172
|
+
"""
|
|
173
|
+
Format a review comment following best practices.
|
|
174
|
+
|
|
175
|
+
Args:
|
|
176
|
+
comment_type: 'major' or 'minor'
|
|
177
|
+
section: Where in the paper (e.g., 'Section 3.2, page 7')
|
|
178
|
+
issue: What the problem is
|
|
179
|
+
suggestion: How to address it
|
|
180
|
+
"""
|
|
181
|
+
return (
|
|
182
|
+
f"[{comment_type.upper()}] {section}\n"
|
|
183
|
+
f"Issue: {issue}\n"
|
|
184
|
+
f"Suggestion: {suggestion}\n"
|
|
185
|
+
)
|
|
186
|
+
|
|
187
|
+
# Good review comment (specific, actionable, constructive):
|
|
188
|
+
print(format_review_comment(
|
|
189
|
+
'major',
|
|
190
|
+
'Section 4.1, Table 3',
|
|
191
|
+
'The comparison with baseline methods uses different evaluation metrics '
|
|
192
|
+
'(accuracy for the proposed method, F1 for baselines), making the '
|
|
193
|
+
'comparison unfair.',
|
|
194
|
+
'Please report the same set of metrics (precision, recall, F1, accuracy) '
|
|
195
|
+
'for all methods, including the proposed approach, to enable fair comparison.'
|
|
196
|
+
))
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
## Common Red Flags to Check
|
|
200
|
+
|
|
201
|
+
### Statistical Issues
|
|
202
|
+
- p-hacking: Multiple comparisons without correction
|
|
203
|
+
- Selective reporting: Only positive results shown
|
|
204
|
+
- Inappropriate tests: Parametric tests on non-normal data
|
|
205
|
+
- Missing effect sizes: Only p-values reported
|
|
206
|
+
- Small sample with large claims: Low power, inflated effects
|
|
207
|
+
|
|
208
|
+
### Methodological Issues
|
|
209
|
+
- Lack of control group or baseline
|
|
210
|
+
- Data leakage in ML (test data used during training/validation)
|
|
211
|
+
- Confounding variables not addressed
|
|
212
|
+
- Circular reasoning in analysis
|
|
213
|
+
|
|
214
|
+
### Writing Issues
|
|
215
|
+
- Claims not supported by the data presented
|
|
216
|
+
- Overclaiming in the title or abstract
|
|
217
|
+
- Missing limitations section
|
|
218
|
+
- Insufficient detail for reproducibility
|
|
219
|
+
|
|
220
|
+
## Ethical Responsibilities of Reviewers
|
|
221
|
+
|
|
222
|
+
- Declare conflicts of interest promptly
|
|
223
|
+
- Maintain confidentiality -- do not share the manuscript or discuss it
|
|
224
|
+
- Complete reviews within the agreed timeline (typically 2-4 weeks)
|
|
225
|
+
- Be constructive -- the goal is to improve the paper, not to display superiority
|
|
226
|
+
- Do not use ideas from the manuscript under review in your own work
|
|
227
|
+
- If you suspect misconduct (fabrication, falsification, plagiarism), report to the editor confidentially
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: rebuttal-writing-guide
|
|
3
|
+
description: "Write effective rebuttals to reviewer comments for journal submissions"
|
|
4
|
+
metadata:
|
|
5
|
+
openclaw:
|
|
6
|
+
emoji: "memo"
|
|
7
|
+
category: "research"
|
|
8
|
+
subcategory: "paper-review"
|
|
9
|
+
keywords: ["rebuttal letter", "reviewer response", "revision", "peer review", "manuscript revision", "author response"]
|
|
10
|
+
source: "wentor-research-plugins"
|
|
11
|
+
---
|
|
12
|
+
|
|
13
|
+
# Rebuttal Writing Guide
|
|
14
|
+
|
|
15
|
+
A skill for writing effective, professional responses to reviewer comments during the peer review revision process. Covers response letter structure, strategies for addressing criticism constructively, handling unfair reviews, and organizing major revisions.
|
|
16
|
+
|
|
17
|
+
## Response Letter Structure
|
|
18
|
+
|
|
19
|
+
### Standard Format
|
|
20
|
+
|
|
21
|
+
```
|
|
22
|
+
Response Letter Template:
|
|
23
|
+
|
|
24
|
+
Dear Editor and Reviewers,
|
|
25
|
+
|
|
26
|
+
Thank you for your thoughtful review of our manuscript
|
|
27
|
+
"[Title]" (Manuscript ID: [ID]). We appreciate the
|
|
28
|
+
constructive feedback and have carefully addressed all
|
|
29
|
+
comments. Below, we provide point-by-point responses.
|
|
30
|
+
|
|
31
|
+
Major changes include:
|
|
32
|
+
- [Summary of change 1]
|
|
33
|
+
- [Summary of change 2]
|
|
34
|
+
- [Summary of change 3]
|
|
35
|
+
|
|
36
|
+
In the revised manuscript, all changes are highlighted in blue.
|
|
37
|
+
|
|
38
|
+
---
|
|
39
|
+
|
|
40
|
+
RESPONSE TO REVIEWER 1
|
|
41
|
+
|
|
42
|
+
Comment R1.1: [Exact quote of reviewer comment]
|
|
43
|
+
|
|
44
|
+
Response: [Your response]
|
|
45
|
+
|
|
46
|
+
Changes made: [Description of what was changed and where]
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
Comment R1.2: [Next comment]
|
|
51
|
+
...
|
|
52
|
+
|
|
53
|
+
RESPONSE TO REVIEWER 2
|
|
54
|
+
...
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
### Formatting Best Practices
|
|
58
|
+
|
|
59
|
+
```python
|
|
60
|
+
def format_response(reviewer_num: int, comment_num: int,
|
|
61
|
+
comment: str, response: str,
|
|
62
|
+
changes: str = None) -> str:
|
|
63
|
+
"""
|
|
64
|
+
Format a single reviewer response entry.
|
|
65
|
+
|
|
66
|
+
Args:
|
|
67
|
+
reviewer_num: Reviewer number (1, 2, 3...)
|
|
68
|
+
comment_num: Comment number within this reviewer
|
|
69
|
+
comment: The reviewer's original comment (verbatim)
|
|
70
|
+
response: Your response
|
|
71
|
+
changes: Description of manuscript changes made
|
|
72
|
+
"""
|
|
73
|
+
entry = (
|
|
74
|
+
f"**Comment R{reviewer_num}.{comment_num}:**\n"
|
|
75
|
+
f"*{comment}*\n\n"
|
|
76
|
+
f"**Response:**\n{response}\n"
|
|
77
|
+
)
|
|
78
|
+
|
|
79
|
+
if changes:
|
|
80
|
+
entry += f"\n**Changes made:** {changes}\n"
|
|
81
|
+
|
|
82
|
+
return entry
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
## Response Strategies
|
|
86
|
+
|
|
87
|
+
### Handling Different Comment Types
|
|
88
|
+
|
|
89
|
+
```
|
|
90
|
+
Agreement (easiest -- just do it):
|
|
91
|
+
Reviewer: "Table 2 should include confidence intervals."
|
|
92
|
+
Response: "We agree. We have added 95% confidence intervals to
|
|
93
|
+
Table 2 (see revised manuscript, p. 12)."
|
|
94
|
+
|
|
95
|
+
Partial agreement (do what you can, explain what you cannot):
|
|
96
|
+
Reviewer: "The authors should include 5 additional control variables."
|
|
97
|
+
Response: "We appreciate this suggestion. We have added controls for
|
|
98
|
+
age and income, which are theoretically motivated (p. 15).
|
|
99
|
+
We could not include education, occupation, and region
|
|
100
|
+
because [specific reason]. However, we now discuss this
|
|
101
|
+
limitation in Section 5.2."
|
|
102
|
+
|
|
103
|
+
Respectful disagreement (provide evidence):
|
|
104
|
+
Reviewer: "The sample is too small to draw any conclusions."
|
|
105
|
+
Response: "We understand this concern. However, our power analysis
|
|
106
|
+
(now included as Supplementary Table S1) shows that our
|
|
107
|
+
sample of N=85 provides 80% power to detect a medium
|
|
108
|
+
effect (d=0.5) at alpha=0.05. Furthermore, our primary
|
|
109
|
+
effect sizes were large (d=0.8-1.2), well above the
|
|
110
|
+
detectable threshold. We have added this justification
|
|
111
|
+
to Section 3.1 (p. 8)."
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
### Golden Rules for Rebuttals
|
|
115
|
+
|
|
116
|
+
```
|
|
117
|
+
DO:
|
|
118
|
+
- Thank reviewers (sincerely, not sarcastically)
|
|
119
|
+
- Address EVERY comment, even minor ones
|
|
120
|
+
- Quote the reviewer's comment verbatim before responding
|
|
121
|
+
- Be specific about what changed and where (page/section numbers)
|
|
122
|
+
- Provide evidence for disagreements (citations, analyses, data)
|
|
123
|
+
- Run additional analyses when requested if feasible
|
|
124
|
+
- Use a respectful, professional tone throughout
|
|
125
|
+
- Keep responses concise but thorough
|
|
126
|
+
|
|
127
|
+
DO NOT:
|
|
128
|
+
- Ignore any comment (even if trivial)
|
|
129
|
+
- Be defensive or dismissive
|
|
130
|
+
- Argue from authority ("We are experts in this area")
|
|
131
|
+
- Lie about changes you did not actually make
|
|
132
|
+
- Attack the reviewer's competence
|
|
133
|
+
- Submit essentially the same manuscript with a new cover letter
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
## Handling Difficult Reviews
|
|
137
|
+
|
|
138
|
+
### When a Reviewer Is Wrong
|
|
139
|
+
|
|
140
|
+
```
|
|
141
|
+
Situation: The reviewer misunderstood your method.
|
|
142
|
+
Strategy: Clarify without blaming the reviewer.
|
|
143
|
+
|
|
144
|
+
Bad: "The reviewer clearly did not read our paper carefully."
|
|
145
|
+
|
|
146
|
+
Good: "We appreciate this comment and recognize that our
|
|
147
|
+
description of the method may not have been sufficiently
|
|
148
|
+
clear. We have rewritten Section 3.2 to clarify that
|
|
149
|
+
[explanation]. The key distinction is [point], which we
|
|
150
|
+
now make explicit on p. 10."
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
### When a Reviewer Requests Impossible Changes
|
|
154
|
+
|
|
155
|
+
```
|
|
156
|
+
Situation: The reviewer asks for data you do not have.
|
|
157
|
+
Strategy: Acknowledge, explain constraints, offer alternatives.
|
|
158
|
+
|
|
159
|
+
Response: "This is an excellent suggestion that would strengthen
|
|
160
|
+
the study. Unfortunately, our dataset does not include
|
|
161
|
+
[variable] because [reason]. As an alternative, we have
|
|
162
|
+
[what you did instead]. We have also added this as a
|
|
163
|
+
limitation and future direction (Section 5.3, p. 18)."
|
|
164
|
+
```
|
|
165
|
+
|
|
166
|
+
## Organizing a Major Revision
|
|
167
|
+
|
|
168
|
+
### Workflow for Revision
|
|
169
|
+
|
|
170
|
+
```
|
|
171
|
+
1. Read ALL reviews completely before making any changes
|
|
172
|
+
2. Create a spreadsheet categorizing each comment:
|
|
173
|
+
- Reviewer, comment number, category, difficulty, action
|
|
174
|
+
3. Address easy changes first (typos, formatting, missing refs)
|
|
175
|
+
4. Tackle substantive comments in order of importance
|
|
176
|
+
5. Run any new analyses requested by reviewers
|
|
177
|
+
6. Revise the manuscript with tracked changes
|
|
178
|
+
7. Write the response letter point by point
|
|
179
|
+
8. Have a co-author review both the response and revised manuscript
|
|
180
|
+
9. Submit within the deadline (ask for extension if needed)
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
## Cover Letter for Resubmission
|
|
184
|
+
|
|
185
|
+
The cover letter to the editor should briefly summarize the major changes, highlight the most significant improvements, and note any disagreements with reviewers that you would like the editor to adjudicate. Keep it to one page. The detailed point-by-point responses belong in the separate response document, not the cover letter.
|